跳到主要内容

Stage模型开发概述

基本概念

下图展示了Stage模型中的基本概念。

图1 Stage模型概念图

  • AbilityStage

    每个Entry类型或者Feature类型的HAP在运行期都有一个AbilityStage实例,当HAP中的代码首次被加载到进程中的时候,系统会先创建AbilityStage实例。

  • UIAbility组件ExtensionAbility组件

    Stage模型提供UIAbility和ExtensionAbility两种类型的组件,这两种组件都有具体的类承载,支持面向对象的开发方式。

    • UIAbility组件是一种包含UI的应用组件,主要用于和用户交互。例如,图库类应用可以在UIAbility组件中展示图片瀑布流,在用户选择某个图片后,在新的页面中展示图片的详细内容。同时用户可以通过返回键返回到瀑布流页面。UIAbility组件的生命周期只包含创建、销毁、前台、后台等状态,与显示相关的状态通过WindowStage的事件暴露给开发者。
    • ExtensionAbility组件是一种面向特定场景的应用组件。开发者并不直接从ExtensionAbility组件派生,而是需要使用ExtensionAbility组件的派生类。目前ExtensionAbility组件有用于卡片场景的FormExtensionAbility,用于输入法场景的InputMethodExtensionAbility,用于延时任务场景的WorkSchedulerExtensionAbility等多种派生类,这些派生类都是基于特定场景提供的。例如,用户在桌面创建应用的卡片,需要开发者从FormExtensionAbility派生,实现其中的回调函数,并在配置文件中配置该能力。ExtensionAbility组件的派生类实例由用户触发创建,并由系统管理生命周期。在Stage模型上,三方应用开发者不能开发自定义服务,而需要根据自身的业务场景通过ExtensionAbility组件的派生类来实现。

    一个HAP包中可以包含一个或多个UIAbility/ExtensionAbility组件,这些组件在运行时共用同一个AbilityStage实例。当HAP中的代码(无论是UIAbility组件还是ExtensionAbility组件)首次被加载到进程中的时候,系统会先创建对应的AbilityStage实例。

  • WindowStage

    每个UIAbility实例都会与一个WindowStage类实例绑定,该类起到了应用进程内窗口管理器的作用。它包含一个主窗口。也就是说UIAbility实例通过WindowStage持有了一个主窗口,该主窗口为ArkUI提供了绘制区域,可以加载不同的ArkUI页面。

  • Context

    在Stage模型上,Context及其派生类向开发者提供在运行期可以调用的各种资源和能力。UIAbility组件和各种ExtensionAbility组件的派生类都有各自不同的Context类,他们都继承自基类Context,但是各自又根据所属组件,提供不同的能力。

  • ArkUI页面

    ArkUI页面是基于ArkUI框架构建的用户界面组件,可以将不同UI组件组合在一起,实现复杂的页面效果。UIAbility组件可以通过ArkUI页面展示其功能,同时也可以通过ArkUI页面与用户进行交互。

  • Application

    Application是应用在设备上的运行实例,作为一个完整的软件实体与用户交互。在Stage模型中,它由一个或多个HAP作为功能模块构成,这些HAP可以共享一个或多个HSP中的代码与资源。

  • Bundle

    Bundle是应用在安装部署阶段的静态文件,包含了所有HAP、HSP及相关资源;当其被安装并启动后,便形成了在运行期的动态实例Application。

构成要素

应用模型章节中介绍了应用模型的构成要素,主要包含应用组件、配置文件、进程模型、线程模型和任务管理模型。下面我们以Demo.app这个应用为例,从应用的开发阶段和运行阶段分别展开介绍,帮助开发者更好地理解Stage模型的构成要素。

该Demo应用主要实现了如下功能:

  • 实现了两个独立的带界面的窗口(UIAbilityA、UIAbilityB),可以与用户交互。
  • 实现了卡片功能,便于用户将应用的卡片添加到桌面上。

图2 Stage模型构成要素

开发阶段 :需要通过Stage模型提供的应用组件(UIAbility组件和ExtensionAbility组件)开发应用功能,并在应用的配置文件(app.json5和module.json5)中注册应用的相关信息。

  • 应用组件:本例中使用UIAbility组件开发带界面的与用户交互的模块,使用FormExtensionAbility组件开发卡片模块,实现卡片的添加、删除、更新功能。为了减少不同功能模块间的依赖和耦合,将UIAbility和FormExtensionAbility的实现分别放在不同的HAP包中,同时,将两者共同依赖的一些通用功能放在HSP包中。
  • 配置文件:开发者可以在app.json5中配置应用的应用名、版本号、应用图标等,在module.json5中配置该HAP包下的组件清单、组件权限等信息。这些配置信息会在应用安装时注册到系统,便于系统和其他模块获取这个应用的详细信息,与应用进行交互。

运行阶段:当应用安装到设备运行时,系统通过一套应用进程和线程的管理机制,确保功能的有序运行。

  • 进程模型:在本例中,UIAbility组件默认运行在主进程中,FormExtensionAbility组件运行在独立进程中,UIAbility和FormExtensionAbility组件之间是进程隔离的。更多详情可参考进程模型
  • 线程模型:Stage模型提供了worker、taskpool等机制支撑应用多线程开发场景。应用如果有复杂的耗时逻辑需要处理,可以通过创建worker的方式开启worker线程,交由worker线程处理。

开发流程

基于Stage模型开发应用时,在应用模型部分,涉及如下开发过程。

表1 Stage模型开发流程

任务简介相关指导
应用组件开发本章节介绍了如何使用Stage模型的UIAbility组件和ExtensionAbility组件开发应用。- 应用/组件级配置 - UIAbility组件 - ExtensionAbility组件 - AbilityStage组件管理器 - 应用上下文Context - 组件启动规则
了解进程模型本章节介绍了Stage模型的进程模型,包括基本进程类型、其他进程类型。进程模型概述
了解线程模型本章节介绍了Stage模型的线程模型,包括线程类型以及使用EventHub进行线程内通信的方法。线程模型概述
应用配置文件本章节介绍Stage模型中应用配置文件的开发要求。Stage模型应用配置文件