首先,我们假设这样一个场景:一个ViewPager里面嵌套一个ViewPager,内部滑动方向和外部滑动方向一样时,该怎么解决这一冲突呢?
针对滑动冲突这里给出两种解决方案:外部拦截法,内部拦截法。
外部拦截法
情景:一个ViewPager嵌套了一个Listview,一个是左右滑动,一个上下滑动。这个时候我们可以用外部拦截法,来处理冲突。在父容器ViewPager中,重写onInterceptTouchEvent()方法,判断当左右滑动时就拦截事件,上下滑动就不拦截,将事件交由子元素Listview来处理。首先我们需要重写一个ViewPager,叫MyViewPager,然后重写onInterceptTouchEvent()方法。具体代码如下:
1publicclassMyViewPagerextendsViewPager {2privateintstartX;3privateintstartY;4publicMyViewPager(Context context) {5super(context);6}789@Override10publicbooleanonInterceptTouchEvent(MotionEvent ev) {11switch(ev.getAction())12{13caseMotionEvent.ACTION_DOWN:14startX= (int) ev.getX();15startY= (int) ev.getY();16break;17caseMotionEvent.ACTION_MOVE:1819intdX= (int) (ev.getX()-startX);20intdY= (int) (ev.getY()-startX);21if(Math.abs(dX)>Math.abs(dY)){//左右滑动22returntrue;23}else{//上下滑动24returnfalse;25}26caseMotionEvent.ACTION_UP:27break;28}29returnsuper.onInterceptTouchEvent(ev);30}31}
这样就解决这种情况下的滑动冲突, 程序演示入下图:
上述代码是外部拦截的典型逻辑,只需要重写onInterceptTouchEvent()方法,修改父容器当前需要的事件即可。
内部拦截法
情景:一个ViewPager嵌套了一个ViewPager,两个都是左右滑动。这个时候我们可以用内部拦截法,来处理冲突。即重写子元素的dispatchTouchEvent()方法,并调用getParent().requestDisallowInterceptTouchEvent(true)是父容器不能拦截子元素需要的事件。下面来看具体代码:
1publicbooleandispatchTouchEvent(MotionEvent event) {2...34switch(action) {5caseMotionEvent.ACTION_MOVE:6getParent().requestDisallowInterceptTouchEvent(true);78break;9caseMotionEvent.ACTION_MOVE:10if(子元素需要处理此事件)11getParent().requestDisallowInterceptTouchEvent(true);1213break;14caseMotionEvent.ACTION_UP: {15break;16}17...18returnsuper.dispatchTouchEvent(event);19;20}
当然,还需要修改父容器的onInterceptTouchEvent()方法,代码如下:
1@Override2publicbooleanonInterceptTouchEvent(MotionEvent ev) {34intaction=ev.getAction();5if(action==MotionEvent.ACTION_DOWN){6returnfalse;7}else{8returntrue;9}10}
运行结果如图:
以上就是两种解决滑动冲突的解决方案。
public class MyViewPager extends ViewPager {
private int startX;
private int startY;
public MyViewPager(Context context) {
super(context);
}
@Override
public boolean onInterceptTouchEvent(MotionEvent ev) {
switch (ev.getAction())
{
case MotionEvent.ACTION_DOWN:
startX= (int) ev.getX();
startY= (int) ev.getY();
break;
case MotionEvent.ACTION_MOVE:
int dX= (int) (ev.getX()-startX);
int dY= (int) (ev.getY()-startX);
if(Math.abs(dX)>Math.abs(dY)){//左右滑动
return true;
}else {//上下滑动
return false;
}
case MotionEvent.ACTION_UP:
break;
}
return super.onInterceptTouchEvent(ev);
}
}
public boolean dispatchTouchEvent(MotionEvent event) {
...
switch (action) {
case MotionEvent.ACTION_MOVE:
getParent().requestDisallowInterceptTouchEvent(true);
break;
case MotionEvent.ACTION_MOVE:
if(子元素需要处理此事件)
getParent().requestDisallowInterceptTouchEvent(true);
break;
case MotionEvent.ACTION_UP: {
break;
}
...
return super.dispatchTouchEvent(event);
;
}
@Override
public boolean onInterceptTouchEvent(MotionEvent ev) {
int action=ev.getAction();
if(action==MotionEvent.ACTION_DOWN){
return false;
}else {
return true;
}
}
http://www.cnblogs.com/yxx123/p/5250101.html