首先贴上自定义viewpager,主要通过判断用户滑动界面的方向来实现滑动的拦截。
当用户滑动方向为左右滑动时,拦截该滑动事件,并自己处理(使viewpager滑动翻页),当滑动的方向为上下时,将滑动事件分发给子view处理。
public class MyViewPager extends ViewPager { //mViewTouchMode表示ViewPager是否全权控制滑动事件,默认为false,即不控制 private boolean mViewTouchMode = false; public MyViewPager(Context context, AttributeSet attrs) { super(context, attrs); } public void setViewTouchMode(boolean b) { if (b && !isFakeDragging()) { //全权控制滑动事件 beginFakeDrag(); } else if (!b && isFakeDragging()) { //终止控制滑动事件 endFakeDrag(); } mViewTouchMode = b; } /** * 在mViewTouchMode为true的时候,ViewPager不拦截点击事件,点击事件将由子View处理 */ @Override public boolean onInterceptTouchEvent(MotionEvent event) { if (mViewTouchMode) { return false; } return super.onInterceptTouchEvent(event); } @Override public boolean onTouchEvent(MotionEvent ev) { try { return super.onTouchEvent(ev); } catch (Exception e) { return false; } } /** * 在mViewTouchMode为true或者滑动方向不是左右的时候,ViewPager将放弃控制点击事件, * 这样做有利于在ViewPager中加入ListView等可以滑动的控件,否则两者之间的滑动将会有冲突 */ @Override public boolean arrowScroll(int direction) { if (mViewTouchMode) return false; if (direction != FOCUS_LEFT && direction != FOCUS_RIGHT) return false; return super.arrowScroll(direction); } }在xml文件里使用自定义的viewpager即可