Android事件分发机制

来源:互联网 发布:mac virtualbox u盘 编辑:程序博客网 时间:2024/06/08 18:53

先引用大神的两张图,转载自http://blog.csdn.net/jdsjlzx/article/details/52355249

事件分发流程
事件传递流程

然后是关于事件自己的理解:

  1. Android中事件必然是从ACTION_DOWN开始,到ACTION_UP结束
  2. 任何ACTION的事件,永远是从最外层开始传递的
  3. 如果ACTION_DOWN的事件被某个View或ViewGroup消费,则后续事件必然会被该View或ViewGroup消费(注意是直接消费,结合传递机制,相当于拦截了后续事件)
  4. 如果一个事件的ACTION_DOWN在所有View层级都没有被消费,则最终会由Activity来处理这个事件,View层不会收到后续事件
  5. 事件可以被onTouch、onTouchEvent、onLongClick、onClick消费,除了onTouchEvent其它三个都是通过Listener设置的。
    • 这四者具有这样一个关系:
      • onTouch的返回决定其是否消费事件,这会影响onTouchEvent是否被调用
      • onTouchEvent:
        • 不重写时:默认返回受View是否可点击(包括clickable、注册click、longClick的监听)影响(这里需要结合View源码),并且可点击的View必然会消费事件
        • 重写时:onTouchEvent的返回决定其是否消费事件,但是不管返回true还是false,后两者都不会被调用(因为后两者都是在源码中View的onTouchEvent中被调用的)
      • onLongClick的返回决定其是否消费事件,这会影响onClick是否被调用
      • onClick被调用就必然消费事件
  6. 事件可以被ViewGroup拦截,但是拦截不代表消费事件,而是其内的子View无法再收到被拦截的事件
  7. 如果在控件开发过程中,遇到特定情况下不希望父控件对事件拦截
    • requestDisallowInterceptTouchEvent(true); //请求不允许上层拦截(内部会递归调用不允许所有上层拦截)
0 0
原创粉丝点击