【转载请注明出处: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);
积累点滴,做好自己~