1 В избранное 0 Ответвления 0

OSCHINA-MIRROR/openharmony-applications_app_samples

Присоединиться к Gitlife
Откройте для себя и примите участие в публичных проектах с открытым исходным кодом с участием более 10 миллионов разработчиков. Приватные репозитории также полностью бесплатны :)
Присоединиться бесплатно
Это зеркальный репозиторий, синхронизируется ежедневно с исходного репозитория.
Клонировать/Скачать
Внести вклад в разработку кода
Синхронизировать код
Отмена
Подсказка: Поскольку Git не поддерживает пустые директории, создание директории приведёт к созданию пустого файла .keep.
Loading...
README_zh.md

AccessibilityExtensionAbility示例(仅对系统应用开放)

介绍

本示例展示了AccessibilityExtensionAbility的简单应用,使用多个辅助功能接口实现了一些快捷的交互方式。

效果预览

主页 交互结果

使用说明

  1. 在启动无障碍扩展服务前,需退出当前应用保证界面节点正常生成;
  2. 启动关闭无障碍扩展服务可参考AccessibilityExtensionAbility开发指南, 服务连接状态将显示在屏幕上;
  3. 启动无障碍扩展服务后,在设备屏幕上绘画右划后再下划的手势rightThenDown获取当前界面全部节点,之后绘画左划后再下划的手势leftThenDown打印所有节点的指定信息;
  4. 在设备屏幕上绘画左划手势left对按钮获焦进行聚焦,之后可通过绘画右划手势right取消对按钮聚焦;
  5. 在设备屏幕上绘画下划手势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                   // 资源工具类

相关权限

不涉及。

依赖

不涉及。

约束与限制

  1. 本示例仅支持标准系统上运行;
  2. 本示例已适配API version 9版本SDK,版本号:3.2.11.9。
  3. 本示例基于DevEco Studio 3.1 Beta2 (Build Version: 3.1.0.400, built on April 7, 2023)开发,需使用该版本或更高版本才可编译运行;
  4. 本示例使用了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

Комментарий ( 0 )

Вы можете оставить комментарий после Вход в систему

1
https://gitlife.ru/oschina-mirror/openharmony-applications_app_samples.git
git@gitlife.ru:oschina-mirror/openharmony-applications_app_samples.git
oschina-mirror
openharmony-applications_app_samples
openharmony-applications_app_samples
weekly_20240115-v