HarmonyOS实战开发:HAR静态共享包

张裕  金牌会员 | 2024-12-13 14:35:49 | 显示全部楼层 | 阅读模式
打印 上一主题 下一主题

主题 506|帖子 506|积分 1518

HAR(Harmony Archive)是静态共享包,可以包含代码、C++库、资源和配置文件。通过HAR可以实现多个模块或多个工程共享ArkUI组件、资源等相干代码。HAR差别于HAP,不能独立安装运行在设备上,只能作为应用模块的依赖项被引用。
创建HAR模块

通过DevEco Studio创建一个HAR模块,创建方式可参考。
必要对代码资产进行掩护时,建议开启混淆能力。混淆能力开启后,DevEco Studio在构建HAR时,会对代码进行编译、混淆及压缩处置处罚,掩护代码资产。
   注意:仅Stage模型的ArkTS工程支持混淆。 HAR开启混淆后资源ID为-1,ResourceManager等通过ID获取资源的API不再见效。
  混淆功能在差别版本默认开启情况差别:


  • 在API 9中,HAR模块默认不开启混淆能力。若要开启混淆能力,必要把HAR模块的build-profile.json5文件中的artifactType字段设置为obfuscation,配置如下所示:
    1. {
    2.   "apiType": "stageMode",
    3.   "buildOption": {
    4.       "artifactType": "obfuscation"
    5.   }
    6. }
    复制代码
    artifactType字段有以下两种取值,默认缺省为original。

    • 原文:不混淆。
    • 混淆:混淆。

  • 在API10中,HAR模块默认开启混淆能力,可以在HAR模块的build-profile.json5文件中的ruleOptions字段下的enable进行设置,配置如下所示:
    1. {
    2.   "apiType": "stageMode",
    3.   "buildOption": {
    4.   },
    5.   "buildOptionSet": [
    6.     {
    7.       "name": "release",
    8.       "arkOptions": {
    9.         "obfuscation": {
    10.           "ruleOptions": {
    11.             "enable": true,
    12.             "files": [
    13.               "./obfuscation-rules.txt"
    14.             ]
    15.           },
    16.           "consumerFiles": [
    17.             "./consumer-rules.txt"
    18.           ]
    19.         }
    20.       }
    21.     },
    22.   ],
    23.   "targets": [
    24.     {
    25.       "name": "default"
    26.     }
    27.   ]
    28. }
    复制代码
    适配指导
该字段配置前向兼容,原有功能暂时不受影响。API10后续将渐渐废弃,建议尽快使用新的配置方式。
HAR开发注意事项



  • HAR不支持在配置文件中声明abilities、extensionAbilities组件。
  • HAR不支持在配置文件中声明页面。
  • HAR不支持在build-profile.json5文件的buildOption中配置worker。
  • FA模型与Stage模型的HAR不支持相互引用。
  • Stage模型的HAR,不能引用AppScope内的内容。在编译构建时AppScope中的内容不会打包到HAR中,导致HAR资源引用失败。
导出HAR的ArkUI组件、接口、资源

Index.ets文件是HAR导作声明文件的入口,HAR必要导出的接口,同一在Index.ets文件中导出。Index.ets文件是DevEco Studio默认主动生成的,用户也可以自定义,在模块的oh-package.json5文件中的main字段配置入口声明文件,配置如下所示:
  1. {
  2.   "main": "Index.ets"
  3. }
复制代码
导出ArkUI组件

ArkUI组件的导出方式与ts的导出方式一致,通过导出ArkUI组件,示例如下:export
  1. // library/src/main/ets/components/MainPage/MainPage.ets
  2. @Component
  3. export struct MainPage {
  4.   @State message: string = 'Hello World'
  5.   build() {
  6.     Row() {
  7.       Column() {
  8.         Text(this.message)
  9.           .fontSize(50)
  10.           .fontWeight(FontWeight.Bold)
  11.       }
  12.       .width('100%')
  13.     }
  14.     .height('100%')
  15.   }
  16. }
复制代码
HAR对外暴露的接口,在Index.ets导出文件中声明如下所示:
  1. // library/Index.ets
  2. export { MainPage } from './src/main/ets/components/MainPage/MainPage'
复制代码
导出ts类和方法

通过导出ts类和方法,支持导出多个ts类和方法,示例如下所示:export
  1. // library/src/main/ts/test.ets
  2. export class Log {
  3.     static info(msg: string) {
  4.         console.info(msg);
  5.     }
  6. }
  7. export function func() {
  8.   return "har func";
  9. }
  10. export function func2() {
  11.   return "har func2";
  12. }
复制代码
HAR对外暴露的接口,在Index.ets导出文件中声明如下所示:
  1. // library/Index.ets
  2. export { Log } from './src/main/ts/test'
  3. export { func } from './src/main/ts/test'
  4. export { func2 } from './src/main/ts/test'
复制代码
导出native方法

在HAR中也可以包含C++编写的so。对于so中的native方法,HAR通过以下方式导出,以导出 libnative.so 的加法接口add为例:
  1. // library/src/main/ets/utils/nativeTest.ts
  2. import native from "libnative.so"
  3. export function nativeAdd(a: number, b: number) {
  4.     let result: number = native.add(a, b);
  5.     return result;
  6. }
复制代码
HAR对外暴露的接口,在Index.ets导出文件中声明如下所示:
  1. // library/Index.ets
  2. export { nativeAdd } from './src/main/ets/utils/nativeTest'
复制代码
资源

HAR模块编译打包时会把资源打包到HAR中。在编译构建HAP时,DevEco Studio会从HAP模块及依赖的模块中收集资源文件,如果差别模块下的资源文件出现重名冲突时,DevEco Studio会按照以下优先级进行覆盖(优先级由高到低):


  • AppScope(仅API9的Stage模型支持)。
  • HAP包自身模块。
  • 依赖的HAR模块,如果依赖的多个HAR之间有资源冲突,会按照依赖序次进行覆盖(依赖序次在前的优先级较高)。
引用HAR的ArkUI组件、接口、资源

引用HAR前,必要先配置对HAR的依赖,配置方式可参考。
引用HAR的ArkUI组件

HAR的依赖配置乐成后,可以引用HAR的ArkUI组件。ArkUI组件的导入方式与ts的导入方式一致,通过引入HAR导出的ArkUI组件,示例如下所示:import
  1. // entry/src/main/ets/pages/Index.ets
  2. import { MainPage } from "library"
  3. @Entry
  4. @Component
  5. struct Index {
  6.   @State message: string = 'Hello World'
  7.   build() {
  8.     Row() {
  9.       // 引用HAR的ArkUI组件
  10.       MainPage()
  11.       Column() {
  12.         Text(this.message)
  13.           .fontSize(50)
  14.           .fontWeight(FontWeight.Bold)
  15.       }
  16.       .width('100%')
  17.     }
  18.     .height('100%')
  19.   }
  20. }
复制代码
引用HAR的ts类和方法

通过引用HAR导出的ts类和方法,示例如下所示:import
  1. // entry/src/main/ets/pages/Index.ets
  2. import { Log } from "library"
  3. import { func } from "library"
  4. @Entry
  5. @Component
  6. struct Index {
  7.   build() {
  8.     Row() {
  9.       Column() {
  10.         Button('Button')
  11.           .onClick(()=>{
  12.             // 引用HAR的类和方法
  13.             Log.info("har msg");
  14.             func();
  15.         })
  16.       }
  17.       .width('100%')
  18.     }
  19.     .height('100%')
  20.   }
  21. }
复制代码
引用HAR的native方法

通过引用HAR导出的native方法,示例如下所示:import
  1. // entry/src/main/ets/pages/Index.ets
  2. import { nativeAdd } from "library"
  3. @Entry
  4. @Component
  5. struct Index {
  6.   @State message: string = 'Hello World'
  7.   build() {
  8.     Row() {
  9.       Column() {
  10.         Text(this.message)
  11.           .fontSize(50)
  12.           .fontWeight(FontWeight.Bold)
  13.         Button('nativeAdd(1, 2)')
  14.           .onClick(()=> {
  15.             this.message = "result: " + nativeAdd(1, 2);
  16.           })
  17.       }
  18.       .width('100%')
  19.     }
  20.     .height('100%')
  21.   }
  22. }
复制代码
引用HAR的资源

通过引用HAR中的资源,例如在HAR模块的里添加字符串资源(在string.json中定义,name:hello_har)和图片资源(icon_har.png),然后在Entry模块中引用该字符串和图片资源的示例如下所示:$rsrc/main/resources
  1. // entry/src/main/ets/pages/Index.ets
  2. @Entry
  3. @Component
  4. struct Index {
  5.   build() {
  6.     Row() {
  7.       Column() {
  8.         // 引用HAR的字符串资源
  9.         Text($r("app.string.hello_har"))
  10.           .fontSize(50)
  11.           .fontWeight(FontWeight.Bold)
  12.         // 引用HAR的图片资源
  13.         Image($r("app.media.icon_har"))
  14.       }
  15.       .width('100%')
  16.     }
  17.     .height('100%')
  18.   }
  19. }
复制代码
最后

有很多小同伴不知道学习哪些鸿蒙开发技术?不知道必要重点把握哪些鸿蒙应用开发知识点?而且学习时频仍踩坑,终极浪费大量时间。所以有一份实用的鸿蒙(HarmonyOS NEXT)资料用来跟着学习是非常有须要的。 
这份鸿蒙(HarmonyOS NEXT)资料包含了鸿蒙开发必把握的焦点知识要点,内容包含了ArkTS、ArkUI开发组件、Stage模型、多端部署、分布式应用开发、音频、视频、WebGL、OpenHarmony多媒体技术、Napi组件、OpenHarmony内核、Harmony南向开发、鸿蒙项目实战等等)鸿蒙(HarmonyOS NEXT)技术知识点。
盼望这一份鸿蒙学习资料可以或许给各人带来资助,有必要的小同伴自行领取,限时开源,先到先得~无套路领取!!
获取这份完整版高清学习路线,请点击→纯血版全套鸿蒙HarmonyOS学习资料
鸿蒙(HarmonyOS NEXT)最新学习路线




  •  HarmonOS基础技能



  • HarmonOS就业必备技能 

  •  HarmonOS多媒体技术



  • 鸿蒙NaPi组件进阶



  • HarmonOS高级技能



  • 初识HarmonOS内核 

  • 实战就业级设备开发

有了路线图,怎么能没有学习资料呢,小编也预备了一份联合鸿蒙官方发布笔记整理收纳的一套系统性的鸿蒙(OpenHarmony )学习手册(共计1236页)鸿蒙(OpenHarmony )开发入门教学视频,内容包含:ArkTS、ArkUI、Web开发、应用模型、资源分类…等知识点。
获取以上完整版高清学习路线,请点击→纯血版全套鸿蒙HarmonyOS学习资料
《鸿蒙 (OpenHarmony)开发入门教学视频》


《鸿蒙生态应用开发V2.0白皮书》


《鸿蒙 (OpenHarmony)开发基础到实战手册》

OpenHarmony北向、南向开发环境搭建

 《鸿蒙开发基础》



  • ArkTS语言
  • 安装DevEco Studio
  • 运用你的第一个ArkTS应用
  • ArkUI声明式UI开发
  • .……

 《鸿蒙开发进阶》



  • Stage模型入门
  • 网络管理
  • 数据管理
  • 电话服务
  • 分布式应用开发
  • 通知与窗口管理
  • 多媒体技术
  • 安全技能
  • 任务管理
  • WebGL
  • 国际化开发
  • 应用测试
  • DFX面向未来计划
  • 鸿蒙系统移植和裁剪定制
  • ……

《鸿蒙进阶实战》



  • ArkTS实践
  • UIAbility应用
  • 网络案例
  • ……

 获取以上完整鸿蒙HarmonyOS学习资料,请点击→纯血版全套鸿蒙HarmonyOS学习资料
总结

总的来说,华为鸿蒙不再兼容安卓,对中年程序员来说是一个挑衅,也是一个时机。只有积极应对变化,不断学习和提升自己,他们才能在这个变革的期间中立于不败之地。

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

张裕

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表