博客
关于我
反思|Android 事件分发机制的设计与实现
阅读量:786 次
发布时间:2019-03-24

本文共 1391 字,大约阅读时间需要 4 分钟。

Android事件分发机制深度解析

Android系统的事件分发机制是其完整性和灵活性的重要体现。本文将从系统启动流程、输入管理、事件分发机制等多个方面,详细阐述Android事件分发的核心设计思想及其实现方法。

系统启动流程

Android系统启动时,SystemServer进程会启动多个关键系统服务,包括WindowManagerServiceInputManagerServiceWindowManagerService负责管理窗口显示,while InputManagerService则负责接收和处理硬件输入事件。

InputManagerService通过与Native层的InputManager建立通信,监控键盘消息。这一机制确保了系统能够及时响应用户的输入操作。

输入事件分类

Android定义了InputEvent作为输入事件的基类,其子类包括KeyEventMouseEvent

  • KeyEvent:处理键盘输入事件。
  • MouseEvent:处理触摸屏输入事件,如手指、笔、触控板等。

这种分类使得输入系统能够统一处理多种输入设备的事件。

输入管理器

InputManager是Android系统的关键组件,它在Native层接收输入事件,并将事件分发给当前激活的窗口。InputManager通过InputChannelViewRootImpl建立通信,确保输入事件能够流向应用层。

ViewRootImpl作为窗口服务与UI之间的纽带,负责将输入事件分发到应用程序中的View层。

事件分发机制

事件分发机制采用了责任链模式,通过递归思想将事件沿着View树传递到合适的消费者。每个事件最多只有一个消费者,保证了事件处理的唯一性。

InputStage:事件分发的分阶段处理

Android引入了InputStage接口,作为事件分发的分阶段基类。其子类,如SyntheticInputStageViewPostImeInputStage等,负责处理不同阶段的输入事件:

  • SyntheticInputStage:处理综合性输入,如轨迹球和导航面板。
  • ViewPostImeInputStage:UI层面的事件分发,主要处理手指触摸和按键事件。

这些阶段通过责任链组装,确保每个事件在适当的阶段被正确处理。

ViewRootImpl:窗口服务与UI的交互

ViewRootImpl负责将系统输入事件传递给应用程序的View层。它通过InputChannel与系统服务进行通信,并在ViewPostImeInputStage阶段开始UI层的事件分发流程。

UI层的事件分发

UI层的事件分发遵循递归思想,每个ViewGroup通过dispatchTouchEvent方法将事件传递给子View。这一流程以View自身的dispatchTouchEvent方法为终点,决定事件是否被消费。

事件拦截机制

为了增强灵活性,Android为ViewGroup提供了拦截事件的机制。通过重写onInterceptTouchEvent函数,开发者可以在事件分发前中止事件传递,满足特定需求,如滑动冲突处理。

总结

Android的事件分发机制以递归思想为核心,通过责任链实现多阶段事件处理。其灵活性和完整性为开发者提供了强大的工具,满足各种复杂场景的需求。

转载地址:http://ttlkk.baihongyu.com/

你可能感兴趣的文章
NIFI1.23.2_最新版_性能优化通用_技巧积累_使用NIFI表达式过滤表_随时更新---大数据之Nifi工作笔记0063
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现数据实时delete同步_实际操作04---大数据之Nifi工作笔记0043
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_生成插入Sql语句_实际操作02---大数据之Nifi工作笔记0041
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_03_来吧用NIFI实现_数据分页获取功能---大数据之Nifi工作笔记0038
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_无分页功能_02_转换数据_分割数据_提取JSON数据_替换拼接SQL_添加分页---大数据之Nifi工作笔记0037
查看>>
NIFI从PostGresql中离线读取数据再导入到MySql中_带有数据分页获取功能_不带分页不能用_NIFI资料太少了---大数据之Nifi工作笔记0039
查看>>
nifi使用过程-常见问题-以及入门总结---大数据之Nifi工作笔记0012
查看>>
NIFI分页获取Mysql数据_导入到Hbase中_并可通过phoenix客户端查询_含金量很高的一篇_搞了好久_实际操作05---大数据之Nifi工作笔记0045
查看>>
NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
查看>>
Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
查看>>
NIFI大数据进阶_FlowFile拓扑_对FlowFile内容和属性的修改删除添加_介绍和描述_以及实际操作---大数据之Nifi工作笔记0023
查看>>
NIFI大数据进阶_Json内容转换为Hive支持的文本格式_操作方法说明_01_EvaluteJsonPath处理器---大数据之Nifi工作笔记0031
查看>>
NIFI大数据进阶_Kafka使用相关说明_实际操作Kafka消费者处理器_来消费kafka数据---大数据之Nifi工作笔记0037
查看>>
NIFI大数据进阶_Kafka使用相关说明_实际操作Kafka生产者---大数据之Nifi工作笔记0036
查看>>
NIFI大数据进阶_NIFI的模板和组的使用-介绍和实际操作_创建组_嵌套组_模板创建下载_导入---大数据之Nifi工作笔记0022
查看>>
NIFI大数据进阶_NIFI监控功能实际操作_Summary查看系统和处理器运行情况_viewDataProvenance查看_---大数据之Nifi工作笔记0026
查看>>
NIFI大数据进阶_NIFI监控的强大功能介绍_处理器面板_进程组面板_summary监控_data_provenance事件源---大数据之Nifi工作笔记0025
查看>>
NIFI大数据进阶_NIFI集群知识点_认识NIFI集群以及集群的组成部分---大数据之Nifi工作笔记0014
查看>>