第20天 Android Touch事件学习 7 交给哪个视图处理事件?

时间:2020-11-29 10:16:59


触摸事件学习系列文章详见:

《Android Touch事件学习系列汇总》


一、 什么是触摸事件?

还是在 《Android Touch事件学习系列汇总》 提出了两个疑问,并且疑问2" Android系统知道你要做什么吗?例如是点击、滚动、长按还是其他的?"已经在之前的文章中解释了。
在此基础上现在来具体看下疑问1 "Andorid系统获取到触摸事件后,如何知道用户触碰的是哪个视图?"


在具体分析前猜猜Andorid系统会如何判断当前触碰的是哪个视图:
1. Android系统从MotionEvent对象中getX() 与 getY()获取当前手指触摸点的坐标,虽然知道手指坐标依然无法确认到底是在哪个视图上。
2. 每个视图都有在屏幕上的固定位置并且宽高也都是固定的(通过View.getLeft(), View.getRight(), View.getTop(), View.getBottom()获取)
3. 通过从UI树由上至下查找,最终找到当前手指坐标具体在哪个视图范围内。最终交由这个视图的onTouchEvent方法进行具体处理。


二、diapatchTouchEvent如何分发?


先来看看例子的效果图:
第20天 Android Touch事件学习 7 交给哪个视图处理事件?

例子输出的LOG
RelativeLayout dispatchTouchEvent ACTION_DOWN
LinearLayout dispatchTouchEvent ACTION_DOWN
CustomView dispatchTouchEvent ACTION_DOWN
CustomView onTouchEvent ACTION_DOWN

RelativeLayout dispatchTouchEvent ACTION_UP
LinearLayout dispatchTouchEvent ACTION_UP
CustomView dispatchTouchEvent ACTION_UP
CustomView onTouchEvent ACTION_UP

从以上LOG可以看出以下结论:
1. 之前 《Android Touch事件学习 5 点击与长按原理》 分析过点击事件原理,仅执行ACTION_DOWN与ACTIOIN_UP动作
2. 每个触摸动作(ACTION)都是先RelativeLayout先执行,再执行LinearLayout,最后执行CustomView。dispatchTouchEvent方法时依次从上向下派发
3. 最终交由触碰视图CustomView.onTouchEvent处理


在来看看例子的结构图、UI结构图、对应的UI树,如果是布局仅显示ViewGroup,如果是视图仅显示View
第20天 Android Touch事件学习 7 交给哪个视图处理事件?  第20天 Android Touch事件学习 7 交给哪个视图处理事件?第20天 Android Touch事件学习 7 交给哪个视图处理事件?


从上面例子的LOG、效果图、UI结构图中可以看出:

1. dispatchTouchEvent的执行顺序是RelativeLayout -> LinearLayout -> CustomView

2. 每次的ACTION,仅有一个视图进行处理



   下一篇文章分析dispatchTouchEvent的源码,具体看看触摸事件传递的规则。