AccessibilityExtensionAbility示例
介绍
本示例展示了AccessibilityExtensionAbility的简单应用,使用多个辅助功能接口实现了一些快捷的交互方式。
效果预览
| 主页 | 交互结果 |
|---|---|
![]() |
![]() |
使用说明
- 在启动无障碍扩展服务前,需退出当前应用保证界面节点正常生成;
- 启动关闭无障碍扩展服务可参考AccessibilityExtensionAbility开发指南, 服务连接状态将显示在屏幕上;
- 启动无障碍扩展服务后,在设备屏幕上绘画手势
rightThenDown获取当前界面全部节点,之后绘画手势leftThenDown打印所有节点的指定信息; - 在设备屏幕上绘画手势
left对按钮获焦进行聚焦,之后可通过绘画手势right取消对按钮聚焦; - 在设备屏幕上绘画手势
down,触发对按钮未点击/已点击的点击动作。
具体实现
- 获取界面元素、查询元素指定信息、通过text查找元素和获取元素执行指定动作的功能封装在AccessibilityManager,源码参考: AccessibilityManager.ts
- 使用 getWindowRootElement() 获取界面根节点;
- 获取元素属性值:使用AccessibilityUtils.getAttributeValue();
- 获取界面所有元素:基于获取的根元素,使用AccessibilityUtils.createElementArray()获取界面所有元素;
- 打印界面元素指定信息:使用AccessibilityUtils.getElementWantedInfo()获取元素指定的信息;
- 寻找指定元素:使用AccessibilityUtils.findElementByKey()。
工程目录
entry/src/main/ets/
|---AccessibilityExtAbility
| |---AccessibilityExtAbility.ts // 无障碍扩展服务
| |---AccessibilityManager.ts // 示例
|---Application
|---MainAbility
|---pages
| |---index.ets // 主页
|---utils
| |---AccessibilityUtils.ts // 工具类
| |---Logger.ts // 日志工具类
| |---ResourceUtils.ts // 资源工具类
相关权限
不涉及。
依赖
不涉及。
约束与限制
- 本示例仅支持标准系统上运行;
- 本示例已适配API version 9版本SDK,版本号:3.2.11.9。
- 本示例基于DevEco Studio 3.1 Beta2 (Build Version: 3.1.0.400, built on April 7, 2023)开发,需使用该版本或更高版本才可编译运行;
- 本示例使用了AccessibilityExtensionAbility相关系统接口,需要将默认的Public SDK替换为Full SDK,具体替换操作可参考替换指南 ;
下载
如需单独下载本工程,执行如下命令:
git init
git config core.sparsecheckout true
echo code/SystemFeature/ApplicationModels/AccessibilityExtAbility/ > .git/info/sparse-checkout
git remote add origin https://gitee.com/openharmony/applications_app_samples.git
git pull origin master

