Android——ViewPager禁止左右滑动的实现

目录

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);会报错,因为类型不匹配:

扫描二维码关注公众号,回复: 12088622 查看本文章

———————————————————————————————————

本文为博主原创文章,转载请注明出处!

若本文对您有帮助,轻抬您发财的小手,关注/评论/点赞/收藏,就是对我最大的支持!

祝君升职加薪,鹏程万里!

猜你喜欢

转载自blog.csdn.net/w464960660/article/details/109387520