深入了解 HarmonyOS 应用开发:从配置到图标,一切尽在掌握

举报
柠檬味拥抱1 发表于 2023/11/30 23:31:55 2023/11/30
【摘要】 @[toc] HarmonyOS 应用模型解析HarmonyOS 应用模型是为开发者提供应用程序所需能力的抽象,简化了应用开发流程,提供了一套统一的模型,使得应用开发更为简单、高效。在此,我们将详细解读应用模型的构成要素以及对新推出的 Stage 模型进行深入分析。 应用模型的构成要素 1. 应用组件应用组件是应用的基本组成单位,充当应用的运行入口。它们包括不同的状态,这些状态被称为应用组件...

@[toc]

HarmonyOS 应用模型解析

HarmonyOS 应用模型是为开发者提供应用程序所需能力的抽象,简化了应用开发流程,提供了一套统一的模型,使得应用开发更为简单、高效。在此,我们将详细解读应用模型的构成要素以及对新推出的 Stage 模型进行深入分析。

应用模型的构成要素

1. 应用组件

应用组件是应用的基本组成单位,充当应用的运行入口。它们包括不同的状态,这些状态被称为应用组件的生命周期。通过生命周期回调函数,开发者能够感知应用状态的变化。在应用开发中,首先需要编写应用组件,同时编写其生命周期回调函数,并在应用配置文件中进行相关配置。这使得操作系统在运行时通过配置文件创建应用组件实例,并调度其生命周期回调函数,从而执行开发者的代码。

2. 应用进程模型

应用进程模型定义了应用进程的创建、销毁方式以及进程间通信方式。

3. 应用线程模型

应用线程模型定义了应用进程内线程的创建、销毁方式,主线程和 UI 线程的创建方式,以及线程间通信方式。

4. 应用任务管理模型

应用任务管理模型定义了任务(Mission)的创建、销毁方式,以及任务与组件间的关系。值得注意的是,HarmonyOS 应用任务管理由系统应用负责,三方应用无需过多关注。

5. 应用配置文件

应用配置文件包含了应用配置信息、应用组件信息、权限信息、开发者自定义信息等。这些信息在编译构建、分发和运行阶段分别提供给编译工具、应用市场和操作系统使用。

HarmonyOS 应用模型概览

随着系统的不断演进,HarmonyOS 先后提供了两种应用模型:

  1. FA(Feature Ability)模型: 早期版本开始支持,目前已不再主推。
  2. Stage 模型: 自 HarmonyOS 3.1 Developer Preview 版本开始新增,是目前主推的模型。在 Stage 模型中,应用组件和窗口通过 AbilityStage、WindowStage 等类作为“舞台”进行管理,因此被称为 Stage 模型。

Stage 模型的设计基于多个出发点:

  • 为复杂应用而设计: 多个应用组件共享同一个 ArkTS 引擎实例,便于共享对象和状态,同时减少内存占用。采用面向对象的开发方式,提高代码可读性、易维护性和可扩展性。

  • 支持多设备和多窗口形态: 应用组件管理和窗口管理在架构层面解耦,方便系统对应用组件进行裁剪,扩展窗口形态。在多设备上,应用组件可使用同一套生命周期。

  • 平衡应用能力和系统管控成本: Stage 模型重新定义了应用能力的边界,提供特定场景的应用组件,规范后台进程管理,防止恶意应用行为。

对比 FA 模型 与 Stage 模型

最大的区别在于 ArkTS 引擎实例的共享。在 Stage 模型中,多个应用组件共享同一个 ArkTS 引擎实例,便于共享对象和状态,降低复杂应用的内存占用。作为主推模型,Stage 模型为开发者提供了更便利地开发分布式场景下复杂应用的方式。

FA 模型与 Stage 模型的主要差异概览如下:

项目 FA 模型 Stage 模型
应用组件 - PageAbility 组件:包含 UI 界面,提供展示 UI 的能力。- ServiceAbility 组件:提供后台服务的能力,无 UI 界面。- DataAbility 组件:提供数据分享的能力,无 UI 界面。- 开发方式:通过导出匿名对象、固定入口文件的方式指定应用组件。不支持派生。 - UIAbility 组件:包含 UI 界面,提供展示 UI 的能力,主要用于用户交互。- ExtensionAbility 组件:提供特定场景的扩展能力,满足更多的使用场景。- 开发方式:采用面向对象的方式,以类接口形式开放给开发者,支持派生。
进程模型 两类进程:主进程和渲染进程。详细介绍请参见进程模型。 三类进程:主进程、ExtensionAbility 进程、渲染进程。详细介绍请参见进程模型。
线程模型 - ArkTS 引擎实例的创建:一个进程可以运行多个应用组件实例,每个实例在一个单独的 ArkTS 引擎实例中。- 线程模型:每个 ArkTS 引擎实例在一个单独线程(非主线程)上创建,主线程没有 Ark

TS 引擎实例。- 进程内对象共享:不支持。 | - ArkTS 引擎实例的创建:一个进程可以运行多个应用组件实例,所有实例共享一个 ArkTS 引擎实例。- 线程模型:ArkTS 引擎实例在主线程上创建。- 进程内对象共享:支持。 |
| 应用配置文件 | 使用 config.json 描述应用信息、HAP 信息和应用组件信息。详细介绍请参见[应用配置文件概述(FA 模型)。 | 使用 app.json5 描述应用信息,module.json5 描述 HAP 信息、应用组件信息。详细介绍请参见应用配置文件概述(Stage 模型) |
在这里插入图片描述
在这里插入图片描述

通过对比 FA 模型 和 Stage 模型,我们可以更清晰地了解两者的异同,以及为何 Stage 模型成为主推模型。 Stage 模型以其设计理念为复杂应用而生、支持多设备和多窗口形态、平衡应用能力和系统管控成本而备受青睐,为开发者提供了更强大的工具和灵活性,适用于各种复杂应用场景。

Stage模型开发概述

基本概念

Stage 模型为 HarmonyOS 应用开发提供了一些核心概念,这些概念构成了应用的基础。以下是 Stage 模型中的基本概念:
在这里插入图片描述

1. UIAbility 组件和 ExtensionAbility 组件

  • UIAbility 组件: 包含 UI 界面的应用组件,主要用于与用户进行交互。例如,图库应用可以在 UIAbility 组件中展示图片瀑布流,用户选择图片后,可以在新的页面中查看详细内容。UIAbility 的生命周期包括创建、销毁、前台和后台等状态,与显示相关的状态通过 WindowStage 的事件暴露给开发者。

  • ExtensionAbility 组件: 面向特定场景的应用组件。

2. WindowStage

每个 UIAbility 类实例都与一个 WindowStage 类实例绑定。WindowStage 提供了应用进程内窗口管理器的功能,包含一个主窗口。UIAbility 通过 WindowStage 持有一个窗口,为 ArkUI 提供绘制区域。

3. Context

在 Stage 模型中,Context 及其派生类为开发者提供在运行期间调用的各种能力。UIAbility 组件和各种 ExtensionAbility 派生类都有不同的 Context 类,它们继承自基类 Context,但根据所属组件提供不同的能力。

4. AbilityStage

每个 Entry 类型或 Feature 类型的 HAP 在运行期都有一个 AbilityStage 类实例。当 HAP 中的代码首次加载到进程中时,系统会先创建 AbilityStage 实例。每个在该 HAP 中定义的 UIAbility 类,在实例化后都会与该 AbilityStage 实例产生关联。开发者可以使用 AbilityStage 获取该 HAP 中 UIAbility 实例的运行时信息。

开发流程

基于 Stage 模型进行应用开发,涉及以下开发流程:

表1 Stage 模型开发流程

步骤 描述
1 定义 UIAbility 和 ExtensionAbility 组件: 开发者需要定义 UIAbility 和 ExtensionAbility 组件,以满足应用的功能需求。
2 创建 AbilityStage 实例: 系统在 HAP 代码首次加载到进程中时,会创建 AbilityStage 实例。
3 UIAbility 组件与 WindowStage 绑定: 每个 UIAbility 实例都与一个 WindowStage 实例绑定,通过 WindowStage 管理窗口。
4 使用 Context 提供的能力: 开发者可以使用 UIAbility 或 ExtensionAbility 的 Context 类提供的能力,实现应用所需的功能。
5 事件处理和生命周期管理: 开发者通过监听 WindowStage 的事件,处理 UIAbility 的生命周期,实现对界面的控制和交互。
6 调用其他组件: 在应用中,不同组件可能需要相互调用,开发者可以通过 Context 提供的能力实现组件间的通信。
7 发布应用: 完成应用开发后,开发者可以将应用发布到 HarmonyOS 设备上,供用户使用。

以上步骤涵盖了 Stage 模型应用开发的基本流程,开发者可以根据具体需求和场景进行灵活调整。在这个过程中,深入理解每个基本概念的作用和相互关系,将有助于更高效、更灵活地开发 HarmonyOS 应用。

在这里插入图片描述

应用/组件级配置

在 HarmonyOS 应用开发过程中,配置是非常重要的一部分,涉及应用的包名、图标、标签等标识特征的属性。本文将介绍在开发应用时,需要配置的一些关键标签,包括应用包名、应用图标、应用标签、入口图标、入口标签、应用版本声明、Module 支持的设备类型以及 Module 权限配置。

1. 应用包名配置

在应用开发中,需要为应用配置一个唯一的包名,用于标识应用。推荐采用反域名形式命名,例如com.example.demo,其中第一级为域名后缀(如com),第二级为厂商/个人名,第三级为应用名。

{
  "app": {
    "bundleName": "com.example.demo",
    // ...
  }
}

2. 应用图标和标签配置

在 Stage 模型中,应用图标和标签配置位于 app.json5 配置文件 中。图标配置使用 icon 标签,需要指定为图片的资源索引。标签配置使用 label 标签,标识应用对用户显示的名称,需要配置为字符串资源的索引。

{
  "app": {
    "icon": "$media:app_icon",
    "label": "$string:app_name",
    // ...
  }
}

3. 入口图标和标签配置

入口图标和标签配置用于在桌面上显示应用的图标。在 module.json5 配置文件 中,通过 abilities 标签配置入口图标和标签。可以在 entities 中添加需要显示图标的 entity.system.home,在 actions 中添加相应的 action.system.home

{
  "module": {
    // ...
    "abilities": [
      {
        "icon": "$media:icon",
        "label": "$string:EntryAbility_label",
        "skills": [
          {
            "entities": [
              "entity.system.home"
            ],
            "actions": [
              "action.system.home"
            ]
          }
        ],
        // ...
      }
    ]
  }
}

4. 应用版本声明配置

应用版本声明需要在 app.json5 配置文件 中配置 versionCodeversionName 标签。versionCode 用于标识应用的版本号,是一个 32 位非负整数,用于确定版本更新。versionName 用于标识版本号的文字描述。

{
  "app": {
    "versionCode": 1,
    "versionName": "1.0.0",
    // ...
  }
}

5. Module 支持的设备类型配置

module.json5 配置文件 中,通过 deviceTypes 标签配置 Module 支持的设备类型。添加某种设备类型表示当前的 Module 支持在该设备上运行。

{
  "module": {
    // ...
    "deviceTypes": [
      "phone",
      "tablet"
    ],
    // ...
  }
}

6. Module 权限配置

Module 访问系统或其他应用受保护部分所需的权限信息需要在 module.json5 配置文件 中配置 requestPermission 标签。该标签用于声明需要申请权限的名称、申请权限的原因以及权限使用的场景。

{
  "module": {
    // ...
    "requestPermission": [
      {
        "name": "ohos.permission.CAMERA",
        "reason": "Access camera for capturing photos",
        "usedScene": "Capture photos"
      }
    ],
    // ...
  }
}

以上是应用/组件级配置的一些关键标签和配置示例,开发者可以根据具体需求进行相应的配置。这些配置将直接影响应用的外观、功能和运行环境。

【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。