600字范文,内容丰富有趣,生活中的好帮手!
600字范文 > 屏蔽ViewPager的左右滑动和切换时的滚动动画

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

时间:2021-03-25 05:27:45

相关推荐

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

【转载请注明出处:From李诗雨—/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 /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;}@Overridepublic boolean onInterceptTouchEvent(MotionEvent ev) {return isCanScroll && super.onInterceptTouchEvent(ev);}@Overridepublic boolean onTouchEvent(MotionEvent ev) {return isCanScroll && super.onTouchEvent(ev);}@Overridepublic void setCurrentItem(int item, boolean smoothScroll) {super.setCurrentItem(item, smoothScroll);}/*** 设置其是否去求切换时的滚动动画*isHasScrollAnim为false时,会去除滚动效果*/@Overridepublic 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);

积累点滴,做好自己~

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。