在网上查了很多,意思都差不多,就是:
ViewPager要实现不滑动需要自定义ViewPager,然后重写scrollTo(int x,int y)方法 。
但是经过尝试之后发现,虽然阻止了其滑动,但是点击按钮的时候却一样的不能切换页面了。
后面又查找了一些资料,找到了解决办法。
public class CustomViewPager extends ViewPager {
private boolean isCanScroll = false; //false表示不滑动
public CustomViewPager(Context context) {
super(context);
}
public CustomViewPager(Context context, AttributeSet attrs) {
super(context, attrs);
}
public void setIsCanScroll(boolean isCanScroll) {
this.isCanScroll = isCanScroll;
}
/*
重写后,能实现不滑动,但是点击按钮时,页面照样不切换
*/
/*@Override
public void scrollTo(int x, int y) {
if (isCanScroll) {
super.scrollTo(x, y);
}
}*/
@Override
public boolean onTouchEvent(MotionEvent ev) {
if (isCanScroll)
return super.onTouchEvent(ev);
else
return false;
}
@Override
public boolean onInterceptTouchEvent(MotionEvent ev) {
if (isCanScroll)
return super.onInterceptTouchEvent(ev);
else
return false;
}
@Override
public void setCurrentItem(int item, boolean smoothScroll) {
super.setCurrentItem(item, smoothScroll);
}
@Override
public void setCurrentItem(int item) {
super.setCurrentItem(item,false); //表示切换的时候,不需要切换时间。
//避免点击标签切换多个page页面时出现闪烁,影响用户体验
}
}