屏蔽ViewPager的左右滑动和切换时的滚动动画

【转载请注明出处:From李诗雨—http://blog.csdn.net/cjm2484836553/article/details/78014447

不诗意的女程序猿不是好厨师~

我们经常会使用到 ViewPager+Fragment+TabLayout 这种类似的组合。

那么各种不同的需求也就来了。

有时需要viewpager不可左右滑动,但保留切换时的滚动动画。
有时则需要viewpager不可左右滑动,且切换时也不出现滚动动画。

【解决方案】
为了达成以上的需求我们需重写ViewPager。

对于禁止ViewPager左右滑动:
覆盖ViewPager的onInterceptTouchEvent(MotionEvent arg0)方法
和onTouchEvent(MotionEvent arg0)方法
这两个方法的返回值都是boolean类型的,只需要将返回值改为false
这样ViewPager就不会消耗掉手指滑动的事件了,转而传递给上层View去处理或者该事件就直接终止了。

对于 静止viewpager切换动画:
则需重写viewpager的setCurrentItem()方法就可以了

自定义的NoScrollViewPager类如下,可直接复制粘贴进行使用。

/**
 * Created by LSY on 2017/9/17.
 * 用于屏蔽viewpager的左右滑动和切换时的滚动动画
 * 
 * 禁止ViewPager左右滑动:
 * 需重写ViewPager,覆盖ViewPager的onInterceptTouchEvent(MotionEvent arg0)方法
 * 和onTouchEvent(MotionEvent arg0)方法
 * 这两个方法的返回值都是boolean类型的,只需要将返回值改为false
 * 这样ViewPager就不会消耗掉手指滑动的事件了,转而传递给上层View去处理或者该事件就直接终止了。
 *
 * 静止viewpager切换动画:
 * 则需重写viewpager的setCurrentItem()方法就可以了
 */
public class NoScrollViewPager extends ViewPager {

    private boolean isCanScroll = true;
    private boolean isHasScrollAnim=true;

    public NoScrollViewPager(Context context) {
        super(context);
    }

    public NoScrollViewPager(Context context, AttributeSet attrs) {
        super(context, attrs);
    }

    /**
     * 设置其是否能滑动
     * @param isCanScroll false 禁止滑动, true 可以滑动
     */
    public void setScanScroll(boolean isCanScroll) {
        this.isCanScroll = isCanScroll;
    }

    public void setHasScrollAnim(boolean isHasScrollAnim){
        this.isHasScrollAnim=isHasScrollAnim;
    }


    @Override
    public boolean onInterceptTouchEvent(MotionEvent ev) {
        return isCanScroll && super.onInterceptTouchEvent(ev);
    }

    @Override
    public boolean onTouchEvent(MotionEvent ev) {
        return isCanScroll && super.onTouchEvent(ev);
    }

    @Override
    public void setCurrentItem(int item, boolean smoothScroll) {
        super.setCurrentItem(item, smoothScroll);
    }

    /**
     * 设置其是否去求切换时的滚动动画
     *isHasScrollAnim为false时,会去除滚动效果
     */
    @Override
    public void setCurrentItem(int item) {
        super.setCurrentItem(item,isHasScrollAnim);
    }

}

使用简说
①首先是布局文件中要换成自己定义的NoScrollViewPger

 <!--<android.support.v4.view.ViewPager-->
    <com.ctvit.worldcom.view.NoScrollViewPager
        android:id="@+id/mainfollowing_viewpager"
        android:layout_width="match_parent"
        android:layout_height="match_parent" />

②初始化控件的地方记得也要替换

   @BindView(R.id.mainsearch_viewpager)
    NoScrollViewPager mainsearchViewpager;
//    ViewPager mainsearchViewpager;

③根据需要,调用相关的屏蔽左右滑动和切换时滚动效果的方法
如果你只需要禁止左右滑动,就调用这个方法:

        //屏蔽左右滑动
        mainsearchViewpager.setScanScroll(false);

如果你既需要屏蔽左右滑动,有需要屏蔽切换时的滚动动画,
则调用如下两个方法:

        //屏蔽左右滑动
        mainFollowingViewpager.setScanScroll(false);
        //屏蔽切换时的滚动动画
        mainFollowingViewpager.setHasScrollAnim(false);



积累点滴,做好自己~

猜你喜欢

转载自blog.csdn.net/cjm2484836553/article/details/78014447