Android 实现不能滑动的ViewPager(禁止ViewPager滑动)

       ViewPager在日志Android开发中几乎是APP必备的组件,通常的APP中要么有banner,要么有tab+viewpager+fragment 来实现底导tab切换,这样的APP太多了,部分APP底导允许通过上面的页面滑动切换Tab的比如微信,但是也有不允许通过上面的页面滑动切换Tab的,比如支付宝。同样都是底导类型的界面,可以根据不同的需求来实现,加入两个都采用  tab + viewpager + fragment 来实现的话,viewpager是默认可以滑动的,那么我们怎么实现类似于支付宝这样,只允许调用setCurrentItem 方式来切换,而不允许通过滑动ViewPager来实现呢。

       大家可能立刻就想到是 禁止ViewPager的滑动事件,组织ViewPager通过滑动切换页面,那么具体怎么实现呢,其实很简单,下面来说如何做到。

       最直接,最简单的就是直接让ViewPager不处理onTouch事件,直接交给他的子控件去处理就行,具体实现如下面代码,新建一个类,叫做NoScrollViewPager,让这个类继承自ViewPager,然后重写两个方法,onTouchEvent 和 onInterceptTouchEvent  这两个方法。为了便于随时控制,可以设置一个变量来控制是否允许滑动,noScroll  ,一个boolean值的变量,如果这个值为true,则不允许滑动,默认为true,然后在签名说的两个方法中,根据noScroll的值判断是否返回false还是交给viewPager去处理滑动逻辑,如果noScroll 为true,则直接返回false,不处理滑动事件(即拦截滑动事件),具体实现代码如


public class NoScrollViewPager extends ViewPager {

            private boolean noScroll = true;

           public NoScrollViewPager(@NonNull Context context) {

                    super(context);

          }

           public NoScrollViewPager(@NonNull Context context, @Nullable AttributeSet attrs) {

                    super(context, attrs);

            }

           @Override

           public boolean onTouchEvent(MotionEvent arg0) {

                     if (noScroll) {

                         return false;

                    } else {        

                        return super.onTouchEvent(arg0);

                  }

          }

           @Override

           public boolean onInterceptTouchEvent(MotionEvent arg0) {

                      if (noScroll) {

                             return false;

                    } else {

                          return super.onInterceptTouchEvent(arg0);

                    }

             }

}

你可能感兴趣的:(Android 实现不能滑动的ViewPager(禁止ViewPager滑动))