目录
1 背景
2 自定义ViewPager实现
3 使用方法
1 背景
用ViewPager+BottomNavigationView+多个Fragment快速搭建的页面切换架构,一个有四个页面,因为测试需要,需要屏蔽掉中间的两个,做法是:
-
设置不可点击选择:xml布局文件中,BottomNavigationView的app:menu属性为各页的item,将不想显示的页面item的android:enabled属性设置为false,此时对应的页面就无法显示了;
-
设置BottomNavigationView不可滑动:但是BottomNavigationView没有对应的方法支持这个功能。
2 自定义ViewPager实现
【原理】:写一个CustomViewPager类继承ViewPager,然后重写onTouchEvent、onInterceptTouchEvent,另外添加了setSlidingEnable方法,外部传参开启或禁止滑动。这里简单解释下onInterceptTouchEvent方法:
- 作用:判断是否拦截上面touch的事件;
- 参数:
——return false: 不对事件进行拦截,放行该事件。事件会被传递到当前的View的子控件中,由子控件中的dispatchTouchEvent方法进行分发处理;
——return true: 拦截该事件,将该事件交给当前View的onTouchEvent方法进行处理;
【代码】:
public class CustomViewPager extends ViewPager {
// the sliding page switch
private boolean isSlidingEnable = true ;
public CustomViewPager(Context context) {
super(context);
}
public CustomViewPager(Context context, AttributeSet attrs) {
super(context, attrs);
}
//重写此函数
@Override
public boolean onTouchEvent(MotionEvent ev) {
return this.isSlidingEnable;
}
//重写此函数
@Override
public boolean onInterceptTouchEvent(MotionEvent ev) {
return this.isSlidingEnable;
}
public void setSlidingEnable(boolean slidingEnable) {
isSlidingEnable = slidingEnable;
}
}
3 使用方法
private CustomViewPager homeViewPager = null;
homeViewPager = (CustomViewPager) findViewById(R.id.view_pager_home);
//中间涉及的其他步骤就不赘述了
homeViewPager.setSlidingEnable(false); //禁止左右滑动
这里需要注意的一个问题:CustomViewPager是自定义的一个类,我们定义布局文件xml时就要用这个CustomViewPager,否则还用原来的androidx.viewpager.widget.ViewPager话,在这里homeViewPager = (CustomViewPager) findViewById(R.id.view_pager_home);会报错,因为类型不匹配:
———————————————————————————————————
本文为博主原创文章,转载请注明出处!
若本文对您有帮助,轻抬您发财的小手,关注/评论/点赞/收藏,就是对我最大的支持!
祝君升职加薪,鹏程万里!