Android Input设备debug技巧

一、驱动层

        检查是否有点上报

        adb shell getevent -l /dev/input/eventX


        检查input设备支持的属性值

        adb shell getevent -i /dev/input/eventX


二、Native层

        检查驱动上报的点是否被InputReader转发给上层

        在TouchInputMapper::sync(nsecs_t when)函数中,打印相关的变量值,检查报点路径是否正常。驱动已经报点,但是上层收不到点的情况大致有以下几种:

        a. 设备模式被设为禁用模式,mDeviceMode == DEVICE_MODE_DISABLED

  引起此问题的原因是,在注册input device时,有些属性值设置不合法,导致在configure阶段,走了异常流程;

        b. 设备类型不正确,走了其他路径


三、Java层

        在ViewRootImpl.java文件的onInputEvent( )函数中添加打印信息,检查底层上报的点,是否通过Framework层成功上报了。

        一般来讲,如果onInputEvent能收到点,报点基本上是OK的。

       有些特殊情况除外,报点的消息类型不正确或者TP的横竖坐标搞反了,会出现上层收点了,但是TP仍然无法正常使用。


       以上是debug input子系统的几个关键地方,如果想debug更细一些,还可以划分更多关键点出来,但是根据我目前的调试经验,这几点基本够用了。希望这个能给大家在调试的时候提供一些帮助!

 

你可能感兴趣的:(android)