1# AccessibilityExtensionAbility示例 2 3## 介绍 4 5本示例展示了AccessibilityExtensionAbility的简单应用,使用多个辅助功能接口实现了一些快捷的交互方式。 6 7## 效果预览 8 9|主页|交互结果| 10|--------------------------------|--------------------------------| 11||| 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```