出现事件输入相关的问题时, 建议先 followhttp://429564140.iteye.com/blog/2355405来检测对应的设备是否有响应输入

如果没有响应输入,则可能是 driver 或者输入设备模组问题,

如果有输入设备响应输入, 则需要打开以下 log 开关,抓取 mobile log 检查 framework 层的对事件的处理

[SOLUTION]

注意:

USER版本只能使用静态方式(修改代码)打开debug开关

ENG版本可以使用动态方式(命令)打开debug开关

App 层 (client) 适用于JB,KK,L,M版本:

动态开启APP层LOG方法如下:

adb shell setprop debug.viewroot.enable 7000

adb shell setprop debug.view.keylog true

adb shell setprop debug.view.touchlog true

adb shell setprop debug.view.motionlog true

adb shell stop

adb shell start

需等待手机软重启后才能生效

静态修改请直接修改DEBUG的值。

开启ViewRootImpl/View/ViewGroup中input event的处理过程的log开关:

frameworks/base/core/java/android/view/viewrootimpl.java 中的 DEBUG_INPUT 开关(设置为 true);

frameworks/base/core/java/android/view/viewgroup.java 中的 DBG_MOTION ,DBG_TOUCH开关

frameworks/base/core/java/android/view/view.java 中的 DBG_MOTION ,DBG_TOUCH开关

frameworks/base/policy/src/com/android/internal/policy/impl/PhoneWindow.java 中的 DBG_MOTION 开关

frameworks/base/core/java/android/view/KeyEvent.java 中的 DEBUG 开关

framework(server): 层

动态打开方法 (适用于KK,L,M. 其中KK只适用于eng build, L,M适用于eng build 和user build):

adb shell setprop sys.inputlog.enabled true

adb shell dumpsys input

不用重启手机就可以生效,重启手机后会失效。

静态开启方法:

frameworks/base/services/input/inputReader.cpp (for ICS & JBx ,KK版本)

frameworks/native/services/inputFlinger/inputReader.cpp (for L ,M版本)

找到以下宏定义, 并将其值改为如下

#define DEBUG_RAW_EVENTS 1

#define DEBUG_HACKS 1

#define DEBUG_VIRTUAL_KEYS 1

#define DEBUG_POINTERS 1

#define DEBUG_POINTER_ASSIGNMENT 1

#define DEBUG_GESTURES 1

#define DEBUG_VIBRATOR 1

frameworks/base/services/input/inputDispatcher.cpp (for ICS & JBx ,KK版本)

frameworks/native/services/inputFlinger/inputDispatcher.cpp (for L, M 版本)

找到以下宏或变量定义, 并将其值改为如下

#else // 改 else 分支中的定义

#define DEBUG_INBOUND_EVENT_DETAILS 1

#define DEBUG_OUTBOUND_EVENT_DETAILS 1

#define DEBUG_DISPATCH_CYCLE 1

#define DEBUG_REGISTRATION 1

#define DEBUG_INJECTION 1

#define DEBUG_FOCUS 1

#define DEBUG_APP_SWITCH 1

#define DEBUG_HOVER 1

#endif

bool gInputLogEnabled = true;

frameworks/base/libs/androidfw/inputTransport.cpp (for ICS & JBx 版本)

找到以下宏或变量定义, 并将其值改为如下

#else // 改 else 分支中的定义

#define DEBUG_CHANNEL_MESSAGES 1

#define DEBUG_CHANNEL_LIFECYCLE 1

#define DEBUG_TRANSPORT_ACTIONS 1

#define DEBUG_RESAMPLING 1

#endif

static bool gInputLogEnabled = true;

frameworks/native/libs/input/inputTransport.cpp (for KK,L ,M版本)

找到以下变量定义, 并将其值改为如下

static bool gInputLogEnabled = true;

因为很多input无响应的问题,常常会跟window的focus扯上关系,如果有需要

可以用下面的命令打开ams和wms的LOG。

adb shell dumpsys activity log x on

adb shell dumpsys window -d enable a

如何抓取 framework input 事件相关 log的更多相关文章

  1. python3 - 通过BeautifulSoup 4抓取百度百科人物相关链接

    导入需要的模块 需要安装BeautifulSoup from urllib.request import urlopen, HTTPError, URLError from bs4 import Be ...

  2. Dynamics CRM Form表单中通过javascript抓取触发change事件字段的属性名

    通过下面这段代码可以抓取到change的事件源,从而判断出是哪个属性字段触发的事件, function change(pContext) {var fieldName=pContext.getEven ...

  3. fiddler抓取手机APP包相关的设置

    一.设置手机的代理服务器 1.前提:手机与电脑用的是同一个网络 2.fiddler设置允许远程连接,并设置好端口 3.查询电脑所在网络的ip地址(windows下,命令行窗口使用:ipconfig进行 ...

  4. 如何在User版本开启串口(Uart),抓取上层Log,开启输入控制台

    [原][FAQ03891] 如何在User版本开启串口(Uart),抓取上层Log,开启输入控制台 2014-11-26阅读1369 评论0 FAQ Content [Description]如何在U ...

  5. 「拉勾网」薪资调查的小爬虫,并将抓取结果保存到excel中

    学习Python也有一段时间了,各种理论知识大体上也算略知一二了,今天就进入实战演练:通过Python来编写一个拉勾网薪资调查的小爬虫. 第一步:分析网站的请求过程 我们在查看拉勾网上的招聘信息的时候 ...

  6. python抓取历年特码开奖记录

    背景: 小时候,有种游戏,两个主人公:白XX和曾XX,每个家庭把他俩像活菩萨一样供着,供他们吃,供他们穿 做生意的老板为了这两位活菩萨,关门大吉 农民为了这两位活菩萨卖牛卖田变卖家产 做官的为了这两位 ...

  7. 重构前的程序:通过rsync命令抓取日志文件

    基本概况: 我有一台服务器每天每个小时都会生成一个日志文件,这些日志文件会被保留2天,超过2天会被一个程序压缩放到备份目录,日志文件的文件名是有命名要求的,例如:project_log.2013010 ...

  8. Web Scraper 翻页——控制链接批量抓取数据

    ![](https://image-1255652541.cos.ap-shanghai.myqcloud.com/images/20190708214014.png) 这是简易数据分析系列的第 5 ...

  9. 简易数据分析 07 | Web Scraper 抓取多条内容

    这是简易数据分析系列的第 7 篇文章. 在第 4 篇文章里,我讲解了如何抓取单个网页里的单类信息: 在第 5 篇文章里,我讲解了如何抓取多个网页里的单类信息: 今天我们要讲的是,如何抓取多个网页里的多 ...

随机推荐

  1. 洛谷 P3420 [POI2005]SKA-Piggy Banks 题解

    蒟蒻的第二篇题解 嗯,直接进入正题 先告诉你们这是并查集,好吧,标签上面有,再来分析这为什么是并查集. 根据题意: 每一个存钱罐能够用相应的钥匙打开或者被砸开,Byteazar已经将钥匙放入到一些存钱 ...

  2. Go语言学习之路

    我关于Go语言的博客原本发布于我的个人网站:wwww.liwenzhouu.com.但是被某些人抄怕了,没办法只好搬运到博客园. 我的Go语言学习之路 2015年底我因为工作原因接触到了Go语言,那时 ...

  3. [TimLinux] Python如何运行程序

    1. Python解释器安装 访问官方网站:https://www.python.org/, 在首页标签中找到“Downloads”,根据不同的操作系统,选择相应的下载源文件即可. 2. 源码安装 在 ...

  4. cesium 实现 3d-tiles 平移旋转贴地(附源码下载)

    前言 cesium 官网的api文档介绍地址cesium官网api,里面详细的介绍 cesium 各个类的介绍,还有就是在线例子:cesium 官网在线例子,这个也是学习 cesium 的好素材. 内 ...

  5. BZOJ 1861书架

    小T有一个很大的书柜.这个书柜的构造有些独特,即书柜里的书是从上至下堆放成一列.她用1到n的正整数给每本书都编了号. 小T在看书的时候,每次取出一本书,看完后放回书柜然后再拿下一本.由于这些书太有吸引 ...

  6. Typora常见的快捷方式

    操作类型 操作 快捷键 文件操作 新建 Ctrl + N    新建窗口 Ctrl + Shift + N    打开 Ctrl + O    快速打开 Ctrl + P    保存 Ctrl + S ...

  7. tensorflow add_to_collection用法

    训练代码: # coding: utf-8 from __future__ import print_function from __future__ import division import t ...

  8. Selenium之勾选框操作

    勾选框操作:       所谓勾选框,意思是可以勾选一个及以上或全部勾选.勾选框的图标一般都是方形的. 复选框勾选一般分为三种情况: ①勾选单个框,我们直接用元素定位的方式定位到点击即可. ②勾选多个 ...

  9. 云服务器+域名+hexo 搭建博客

    1 阿里云服务器安全组规则中启用80,4000,22端口, 记得出方向也要设置,否则... 2 域名指向服务器ip 3 安装git yum install git 4 安装node.js 下载地址为: ...

  10. Winform修改配置文件节点保存到配置文件

    主要使用: Configuration config = ConfigurationManager.OpenExeConfiguration(ConfigurationUserLevel.None); ...