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

   日期:2020-11-01     浏览:94    评论:0    
核心提示:目录1 背景2 自定义ViewPager实现3 使用方法1 背景用ViewPager+BottomNavigationView+多个Fragment快速搭建的页面切换架构,一个有四个页面,因为测试需要,需要屏蔽掉中间的两个,做法是: 设置不可点击选择:xml布局文件中,BottomNavigationView的app:menu属性为各页的item,将不想显示的页面item的android:enabled属性设置为false,此时对应的页面就无法显示了; 设置BottomN

目录

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

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

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

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

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

 
打赏
 本文转载自:网络 
所有权利归属于原作者,如文章来源标示错误或侵犯了您的权利请联系微信13520258486
更多>最近资讯中心
更多>最新资讯中心
0相关评论

推荐图文
推荐资讯中心
点击排行
最新信息
新手指南
采购商服务
供应商服务
交易安全
关注我们
手机网站:
新浪微博:
微信关注:

13520258486

周一至周五 9:00-18:00
(其他时间联系在线客服)

24小时在线客服