博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
当ViewPager嵌套在ScrollView/ListView里时,手势冲突如何处理?
阅读量:6649 次
发布时间:2019-06-25

本文共 1484 字,大约阅读时间需要 4 分钟。


有时我们需要将ViewPager嵌套在其他已经含有手势动作的ViewGroup里,如ScrollView,ListView时,会造成手势冲突,如表现为ViewPager向左划时,不小心向上移动了一点距离,ViewPager立刻回弹到原始位置。

主要问题出在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中调用即可

转载于:https://www.cnblogs.com/Sharley/p/5222518.html

你可能感兴趣的文章
模拟器可以,但是真机却不行
查看>>
CSS: hover选择器的使用
查看>>
Java消息服务
查看>>
Grid列拖拽、列选择、显示行号
查看>>
自定义的allocator
查看>>
浅谈CSRF漏洞
查看>>
JS----基本数据类型
查看>>
明天考前突击
查看>>
Android中的Handler的机制与用法详解
查看>>
【算法学习笔记】18.暴力求解法06 隐式图搜索2 八数码问题 未启发
查看>>
「小程序JAVA实战」运行微信官方demo(四)
查看>>
jqGrid基本用法与示例
查看>>
spring @Bean注解的使用
查看>>
Vmware Workstation及Centos6.8 的安装
查看>>
发生未知错误17,解决办法
查看>>
EL与OGNL区别
查看>>
第7章课后总结
查看>>
Python os模块,常用函数和类
查看>>
C#窗体加载和控件加载不同步导致控件闪烁
查看>>
js 2
查看>>