android中的事件分发机制是非常重要的知识。网上的介绍事件分发机制的文章确实不少,最近也看了不少。但是很多都是贴代码用log日志找规律来介绍,看的我头痛。下面用图文结合的方式来给大有介绍一下。
1.方法介绍
事件分发的机制牵扯到的3个方法,我们会介绍Activity,ViewGroup和View中对这些方法的处理流程。如下图:
方法 | 介绍 | Activity | ViewGroup | View |
---|---|---|---|---|
dispatchTouchEvent | 分发事件 | 有 | 有 | 有 |
onInterceptTouchEvent | 拦截事件 | 无 | 有 | 无 |
onTouchEvent | 处理事件 | 有 | 有 | 有 |
2.ACTION_DOWN事件分析
这里我们先讲ACTION_DOWN事件的分发流程,后面再补充其他的事件
2.1 设置场景
我们设置一个场景,要不没办法继续讲下去。如下图:
这张图中,Activity中有一个ViewGroup,ViewGroup中有一个View。
2.2 分发总流程
当我们点击View的时候,事件分发的总流程如下:
0.Action_Down事件
1.Activity收到点击事件
2.如果Activtiy不处理事件,Activity分发事件给ViewGroup。
3.如果ViewGroup不处理事件,ViewGroup分发事件给View。
4.View如果不处理事件,再交给ViewGroup。
5.ViewGroup如果不处理事件,再交给Activity;
这么说可能不好理解,我们打个比方:
0.公司接了一个项目
1.经理收到项目
2.经理把项目交给主管。
3.主管把项目交给员工
4.员工发现项目解决不了。告诉主管
5.主管仔细研究发现也解决不了,告诉经理。
这么说大家是否好理解一些。下面我们来看一下详细的流程图。
2.3 流程图
2.4 总结规律
现在我们来总结一下规律
规律1:
ViewGroup中方法的调用流程:
dispatchTouchEvent ->onInterceptTouchEvent->onTouchEvent
View和Activity中的方法调用流程:
dispatchTouchEvent ->onTouchEvent
规律2:
1.Activity的规律:
2.ViewGroup的规律:
3.View的规律:
3.ACTION_MOVE 和 ACTION_UP事件分析
3.1 在ViewGroup1 的dispatchTouchEvent 方法返回true消费事件
红色的箭头代表ACTION_DOWN 事件的流向
蓝色的箭头代表ACTION_MOVE 和 ACTION_UP 事件的流向
3.2 在ViewGroup2 的dispatchTouchEvent 返回true消费事件
红色的箭头代表ACTION_DOWN 事件的流向
蓝色的箭头代表ACTION_MOVE 和 ACTION_UP 事件的流向
结论
如果在dispatchTouchEvent 返回true消费终结事件,那么收到ACTION_DOWN 的函数也能收到 ACTION_MOVE和ACTION_UP。
3.3 在View 的onTouchEvent 返回true消费事件
红色的箭头代表ACTION_DOWN 事件的流向
蓝色的箭头代表ACTION_MOVE 和 ACTION_UP 事件的流向
3.5 在ViewGroup2 的onTouchEvent 返回true消费事件
红色的箭头代表ACTION_DOWN 事件的流向
蓝色的箭头代表ACTION_MOVE 和 ACTION_UP 事件的流向
3.6 在ViewGroup 1 的onTouchEvent 返回true消费事件
3.7 在Activity 的onTouchEvent 返回true消费事件
结论:
1.ACTION_DOWN事件在哪个控件消费了(return true), 那么ACTION_MOVE和ACTION_UP就会从上往下(通过dispatchTouchEvent)做事件分发往下传,就只会传到这个控件,不会继续往下传。
2.如果ACTION_DOWN事件是在dispatchTouchEvent消费,那么ACTION_MOVE或ACTION_UP事件到此为止停止传递,
3.如果ACTION_DOWN事件是在onTouchEvent消费的,那么会把ACTION_MOVE或ACTION_UP事件传给该控件的onTouchEvent处理并结束传递。
4.结尾
先总结到这吧,希望对大家有所帮助。
技术上我依旧是个小渣渣,加油,勉励自己!