getevent基础及实际使用(按自己理解写的)

基本

首先这个工具或者说命令,是只能再安卓平台上使用。自己的安卓手机+设备都是自带这个命令。

130|jason:/ $ getevent -h
Usage: getevent [-t] [-n] [-s switchmask] [-S] [-v [mask]] [-d] [-p] [-i] [-l] [-q] [-c count] [-r] [device]
    -t: show time stamps
    -n: don't print newlines
    -s: print switch states for given bits
    -S: print all switch states
    -v: verbosity mask (errs=1, dev=2, name=4, info=8, vers=16, pos. events=32, props=64)
    -d: show HID descriptor, if available
    -p: show possible events (errs, dev, name, pos. events)
    -i: show all device info and possible events
    -l: label event types and names in plain text
    -q: quiet (clear verbosity mask)
    -c: print given number of events then exit
    -r: print rate events are received

(以上以小米手机为例)

  • -t: show time stamps
1|jason:/ $ getevent -t
add device 1: /dev/input/event6
...
...
add device 7: /dev/input/event4
  name:     "gpio-keys"
[     178.611639] /dev/input/event0: 0001 0074 00000001
[     178.611639] /dev/input/event0: 0000 0000 00000000
[     178.718516] /dev/input/event0: 0001 0074 00000000
[     178.718516] /dev/input/event0: 0000 0000 00000000
[     180.954315] /dev/input/event0: 0001 0074 00000001

打印时间戳

  • -n: don't print newlines
1|jason:/ $ getevent -n
add device 1: /dev/input/event6
...
...
  name:     "synaptics_dsx"
/dev/input/event0: 0001 0074 00000001/dev/input/event0: 0000 0000 
00000000/dev/input/event0: 0001 0074 00000000/dev/input/event0: 0000 
0000 00000000/dev/input/event1: 0003 0039 0000000a/dev/input/event1: 
0001 014a 00000001/dev/input/event1: 0001 0145 
00000001/dev/input/event1: 0003 0035 00000288/dev/input/event1: 0003 
0036 0000064e/dev/input/event1: 0003 0030 00000006/dev/input/event1: 
0003 0031 00000005/dev/input/event1: 0000 0000 
00000000/dev/input/event1: 0003 0031 00000006/dev/input/event1: 0000 
0000 00000000/dev/input/event1: 0003 0031 00000005

(个人不建议使用,没想到实际用处)

  • -s: print switch states for given bits
  • -p: show possible events (errs, dev, name, pos. events)
jason:/dev/input $ getevent -p
add device 1: /dev/input/event6
  name:     "sdm660-snd-card Button Jack"
  events:
    KEY (0001): 00e2  0101  0102  0103  0104  0105
  input props:
    INPUT_PROP_ACCELEROMETER
add device 2: /dev/input/event5
  name:     "sdm660-snd-card Headset Jack"
  events:
    SW  (0005): 0002  0004  0006  0007  000f  0010  0011  0012
  input props:
    <none>
could not get driver version for /dev/input/mice, Not a typewriter
could not get driver version for /dev/input/mouse0, Not a typewriter
add device 3: /dev/input/event0
  name:     "qpnp_pon"
  events:
    KEY (0001): 0072  0074
  input props:
    <none>
add device 4: /dev/input/event2
  name:     "hbtp_vm"
  events:
    KEY (0001): 0110  0111
    REL (0002): 0000  0001
  input props:
    INPUT_PROP_DIRECT
add device 5: /dev/input/event4
  name:     "gpio-keys"
  events:
    KEY (0001): 0073
    SW  (0005): 0000
  input props:
    <none>
could not get driver version for /dev/input/mouse1, Not a typewriter
add device 6: /dev/input/event3
  name:     "uinput-goodix"
  events:
    KEY (0001): 0066  0067  0069  006a  006c  0072  0073  0074
                008b  009e  00d4  00d8  00d9
  input props:
    <none>
add device 7: /dev/input/event1
  name:     "synaptics_dsx"
  events:
    KEY (0001): 0066  008b  008f  009e  0145  014a
    ABS (0003): 0000  : value 0, min 0, max 1079, fuzz 0, flat 0, resolution 0
                0001  : value 0, min 0, max 1919, fuzz 0, flat 0, resolution 0
                002f  : value 0, min 0, max 9, fuzz 0, flat 0, resolution 0
                0030  : value 0, min 0, max 255, fuzz 0, flat 0, resolution 0
                0031  : value 0, min 0, max 255, fuzz 0, flat 0, resolution 0
                0035  : value 0, min 0, max 1079, fuzz 0, flat 0, resolution 0
                0036  : value 0, min 0, max 1919, fuzz 0, flat 0, resolution 0
                0039  : value 0, min 0, max 65535, fuzz 0, flat 0, resolution 0
  input props:
    INPUT_PROP_DIRECT

每个设备支持的事件类型以及编码都列举了出来
支持的事件类型有:
EV_SYN [0000] (同步事件);
EV_KEY [0001] (按键事件);
EV_ABS [0003] (绝对值事件);

/dev/input/event1: EV_ABS       ABS_MT_TRACKING_ID   00000058
/dev/input/event1: EV_KEY       BTN_TOUCH            DOWN
/dev/input/event1: EV_KEY       BTN_TOOL_FINGER      DOWN
/dev/input/event1: EV_ABS       ABS_MT_POSITION_X    000002a7
/dev/input/event1: EV_ABS       ABS_MT_POSITION_Y    00000500
/dev/input/event1: EV_ABS       ABS_MT_TOUCH_MINOR   00000004
/dev/input/event1: EV_SYN       SYN_REPORT           00000000

https://blog.csdn.net/lqxandroid2012/article/details/45889657

  • -l: label event types and names in plain text
# event类型+事件类型              #事件码               #事件值
/dev/input/event1: EV_ABS       ABS_MT_TRACKING_ID   000000a6
/dev/input/event1: EV_KEY       BTN_TOUCH            DOWN
/dev/input/event1: EV_KEY       BTN_TOOL_FINGER      DOWN
/dev/input/event1: EV_ABS       ABS_MT_POSITION_X    00000311
/dev/input/event1: EV_ABS       ABS_MT_POSITION_Y    0000038f

以文本形式输出事件类型和名称
(强调:这个实际用的最多,比直接看码直观很多)

ABS_MT_TOUCH_MAJOR [0030] (接触面长轴值) {有效值范围[0, 255]}
ABS_MT_POSITION_X [0035] (x轴坐标) {有效值范围[0, 1079]}
ABS_MT_POSITION_Y [0036] (y轴坐标) {有效值范围[0, 1919]}
(主要关注这机个就行了,补充x、y+1就是屏幕尺寸1920*1080)

按键编码有:
KEY_HOME [0066] (HOME键),
KEY_MENU [008b] (MENU键)
KEY_BACK [009e] (BACK键)
KEY_SEARCH [00d9] (SEARCH键)
BTN_TOUCH [014a]
BTN_TOOL_FINGER [0145]

实际使用

1、触屏坐标检验、按键按压判断

实际在工作中使用(测试),绝大多数情况用于触屏坐标检验、按键按压判断等

/dev/input/event1: EV_SYN       SYN_REPORT           00000000
/dev/input/event1: EV_ABS       ABS_MT_POSITION_X    00000407
/dev/input/event1: EV_ABS       ABS_MT_POSITION_Y    0000077c
/dev/input/event1: EV_SYN       SYN_REPORT           00000000

比如上面这个例子
可以判断
X:1031
y:1916

/dev/input/event0: EV_KEY       KEY_VOLUMEDOWN       DOWN
/dev/input/event0: EV_SYN       SYN_REPORT           00000000
/dev/input/event0: EV_KEY       KEY_VOLUMEDOWN       UP
/dev/input/event0: EV_SYN       SYN_REPORT           00000000

这个例子表示一个按键的按下和抬起

2、作为脚本测试工具调用

思路:选择固定的点作为测试目标,设计误差范围,持续读取X、Y轴坐标点,量化错误率:

# 主函数
adb shell " evtest /dev/input/event1 "| while read line
    do
        if [[ $(echo $line|grep "ABS_MT_POSITION_X)," |wc -l) -ge 1 ]]
        then
            tp_x2=$(echo $line |awk '{print $NF}'|tr -d '\r')
            #number tp_x2
        elif [[ $(echo $line|grep "ABS_MT_POSITION_Y)," |wc -l) -ge 1 ]]
        then
            tp_y2=$(echo $line |awk '{print $NF}'|tr -d '\r')
            #number tp_y2
            echo "LOOP: "$i
            ((i++))
            tp_check $tp_x2 $tp_x1 ABS_MT_POSITION_X
            tp_check $tp_y2 $tp_y1 ABS_MT_POSITION_Y
            echo "fail number : $m "
            echo " "
        fi
    done

主函数分享(这个用evtest的,思路一样)

...

LOOP: 20
ABS_MT_POSITION_X: success.
ABS_MT_POSITION_Y: success.
fail number : 0

LOOP: 21
ABS_MT_POSITION_X: success.
ABS_MT_POSITION_Y: check fail !!!
fail number : 1

...
3、用于UI自动化测试

通过使用指令或脚本,控制设备的触屏事件和各种物理按键按压时间,也就是说不只是在某一个APP操作,也可以做到传统的adb shell input无法实现的case,比如连续快速点击事件;
通过adb 模拟手机快速点击方法
(方法参考之前写的一篇文章)

getevent/sendevent

补充-关于触屏事件

/dev/input/event1: 0003 0039 000000ec
/dev/input/event1: 0001 014a 00000001
/dev/input/event1: 0001 0145 00000001
/dev/input/event1: 0003 0035 0000023e
/dev/input/event1: 0003 0036 0000056a
/dev/input/event1: 0003 0031 00000003
/dev/input/event1: 0000 0000 00000000
/dev/input/event1: 0003 0031 00000004
/dev/input/event1: 0000 0000 00000000
/dev/input/event1: 0003 0030 00000006
/dev/input/event1: 0000 0000 00000000
/dev/input/event1: 0003 0030 00000005
/dev/input/event1: 0000 0000 00000000
/dev/input/event1: 0003 0039 ffffffff
/dev/input/event1: 0001 014a 00000000
/dev/input/event1: 0001 0145 00000000
/dev/input/event1: 0000 0000 00000000

一次触屏事件

1 、/dev/input/event1: EV_ABS       ABS_MT_TRACKING_ID   000000ee
2 、/dev/input/event1: EV_KEY       BTN_TOUCH            DOWN
3 、/dev/input/event1: EV_KEY       BTN_TOOL_FINGER      DOWN
4 、/dev/input/event1: EV_ABS       ABS_MT_POSITION_X    00000215
5 、/dev/input/event1: EV_ABS       ABS_MT_POSITION_Y    000004f4
6 、/dev/input/event1: EV_ABS       ABS_MT_TOUCH_MAJOR   00000004
7 、/dev/input/event1: EV_ABS       ABS_MT_TOUCH_MINOR   00000003
8 、/dev/input/event1: EV_SYN       SYN_REPORT           00000000
9 、/dev/input/event1: EV_ABS       ABS_MT_TOUCH_MAJOR   00000006
10、/dev/input/event1: EV_ABS       ABS_MT_TOUCH_MINOR   00000004
11、/dev/input/event1: EV_SYN       SYN_REPORT           00000000
12、/dev/input/event1: EV_ABS       ABS_MT_TRACKING_ID   ffffffff
13、/dev/input/event1: EV_KEY       BTN_TOUCH            UP
14、/dev/input/event1: EV_KEY       BTN_TOOL_FINGER      UP
15、/dev/input/event1: EV_SYN       SYN_REPORT           00000000

使用-l方便阅读,已加上序号
1、可理解为一次touch的开始;

130|jason:/ $ getevent -l |grep ABS_MT_TRACKING_ID
/dev/input/event1: EV_ABS       ABS_MT_TRACKING_ID   000000f7
/dev/input/event1: EV_ABS       ABS_MT_TRACKING_ID   ffffffff
/dev/input/event1: EV_ABS       ABS_MT_TRACKING_ID   000000f8
/dev/input/event1: EV_ABS       ABS_MT_TRACKING_ID   ffffffff
/dev/input/event1: EV_ABS       ABS_MT_TRACKING_ID   000000f9
/dev/input/event1: EV_ABS       ABS_MT_TRACKING_ID   ffffffff
/dev/input/event1: EV_ABS       ABS_MT_TRACKING_ID   000000fa
/dev/input/event1: EV_ABS       ABS_MT_TRACKING_ID   ffffffff
/dev/input/event1: EV_ABS       ABS_MT_TRACKING_ID   000000fb
/dev/input/event1: EV_ABS       ABS_MT_TRACKING_ID   ffffffff
/dev/input/event1: EV_ABS       ABS_MT_TRACKING_ID   000000fc
/dev/input/event1: EV_ABS       ABS_MT_TRACKING_ID   ffffffff
/dev/input/event1: EV_ABS       ABS_MT_TRACKING_ID   000000fd

每次点击屏幕,ABS_MT_TRACKING_ID 的值增加一位(16进制)
同样,ABS_MT_TRACKING_ID ffffffff可以理解为一次touch的结束;

2、3、

  • BTN_TOUCH
    触碰按键。其值是DOWN或者UP。
  • BTN_TOOL_FINGER
    按键的是finger,并且其值也是DOWN或者UP

4、5、
ABS_MT_POSITION_X,ABS_MT_POSITION_Y
相对于屏幕中心的x,y坐标(16进制表示)。

6、7、

  • ABS_MT_TOUCH_MAJOR
    接触部分的长轴长度。相当于椭圆的长轴。
  • ABS_MT_TOUCH_MINOR
    接触部分的短轴长度。相当于椭圆的短轴

其他、SYN_REPORT
可以看到,在一次触摸中,就有好几次SYN_REPORT。是因为有很多的事件,或者是说SYN_REPORT就是一次事件的结束。我的理解是,虽然我们人是用手触摸了一次,但是实际上是有很多个微小的接触点的,这些点对于Touch来说就是事件。并且每次上报的信息可能不同,没有变的参数就不会再重复出现了。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,921评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,635评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,393评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,836评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,833评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,685评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,043评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,694评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 42,671评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,670评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,779评论 1 332
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,424评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,027评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,984评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,214评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,108评论 2 351
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,517评论 2 343