鸿蒙开发笔记-13-AbilityStage组件容器

以下内容均基于HarmonyOS NEXT版本

  • HarmonyOS Stage模型采用分层设计思想,形成Application Framework -> AbilityStage -> UIAbility -> Component 的四层架构体系。其中:
    • AbilityStage:管理HAP模块的生命周期和资源分配
    • UIAbility:负责界面交互,支持跨设备数据迁移和远程调用
    • Component:提供基础UI组件能力
  • AbilityStage是一个Module级别的组件容器,应用的HAP在首次加载时会创建一个AbilityStage实例,可以对该Module进行初始化等操作。
  • AbilityStage与Module一一对应,即一个Module拥有一个AbilityStage。

AbilityStage开发流程

  • DevEco Studio默认工程中未自动生成AbilityStage,如需要使用AbilityStage的能力,可以手动新建一个AbilityStage文件:
  1. 在工程Module对应的ets目录下,右键选择"New > Directory",新建一个目录并命名为myabilitystage。
  2. 在myabilitystage目录,右键选择"New > ArkTS File",新建一个文件并命名为MyAbilityStage.ts。
  3. 打开MyAbilityStage.ts文件,导入AbilityStage的依赖包,自定义类继承AbilityStage并加上需要的生命周期回调,示例中增加了一个onCreate()生命周期回调。
typescript 复制代码
// MyAbilityStage.ets
import { AbilityStage, Want } from '@kit.AbilityKit';

export default class MyAbilityStage extends AbilityStage {
  private static readonly TAG: string = 'MyAbilityStage';

  // 模块首次加载时触发
  onCreate(): void {
    console.log(`${MyAbilityStage.TAG} onCreate`);
    // 初始化模块级资源
    this.initModuleResources();
  }

  // 指定模式下的Ability启动拦截
  onAcceptWant(want: Want): string {
    console.log(`${MyAbilityStage.TAG} onAcceptWant ${JSON.stringify(want)}`);
    return 'MyAbilityStage';
  }
  
   onConfigurationUpdated(config: Configuration) {
    log.info("系统配置变更:", JSON.stringify(config));
    this.adjustUILocale(config.locale);
  }
  
  onMemoryLevel(level: number) {
    if (level < this.memoryLevel) {
      this.releaseCache();
    }
    this.memoryLevel = level;
    switch(level) {
      case 0: // NORMAL
        this.cacheMap.clear();
        break;
      case 2: // COMPLETE
        this.cacheMap.clear();
        break;
    }
  }
  
   // 模块销毁前清理
  onDestroy(): void {
    this.releaseResources();
  }

  private initModuleResources(): void {
    // 预加载公共资源
    // 初始化全局对象
    // 创建后台线程
  }
}
  1. 在module.json5配置文件中,通过配置 srcEntry 参数来指定模块对应的代码路径,以作为HAP加载的入口。
json 复制代码
// module.json5
{
  "module": {
    "name": "entry",
    "type": "entry",
    "srcEntry": "./ets/myabilitystage/MyAbilityStage.ets",
    "abilities": [
      {
        "name": "MainAbility",
        "srcEntry": "./ets/mainability/MainAbility.ets",
        "launchType": "standard"
      }
    ]
  }
}
AbilityStage生命周期
  1. onCreate():在开始加载对应Module的第一个UIAbility实例之前会先创建AbilityStage,并在AbilityStage创建完成之后执行其onCreate()生命周期回调;
  2. onAcceptWant():UIAbility指定实例模式(specified)启动时候触发的事件回调;
  3. onConfigurationUpdated():当系统全局配置发生变更时触发的事件;
  4. onMemoryLevel():当系统调整内存时触发的事件;
  5. onDestroy(): 模块销毁前回收资源;

我是今阳,如果想要进阶和了解更多的干货,欢迎关注微信公众号 "今阳说" 接收我的最新文章

相关推荐
maki0774 小时前
VR大空间资料 01 —— 常用VR框架对比
android·ue5·游戏引擎·vr·虚幻·pico
xhBruce8 小时前
InputReader与InputDispatcher关系 - android-15.0.0_r23
android·ims
领创工作室8 小时前
安卓设备分区作用详解-测试机红米K40
android·java·linux
hello_ludy8 小时前
Android 中的 mk 和 bp 文件编译说明
android·编译
maki07711 小时前
VR大空间资料 03 —— VRGK使用体验和源码分析
android·vr·虚幻·源码分析·oculus·htc vive·vrgk
yenggd12 小时前
sr mpls te隧道配置案例
网络·华为
爱笑的眼睛1112 小时前
深入解析HarmonyOS应用开发:ArkTS语法精要与UI组件实践
华为·harmonyos
爱笑的眼睛1112 小时前
深入浅出 ArkTS:构建响应式 HarmonyOS 应用的现代语法与实践
华为·harmonyos
white-persist13 小时前
【burp手机真机抓包】Burp Suite 在真机(Android and IOS)抓包手机APP + 微信小程序详细教程
android·前端·ios·智能手机·微信小程序·小程序·原型模式
安卓AndroidQ13 小时前
Android Studio 代码混淆核心解释
android·ide·android studio