您的位置:首页
当ViewPager嵌套在ScrollView/ListView里时,手势冲突如何处理?
2016-02-27 11:08
591 查看
有时我们需要将ViewPager嵌套在其他已经含有手势动作的ViewGroup里,如ScrollView,ListView时,会造成手势冲突,如表现为ViewPager向左划时,不小心向上移动了一点距离,ViewPager立刻回弹到原始位置。
主要问题出在ScrollView/ListView作为ViewPager的ParentView,会先接受到触摸信息,而且他们对上下滑动是会做出拦截动作,并接管触摸信息的向下传递,导致ViewPager滑动异常。 先看一种解决方式:
这种方式的确可以解决这个问题,但是其实Google已经提供了一个函数来解决ParentView与ChildView手势冲突的问题。
由ViewPager在OnTouch/onInterceptTouchEvent,dispatchTouchEvent中调用即可
主要问题出在ScrollView/ListView作为ViewPager的ParentView,会先接受到触摸信息,而且他们对上下滑动是会做出拦截动作,并接管触摸信息的向下传递,导致ViewPager滑动异常。 先看一种解决方式:
public class ScrollViewExtend extends ScrollView { private float xDistance, yDistance, xLast, yLast; public ScrollViewExtend(Context context, AttributeSet attrs) { super(context, attrs); } @Override public boolean onInterceptTouchEvent(MotionEvent ev) { switch (ev.getAction()) { case MotionEvent.ACTION_DOWN: xDistance = yDistance = 0f; xLast = ev.getX(); yLast = ev.getY(); break; case MotionEvent.ACTION_MOVE: final float curX = ev.getX(); final float curY = ev.getY(); xDistance += Math.abs(curX - xLast); yDistance += Math.abs(curY - yLast); xLast = curX; yLast = curY; if(xDistance > yDistance){ return false; } } return super.onInterceptTouchEvent(ev); } }
这种方式的确可以解决这个问题,但是其实Google已经提供了一个函数来解决ParentView与ChildView手势冲突的问题。
public void requestDisallowInterceptTouchEvent(boolean disallowIntercept)
由ViewPager在OnTouch/onInterceptTouchEvent,dispatchTouchEvent中调用即可
相关文章推荐
- hdu 1151 Air Raid
- Libev库学习3---watcher与loop的操作
- 在github上维护开源项目的流程
- 10026---forward和redirect的区别
- java中变量值为NULL的意义
- 展望2016,,总结2015
- 线程并发
- 分布式环境下的id生成方法
- Angularjs中设置cookies的过期时间
- [转]Java使用commons-dbcp2.0
- Python的函数参数传递:传值?引用?
- Java- dos命令下带包运行
- python sklearn包——3.1cross validation笔记
- 数据结构--1、线性表
- flume 读取tcp写到hdfs
- 设计模式之策略模式
- 简单的圆形图标鼠标hover效果 | CSS3教程
- flume 读取tcp写到hdfs
- 数据结构算法之排序系列Java、C源码实现(1)--直接插入排序
- 11.UISlider