Android Input设备debug技巧
2014-03-01 11:13
253 查看
一、驱动层
检查是否有点上报
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更细一些,还可以划分更多关键点出来,但是根据我目前的调试经验,这几点基本够用了。希望这个能给大家在调试的时候提供一些帮助!
检查是否有点上报
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 Adb Analyse
- Android开发学习之QQ好友列表的实现
- android nfc
- android 耳机按钮
- 计算sdcard上的剩余空间
- 查看android 版本号
- 怎么获得android的近期任务列表?
- Android处理Bit图片的几个函数分享
- Android开发之Service的远程调用
- 【移动开发】Android中将我们平时积累的工具类打包
- Android ADB详解
- 使用Google帐号登录Android应用
- Android开发学习之Xml解析归纳
- Android 之 将RAW资源文件写入SD卡工具类
- Android 之 监控手机电量
- Android 之 广播BroadcastReceiver
- Android 之 Service服务介绍
- Android 之 对话框总结
- Android NFC介绍
- Android调用系统内部的下载程序下载文件(一)