为什么会有事件分发机制:

安卓上面的View是树形结构的,View可能会重叠在一起,当我们点击的地方有多个View都可以响应的时候,这个点击事件应该给谁呢?为了解决这一问题,就有了事件分发机制。用图来说明:

View相关面试问题-事件分发面试问题讲解_事件分发机制

如图,当点击View1时,其它下面的ViewGroupA和RootView也是能响应的,为了能确认是哪个View最终来处理此次点击事件,所以就引入了事件分发机制。针对上图中的View的树形结构如下:

View相关面试问题-事件分发面试问题讲解_树形结构_02

三个重要的事件分发的方法:


  • dispatchTouchEvent
  • onInterceptTouchEvent
  • onTouchEvent

事件分发流程:

其整体传递过程如下:Activity -> PhoneWindow -> DecorView -> ViewGroup -> ... -> View

结合之前提到的例子下面看一下它完整的事件分发流程:

View相关面试问题-事件分发面试问题讲解_树形结构_03

首先事件会回传给Activity的dispatchTouchEvent,然后又会传递给PhoneWindow,紧接着再到DecorView,此时如果DecorView不拦截此次事件,那又会交由RootView去处理,同样的如果RootView也不拦截则事件又会到ViewGroupA中,如果ViewGroupA也不拦截此次事件,接着又会到View1,由于它是最底层View,则直接到onTouchEvent()进行处理,如果返回true那此次事件最终就由View1给消费掉了,然后再将结果往回返回给Activity。