Input机制之-Debug调试方法

Input机制之-Debug调试方法

项目碰到功能按键ASSIT点击没有反应的情况
确定哪部分出了问题

  1. adb shell getevent命令可以获取Android kernel层上报到/dev/input/目录下的原始数据
    在这里插入图片描述

我们可以通过这个命令,判断驱动层是否能正常的生成数据,当我们点击ASSIT按钮,/dev/input/event2生成两条数据,分别为DOWN和UP事件,如上图表示,其中00fa(250)表示这个ASSIT按键在驱动层定义的键值,若这边没有数据表示驱动没有正常的上报数据,找驱动处理

  1. adb shell input keyevent 219命令可以模拟进行按键的点击,将点击事件直接通过InputDispatcher的injectInputEvent方法发送到Native层,若这边有问题表示InputDispatcher的拦截和分发存在问题,需要追踪源码,可以打开DEBUG_INBOUND_EVENT_DETAILS,DEBUG_OUTBOUND_EVENT_DETAILS等配置宏打印LOG,事件的拦截逻辑是在PhoneWindowManager中实现的,可以通过DEBUG_INPUT开关打印LOG

  2. adb shell dumpsys input 可以输出一些input系统运行时的一些信息,比如关键字RecentQueue,记录了10条最近的Input事件的信息。还有诸如PendingEvent,InboundQueue,Windows,Connections等信息。
    在这里插入图片描述

通过这个可以确定InputReader是否正常的读取事件,若这边没有相关数据,就需要查看InputReader的逻辑了,若只是某一个特定功能按键有问题,可能是EventHub对特定/dev/input/的读取有问题或者驱动键值表文件配置问题导致事件无法正常转换,前者可以通过DEBUG_RAW_EVENTS配置宏打印LOG,后者可以导出手机中相应的/system/usr/keylayout/xxxx.kl和/system/usr/keychars/xxxx.kcm键值配置文件分析是否是转换错误

附MTK FAQ:

  1. 如何抓取 framework input 事件相关 log

  2. 如何让KEYCODE_DPAD_CENTER等功能键在activity中处理

  3. 长按Home键唤起Google Now

  4. KeyEvent/MotionEvent的音效处理

  5. 如何用getevent查看C-TouchPanel上报数据

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值