appium模拟键盘事件
原方法:
1 def press_keycode(self, keycode, metastate=None):
2 """Sends a keycode to the device. Android only. Possible keycodes can be
3 found in http://developer.android.com/reference/android/view/KeyEvent.html.
4 :Args:
5 - keycode - the keycode to be sent to the device
6 - metastate - meta information about the keycode being sent
7 """
8 data = {
9 'keycode': keycode,
10 }
11 if metastate is not None:
12 data['metastate'] = metastate
13 self.execute(Command.PRESS_KEYCODE, data)
14 return self
调用:
self.driver.press_keycode('66') #回车键
appium模拟键盘事件的全部对照表:
| 输入值 | 功能名 | keycode |
|---|---|---|
| 电话键 | ||
| KEYCODE_CALL | 拨号键 | 5 |
| KEYCODE_ENDCALL | 挂机键 | 6 |
| KEYCODE_HOME | 按键Home | 3 |
| KEYCODE_MENU | 菜单键 | 82 |
| KEYCODE_BACK | 返回键 | 4 |
| KEYCODE_SEARCH | 搜索键 | 84 |
| KEYCODE_CAMERA | 拍照键 | 27 |
| KEYCODE_FOCUS | 拍照对焦键 | 80 |
| KEYCODE_POWER | 电源键 | 26 |
| KEYCODE_NOTIFICATION | 通知键 | 83 |
| KEYCODE_MUTE | 话筒静音键 | 91 |
| KEYCODE_VOLUME_MUTE | 扬声器静音键 | 164 |
| KEYCODE_VOLUME_UP | 音量增加键 | 24 |
| KEYCODE_VOLUME_DOWN | 音量减小键 | 25 |
| 控制键 | ||
| KEYCODE_ENTER | 回车键 | 66 |
| KEYCODE_ESCAPE | ESC键 | 111 |
| KEYCODE_DPAD_CENTER | 导航键确定键 | 23 |
| KEYCODE_DPAD_UP | 导航键向上 | 19 |
| KEYCODE_DPAD_DOWN | 导航键向下 | 20 |
| KEYCODE_DPAD_LEFT | 导航键向左 | 21 |
| KEYCODE_DPAD_RIGHT | 导航键向右 | 22 |
| KEYCODE_MOVE_HOME | 光标移动到开始键 | 122 |
| KEYCODE_MOVE_END | 光标移动到末尾键 | 123 |
| KEYCODE_PAGE_UP | 向上翻页键 | 92 |
| KEYCODE_PAGE_DOWN | 向下翻页键 | 93 |
| KEYCODE_DEL | 退格键 | 67 |
| KEYCODE_FORWARD_DEL | 删除键 | 112 |
| KEYCODE_INSERT | 插入键 | 124 |
| KEYCODE_TAB | Tab键 | 61 |
| KEYCODE_NUM_LOCK | 小键盘锁 | 143 |
| KEYCODE_CAPS_LOCK | 大写锁定键 | 115 |
| KEYCODE_BREAK | Break/Pause键 | 121 |
| KEYCODE_SCROLL_LOCK | 滚动锁定键 | 116 |
| KEYCODE_ZOOM_IN | 放大键 | 168 |
| KEYCODE_ZOOM_OUT | 缩小键 | 169 |
| 组合键 | ||
| KEYCODE_ALT_LEFT | Alt+Left | |
| KEYCODE_ALT_RIGHT | Alt+Right | |
| KEYCODE_CTRL_LEFT | Control+Left | |
| KEYCODE_CTRL_RIGHT | Control+Right | |
| KEYCODE_SHIFT_LEFT | Shift+Left | |
| KEYCODE_SHIFT_RIGHT | Shift+Right | |
| 基本 | ||
| KEYCODE_0 | 按键’0’ | 7 |
| KEYCODE_1 | 按键’1’ | 8 |
| KEYCODE_2 | 按键’2’ | 9 |
| KEYCODE_3 | 按键’3’ | 10 |
| KEYCODE_4 | 按键’4’ | 11 |
| KEYCODE_5 | 按键’5’ | 12 |
| KEYCODE_6 | 按键’6’ | 13 |
| KEYCODE_7 | 按键’7’ | 14 |
| KEYCODE_8 | 按键’8’ | 15 |
| KEYCODE_9 | 按键’9’ | 16 |
| KEYCODE_A | 按键’A’ | 29 |
| KEYCODE_B | 按键’B’ | 30 |
| KEYCODE_C | 按键’C’ | 31 |
| KEYCODE_D | 按键’D’ | 32 |
| KEYCODE_E | 按键’E’ | 33 |
| KEYCODE_F | 按键’F’ | 34 |
| KEYCODE_G | 按键’G’ | 35 |
| KEYCODE_H | 按键’H’ | 36 |
| KEYCODE_I | 按键’I’ | 37 |
| KEYCODE_J | 按键’J’ | 38 |
| KEYCODE_K | 按键’K’ | 39 |
| KEYCODE_L | 按键’L’ | 40 |
| KEYCODE_M | 按键’M’ | 41 |
| KEYCODE_N | 按键’N’ | 42 |
| KEYCODE_O | 按键’O’ | 43 |
| KEYCODE_P | 按键’P’ | 44 |
| KEYCODE_Q | 按键’Q’ | 45 |
| KEYCODE_R | 按键’R’ | 46 |
| KEYCODE_S | 按键’S’ | 47 |
| KEYCODE_T | 按键’T’ | 48 |
| KEYCODE_U | 按键’U’ | 49 |
| KEYCODE_V | 按键’V’ | 50 |
| KEYCODE_W | 按键’W’ | 51 |
| KEYCODE_X | 按键’X’ | 52 |
| KEYCODE_Y | 按键’Y’ | 53 |
| KEYCODE_Z | 按键’Z’ | 54 |
appium模拟键盘事件的更多相关文章
- JS模拟键盘事件 -- 原理及小例子
提问: 键盘默认事件,比如tab切换,alt+f4关闭,ctrl+t新建等,如果不想通过键盘而是一些按钮点击来触发这些功能,该咋办呢? 例子: 先以tab为例上一个小例子: <!DOCTYPE ...
- JavaScript 模拟键盘事件
JavaScript 模拟键盘事件和鼠标事件(比如模拟按下回车等) 2016年09月08日 15:23:25 神秘_博士 阅读数:41158 标签: javascript鼠标键盘事件模拟更多 个人分类 ...
- selenium 模拟键盘事件 复制粘贴、右键、回车等
#coding=utf-8 ''' selenium ''' from selenium import webdriver as wd import time bc=wd.Chrome(executa ...
- 初识 jquery.simulate.js 模拟键盘事件
用jquery 和 jquery.simulate.js 实现模拟键盘事件,点击上下左右div相当于点击键盘的上下左右键 <!DOCTYPE html> <html> < ...
- 使用jquery模拟键盘事件,但window系统并不会真的响应事件,只是浏览器当前页面会响应而已
<!DOCTYPE html> <html> <head> <title>Demo</title> <meta http-equiv= ...
- C#模拟键盘事件
public partial class Form1 : Form { public Form1() { InitializeComponent(); } [DllImport("USER3 ...
- JavaScript 模拟键盘事件和鼠标事件(比如模拟按下回车等)
http://blog.csdn.net/lovelyelfpop/article/details/52471878# 封装好的function大概就是这样: function fireKeyEven ...
- js模拟键盘事件
<!DOCTYPE html> <html> <head lang="zh-CN"> <meta charset="UTF-8& ...
- JS全屏事件 模拟键盘事件F11 兼容IE
方法1: // 全屏 //el为全屏对象 fullScreen(el) { var rfs = el.requestFullScreen || el.webkitRequestFullScreen | ...
- 由chrome剪贴板问题研究到了js模拟鼠标键盘事件
写在前面 最近公司在搞浏览器兼容的事情,所有浏览器兼容的问题不得不一个人包了.下面来说一下今天遇到的一个问题吧 大家都知道IE下面如果要获得剪贴板里面的信息的话,代码应该如下所示 window.cli ...
随机推荐
- Flutter(八):Flutter路由管理(Router)
目录 一.术语 路由(route): 导航(Navigator): 二.路由管理 1.Navigator示例代码 2.路由定义(命名路由) 在App中定义router: 3.Navigator方法介绍 ...
- kubenetes中的pod删除策略 级联删除与非级联删除
StatefulSet 有状态应用[有状态应用] 有状态:StatefulSet - 集群节点之间的关系. - 数据不完全一致. - 实例之间不对等的关系. - 依靠外部存储的应用. - 通过dns维 ...
- mobile select 移动端下拉框
官方链接 原生 js 移动端选择控件,不依赖任何库 可传入普通数组或者 json 数组 可根据传入的参数长度,自动渲染出对应的列数,支持单项到多项选择 自动识别是否级联 选择成功后,提供自定义回调函数 ...
- LeetCode 690. Employee Importance 员工的重要性(C++/Java)
题目: You are given a data structure of employee information, which includes the employee's unique id, ...
- pandas、spark计算相关性系数速度对比
pandas.spark计算相关性系数速度对比 相关性计算有三种算法:pearson.spearman,kenall. 在pandas库中,对一个Dataframe,可以直接计算这三个算法的相关系数c ...
- Vue3:项目创建
Vue 3 相对于 Vue 2 带来了许多改进和优点,这些改进主要是为了提高性能.开发体验和可维护性.但是对于创建项目,Vue3也可以采用跟Vue2相同的方式. 使用CLI创建 1. 安装Vue CL ...
- node-sass升级为dart-sass
卸载node-sass npm uninstall node-sass 安装dart-sass npm install sass sass-loader -D 在选择dart-sass版本的时候建议低 ...
- AGE SORT
AGE SORT 你有所有城市的人的年齡資料,而且這城市的人們都大於1歲,且都不會活超過100歲.現在你有個簡單的任務以升冪去排序所有的年齡 Input 接下來會有很多筆的資料,每筆資料從輸入n 開始 ...
- #PowerBi 1分钟学会,用PowerBi获取数据库最近90天的数据(DATE_SUB)
在powerbi报表中,我们往往会对数据源进行日常刷新,powerbi链接了数据库的情况下,根据日期灵活取数是我们必须掌握的一个技能. 在本文中,我们将介绍如何使用 SQL 的 DATE_SUB 函数 ...
- Mysql 聚合函数嵌套使用
Mysql 聚合函数嵌套使用 目的:Mysql 聚合函数嵌套使用 聚合函数不可以直接嵌套使用,比如: max(count(*)) 思路:但是可以嵌套子查询使用(先分组取出count值, 再将count ...