博客
关于我
反思|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/

你可能感兴趣的文章
NIFI大数据进阶_FlowFile生成器_GenerateFlowFile处理器_ReplaceText处理器_处理器介绍_处理过程说明---大数据之Nifi工作笔记0019
查看>>
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
查看>>
NIFI大数据进阶_NIFI集群知识点_集群的断开_重连_退役_卸载_总结---大数据之Nifi工作笔记0018
查看>>
NIFI大数据进阶_内嵌ZK模式集群1_搭建过程说明---大数据之Nifi工作笔记0015
查看>>
NIFI大数据进阶_外部ZK模式集群1_实际操作搭建NIFI外部ZK模式集群---大数据之Nifi工作笔记0017
查看>>
NIFI大数据进阶_实时同步MySql的数据到Hive中去_可增量同步_实时监控MySql数据库变化_操作方法说明_01---大数据之Nifi工作笔记0033
查看>>
NIFI大数据进阶_离线同步MySql数据到HDFS_01_实际操作---大数据之Nifi工作笔记0029
查看>>
NIFI大数据进阶_离线同步MySql数据到HDFS_02_实际操作_splitjson处理器_puthdfs处理器_querydatabasetable处理器---大数据之Nifi工作笔记0030
查看>>
NIFI大数据进阶_离线同步MySql数据到HDFS_说明操作步骤---大数据之Nifi工作笔记0028
查看>>
NIFI大数据进阶_连接与关系_设置数据流负载均衡_设置背压_设置展现弯曲_介绍以及实际操作---大数据之Nifi工作笔记0027
查看>>
NIFI数据库同步_多表_特定表同时同步_实际操作_MySqlToMysql_可推广到其他数据库_Postgresql_Hbase_SqlServer等----大数据之Nifi工作笔记0053
查看>>
NIFI汉化_替换logo_二次开发_Idea编译NIFI最新源码_详细过程记录_全解析_Maven编译NIFI避坑指南001---大数据之Nifi工作笔记0068
查看>>
NIFI汉化_替换logo_二次开发_Idea编译NIFI最新源码_详细过程记录_全解析_Maven编译NIFI避坑指南002---大数据之Nifi工作笔记0069
查看>>
NIFI集群_内存溢出_CPU占用100%修复_GC overhead limit exceeded_NIFI: out of memory error ---大数据之Nifi工作笔记0017
查看>>