Android Q的事件分发机制

1:InputManagerServices(IMS)接收事件,根据读取到的事件分类,分别调用不同的函数,包括触屏、按键、键盘等,我们这边只分析触屏事件。

2:触摸事件会首先通过findTouchedWindowTargetsLocked()函数找到目标Window,进而通过dispatchEventLocked()将消息发送到目标窗口。

4:通过WMS把APP端和IMS联系到一起,牵扯进程间通讯(socket和binder)。

5:最后就是触摸事件被封装成了inputEvent,并通过InputEventReceiver的dispatchInputEvent(WindowInputEventReceiver)进行处理。

ViewRootImpl中WindowInputEventReceiver 是上层的源头。

6:最终 调用了decerView的dispatchPointerEvent。

       private int processPointerEvent(QueuedInputEvent q) {
            boolean handled = mView.dispatchPointerEvent(event);
        }

7: decerView重写了dispatchTouchEvent,通过父view调到了decerView的dispatchTouchEvent。

8:Window.Callback.dispatchTouchEvent()。

9:Window.Callback被Activity实现 Activity.dispatchTouchEvent。

10:superDispatchTouchEvent->phonewindow.superDispatchTouchEvent

11:decerView.superDispatchTouchEvent

12:decerView继承VIewGroup-》VIewGroup.dispatchTouchEvent

剩下的部分就简单了,就是VIewGroup的dispatchTouchEvent一级级的往下传递,直到最底层的View是否处理,如果还是没有处理,则继续调用父类的OnTouchEvent进行处理。

可以这么理解,就是1个事件传递下来,上层领导是否需要拦截处理,如果感觉这个不需要自己处理,就给自己的下级,下级在给下级,直到被人拦截处理,如果都下级没有人处理的了的话,则事件继续给自己的上层领导汇报处理。直到最终的Boss  Activity决定是否处理,都没人处理,则抛掉事件,做不了。

具体的代码看 VIewGroup和View就可以,他们会根据触点的X,Y来寻找匹配的View。

我写的自己看的懂,可能别人会一头懵,推荐看下面的文章,比较详细,对着Android源码看,太忙了,没空写那么细,

参考资料:

浅谈framework之InputManagerService_生于忧患,死于安乐-CSDN博客

浅谈Android之Activity触摸事件传输机制介绍_拿节-CSDN博客

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值