自定义的HorizontalScrollView与Viewpager组成tab之间的滑动

本文详细介绍了如何使用自定义HorizontalScrollView与viewpager结合实现Tab类型的界面,包括禁止viewpager原生滑动、自定义HorizontalScrollView、适配FragmentPagerAdapter、设置Tab属性以及实现界面展示等功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Android现在实现Tab类型的界面方式越来越多,之前做电商项目时,遇见了类似tab与viewpager之间的左右连带滑动,我查了一些资料这种效果是继承自定义的HorizontalScrollView和viewpager完成的,我认为效果蛮好的,也比较简便。效果图:,这里我是禁止了viewpager原生自带的左右滑动,我上传了一个类文件,里面有禁止viewpager左右滑动和自定义的HorizontalScrollView。下载地址:http://download.youkuaiyun.com/detail/qq_32365567/9525324

代码:

 
  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
       
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical" >

<cn.tay.Tools.PagerSlidingTabStrip
android:id="@+id/tabs"
android:layout_width="match_parent"
android:background="#ececec"
android:layout_height="51dp" />
<cn.tay.Tools.Fobidden
android:id="@+id/pager"
android:layout_marginTop="15dp"
android:layout_width="match_parent"
android:layout_height="wrap_content" />
</LinearLayout>

这里需要注意的是,我这里是使用的<cn.tay.Tools.Fobidden 禁止左右滑动的viwepager,如果需要滑动可以调用安卓原生的viewager,android.support.v4.view.ViewPager。xml文件不好后,我们继续看activity里的方法。

  首先我们需要在on creat()方法中实例化 pager和tabs控件, pager = (ViewPager) findViewById(R.id.pager);
tabs = (PagerSlidingTabStrip) findViewById(R.id.tabs);  还需要适配屏幕的尺寸,DisplayMetrics dm = getResources().getDisplayMetrics();   当然除了做这些外,我们肯定还要为ViewPager做适配的,也就是继承FragmentPagerAdapter。这里为什么会继承FragmentPagerAdapter,因为我下面的都是用Fragment填充视图的,说到这里,很显然我们需要创建3个Fragment,private  JinBi_all quanbu,JinBi_Add shouru,JinBi_Reduce zhichu。

创建好后,那就要给ViewPager做适配了,代码:

 1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
      
public class MyPagerAdapter extends FragmentPagerAdapter {

public MyPagerAdapter(FragmentManager fm) {
super(fm);
}

private final String[] titles = { "全部","收入","支出"};

@Override
public CharSequence getPageTitle(int position) {
return titles[position];
}

@Override
public int getCount() {
return titles.length;
}

@Override
public Fragment getItem(int position) {
switch (position) {
case 0:
if (quanbu == null) {
quanbu = new JinBi_all();
}
return quanbu;
case 1:
if (shouru == null) {
shouru = new JinBi_Add_shouru();
}
return shouru;
case 2:
if (zhichu == null) {
zhichu = new Reduce_zhichu();
}
return zhichu;
default:
return null;
}
}
}
上面的就是为pager做的适配Adapter方法,显然就是给tab设置的标题以及点击相对应的fragment界面,那我们还需要在on creat()方法里实例pager,  pager.setAdapter(new MyPagerAdapter(getSupportFragmentManager()));
tabs.setViewPager(pager); setTabsValue();那写到这里,我们就需要给tab这些标题设置属性,比如填充满屏幕、分割线是透明的、Tab底部线的高度、等。如代码:

1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
      
private void setTabsValue () {
// 设置 Tab 是自动填充满屏幕的
tabs.setShouldExpand ( true ) ;
// 设置 Tab 的分割线是透明的
tabs.setDividerColor ( Color.TRANSPARENT ) ;
// 设置 Tab 底部线的高度
tabs.setUnderlineHeight (( int ) TypedValue.applyDimension (
TypedValue.COMPLEX_UNIT_DIP , 0 , dm )) ;
// 设置 Tab Indicator 的高度
tabs.setIndicatorHeight (( int ) TypedValue.applyDimension (
TypedValue.COMPLEX_UNIT_DIP , 2 , dm )) ;
// 设置 Tab 标题文字的大小
tabs.setTextSize (( int ) TypedValue.applyDimension (
TypedValue.COMPLEX_UNIT_SP , 14 , dm )) ;
// 设置 Tab Indicator 的颜色
tabs.setIndicatorColor ( Color.parseColor ( " #e61e19"));
tabs.setTextColorResource ( R.color.viewpage ) ;
// 设置选中 Tab 文字的颜色 ( 这是我自定义的一个方法 )
tabs.setSelectedTextColor ( Color.parseColor ( " #e61e19"));
}
这些方法都可以使用我们所需要的界面展示,如果你们还想创建其他炫酷的界面展示,可以在自定义HorizontalScrollView的类中添加需要的方法,以上这些属性都是在这里面添加的。写到这里基本上都把这些功能给实现了,但是这里我们还需要做一个关于tab中 使用到的标准常量,像超时、尺寸、距离,这样的一个工具类,我们还需创建一个方法放进on creat():private void setOverflowShowingAlways() {
try {
ViewConfiguration config = ViewConfiguration.get(this);
Field menuKeyField = ViewConfiguration.class
.getDeclaredField("MenuKey");
menuKeyField.setAccessible(true);
menuKeyField.setBoolean(config, false);
} catch (Exception e) {
e.printStackTrace();
}
}这里关于ViewConfiguration 类不懂的可以看一下,http://www.aichengxu.com/view/65180,到这里就能完全实现上图那种效果了。那每一个fragment就处理相应的界面数据,如果你那几个界面都是一样的,可以创建一个fragment,实现共用就行了,也比较简单只是处理数据不同而已,这样会节约很多时间。如果需要看其他的实现效果,可以看一下鸿洋老师的:http://blog.youkuaiyun.com/lmj623565791/article/details/24740977,我看了一下,貌似我这个还比较简单一点。

可能下一篇会贴出关于listview中头部和身部的item不同,就如上图中全部界面那种。好了,这个功能就介绍到这里了,有什么改进的地方,希望可以给我留言。


                
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值