1# AccessibilityExtensionAbility示例
2
3## 介绍
4
5本示例展示了AccessibilityExtensionAbility的简单应用,使用多个辅助功能接口实现了一些快捷的交互方式。
6
7## 效果预览
8
9|主页|交互结果|
10|--------------------------------|--------------------------------|
11|![](screenshots/device/NotConnected.png)|![](screenshots/device/Connected.png)|
12
13## 使用说明
141. 在启动无障碍扩展服务前,需退出当前应用保证界面节点正常生成;
152. 启动关闭无障碍扩展服务可参考[AccessibilityExtensionAbility开发指南](https://gitee.com/openharmony/docs/blob/master/zh-cn/application-dev/accessibility/accessibilityextensionability.md), 服务连接状态将显示在屏幕上;
163. 启动无障碍扩展服务后,在设备屏幕上绘画右划后再下划的手势`rightThenDown`获取当前界面全部节点,之后绘画左划后再下划的手势`leftThenDown`打印所有节点的指定信息;
174. 在设备屏幕上绘画左划手势`left`对按钮`获焦`进行聚焦,之后可通过绘画右划手势`right`取消对按钮聚焦;
185. 在设备屏幕上绘画下划手势`down`,触发对按钮`未点击/已点击`的点击动作。
19
20## 具体实现
21
22* 获取界面元素、查询元素指定信息、通过text查找元素和获取元素执行指定动作的功能封装在AccessibilityManager,源码参考: [AccessibilityManager.ts](entry/src/main/ets/AccessibilityExtAbility/AccessibilityManager.ts)
23  * 使用 [getWindowRootElement()](https://gitee.com/openharmony/docs/blob/master/zh-cn/application-dev/reference/apis-accessibility-kit/js-apis-inner-application-accessibilityExtensionContext.md#accessibilityextensioncontextgetwindowrootel) 获取界面根节点;
24  * 获取元素属性值:使用AccessibilityUtils.getAttributeValue();
25  * 获取界面所有元素:基于获取的根元素,使用AccessibilityUtils.createElementArray()获取界面所有元素;
26  * 打印界面元素指定信息:使用AccessibilityUtils.getElementWantedInfo()获取元素指定的信息;
27  * 寻找指定元素:使用AccessibilityUtils.findElementByKey()。
28
29## 工程目录
30```
31entry/src/main/ets/
32|---AccessibilityExtAbility
33|   |---AccessibilityExtAbility.ts         // 无障碍扩展服务
34|   |---AccessibilityManager.ts            // 示例
35|---Application
36|---MainAbility
37|---pages
38|   |---index.ets                          // 主页
39|---utils
40|   |---AccessibilityUtils.ts              // 工具类
41|   |---Logger.ts                          // 日志工具类
42|   |---ResourceUtils.ts                   // 资源工具类
43```
44## 相关权限
45不涉及。
46
47## 依赖
48不涉及。
49
50## 约束与限制
511. 本示例仅支持标准系统上运行;
522. 本示例已适配API version 9版本SDK,版本号:3.2.11.9。
533. 本示例基于DevEco Studio 3.1 Beta2 (Build Version: 3.1.0.400, built on April 7, 2023)开发,需使用该版本或更高版本才可编译运行;
544. 本示例使用了AccessibilityExtensionAbility相关系统接口,需要将默认的Public SDK替换为Full SDK,具体替换操作可参考[替换指南](https://gitee.com/openharmony/docs/blob/master/zh-cn/application-dev/faqs/full-sdk-switch-guide.md/) ;
55
56### 下载
57
58如需单独下载本工程,执行如下命令:
59```
60git init
61git config core.sparsecheckout true
62echo code/SystemFeature/ApplicationModels/AccessibilityExtAbility/ > .git/info/sparse-checkout
63git remote add origin https://gitee.com/openharmony/applications_app_samples.git
64git pull origin master
65```