HarmonyOS鸿蒙NEXT应用元服务开发组合场景

HarmonyOS鸿蒙NEXT应用元服务开发组合场景 在一些场景中,一个功能上完整的UI对象可能是由若干个更小的UI组件组合而成的。若每一个小的UI组件都可以获焦并朗读,则会造成信息冗余和效率降低。同时由于可聚焦的组件过多过细,也会影响触摸浏览时走焦的性能体验。在这种情况下,将它们在功能或语义上聚合成一个自然组并作为一个独立可获焦的UI元素来向视障用户表达内容更加合理,且更加高效。

总体原则是:对于表示同一个对象信息的多个组件,需要进行组合标注,对外只暴露一个无障碍焦点。

如下,可以将多个控件设置为一个组,通过对组设置朗读标签,达到整组播报的效果,组内的子控件设置不可获取焦点。

可以将多个控件设置为一个组,通过对组设置朗读标签,达到整组播报的效果,组内的子控件设置不可获取焦点。

@Component
export struct Rule_2_1_5 {
  title: string = 'Rule 2.1.5'

  build() {
    NavDestination() {
      Column() {

        Row(){
          //默认只有子组件才能获取焦点
         //日期、天气、温度等信息在每个组件独立获取焦点时分别朗读
         //在组合式组件规范里是不正确的。
          Text("23 Dec 2023") // 日期信息。组件可独立对焦和朗读
            .fontSize(32)
            .fontColor(Color.Red)
            .fontWeight(FontWeight.Bold)
            .textAlign(TextAlign.Center)
            .margin({right: 20})

          Column() // 天气信息。组件可独立对焦和朗读
            .backgroundColor(Color.Blue)
            .width(50)
            .height(50)
            .accessibilityText("Snow") // 当该组件被屏幕阅读器选中时,该组件不包含文本信息,因此将读取此文本
            .margin({right: 20})

          Text("-1") // 温度信息。组件可独立对焦和朗读
            .fontSize(20)
            .fontColor(Color.Green)
            .fontWeight(FontWeight.Bold)
            .textAlign(TextAlign.Center)
        }
        .height(50)
        .margin({bottom: 20})

        Row(){
          //因为accessibilityGroup属性设置为true,子组件无法获取焦点。
          //获取焦点时,日期、天气、温度信息一起朗读
         //此时只有Row可以获取焦点,这是符合组合式组件规范的。
          Text("24 Dec 2023") //日期信息。组件无法聚焦,无法朗读,因为父组件的accessibilityGroup属性设置为true
            .fontSize(32)
            .fontColor(Color.Red)
            .fontWeight(FontWeight.Bold)
            .textAlign(TextAlign.Center)
            .margin({right: 20})

          Column() //天气信息组件无法聚焦,无法朗读,因为父组件的accessibilityGroup为true
            .backgroundColor(Color.Yellow)
            .width(50)
            .height(50)
            .accessibilityText("Sunny") // 组件不包含文本信息,当组件被屏幕阅读器选中时,因此将读取此文本
            .margin({right: 20})

          Text("-7") // //温度信息。组件无法聚焦,无法朗读因为父组件的accessibilityGroup为true
            .fontSize(20)
            .fontColor(Color.Green)
            .fontWeight(FontWeight.Bold)
            .textAlign(TextAlign.Center)
        }
        .height(50)
        .margin({bottom: 20})
        .accessibilityGroup(true) // 将accessibilityGroup属性设置为true
      }
      .alignItems(HorizontalAlign.Start)
      .padding(10)
    }
    .title(this.title)
  }
}

更多关于HarmonyOS鸿蒙NEXT应用元服务开发组合场景的实战教程也可以访问 https://www.itying.com/category-93-b0.html

2 回复

HarmonyOS鸿蒙NEXT应用元服务开发组合场景涉及多个关键技术和组件。首先,元服务(Ability)是鸿蒙系统中的基本功能单元,分为Page Ability和Service Ability。Page Ability用于展示用户界面,Service Ability用于后台任务处理。组合场景开发通常需要结合这两种Ability,以实现复杂的功能需求。其次,鸿蒙NEXT引入了分布式任务调度机制,允许应用在不同设备间无缝切换和协同工作。开发者可以通过分布式数据管理技术,实现跨设备的数据共享和同步。此外,鸿蒙NEXT还提供了丰富的UI组件和动画效果,帮助开发者构建流畅的用户体验。在组合场景开发中,开发者需要利用鸿蒙的ArkTS语言进行编程,ArkTS是鸿蒙系统的专用语言,支持声明式UI和响应式编程范式。最后,鸿蒙NEXT的开发者工具链(如DevEco Studio)提供了完整的开发、调试和测试环境,支持快速迭代和部署应用。通过这些技术和工具,开发者可以高效地构建复杂、跨设备的应用元服务组合场景。

更多关于HarmonyOS鸿蒙NEXT应用元服务开发组合场景的实战系列教程也可以访问 https://www.itying.com/category-93-b0.html


在HarmonyOS鸿蒙NEXT中,应用元服务开发组合场景主要涉及以下步骤:

  1. 服务定义:使用@Service注解定义元服务,明确服务功能与接口。
  2. 服务实现:在ServiceAbility中实现服务逻辑,确保高效稳定。
  3. 服务注册:在config.json中注册服务,使其可被其他应用发现和调用。
  4. 服务调用:通过connectAbility连接到服务,使用call方法进行远程调用。
  5. 组合场景:结合多个元服务,构建复杂业务逻辑,通过事件驱动和数据共享实现协同工作。

这种开发模式提升了应用的模块化和可重用性,适合复杂业务场景。

回到顶部