赞
踩
HAR(Harmony Archive)是静态共享包,可以包含代码、C++库、资源和配置文件。通过HAR可以实现多个模块或多个工程共享ArkUI组件、资源等相关代码。HAR不同于HAP,不能独立安装运行在设备上。只能作为应用模块的依赖项被引用。
通过DevEco Studio创建一个HAR模块,详见创建库模块。HAR模块默认不开启混淆能力,开启混淆能力,需要把HAR模块的build-profile.json5文件中的artifactType字段设置为obfuscation,配置如下所示:
- {
- "apiType": "stageMode",
- "buildOption": {
- "artifactType": "obfuscation"
- }
- }
在Api11长这样:
- {
- "apiType": "stageMode",
- "buildOption": {
- },
- "buildOptionSet": [
- {
- "name": "release",
- "arkOptions": {
- "obfuscation": {
- "ruleOptions": {
- "enable": true,
- "files": [
- "./obfuscation-rules.txt"
- ]
- }
- }
- }
- },
- ],
- "targets": [
- {
- "name": "default"
- },
- {
- "name": "ohosTest",
- }
- ]
- }
artifactType字段有以下两种取值,默认缺省为original。
需要对代码资产进行保护时,建议开启混淆能力,混淆能力开启后,DevEco Studio在构建HAR时,会对代码进行编译、混淆及压缩处理,保护代码资产。
注意:artifactType字段设置为obfuscation时,apiType字段必须设置为stageMode,因为Stage模型才支持混淆。
Index.ets文件是HAR导出声明文件的入口,HAR需要导出的接口,统一在Index.ets文件中导出。Index.ets文件是DevEco Studio默认自动生成的,用户也可以自定义,在模块的oh-package.json5文件中的main字段配置入口声明文件,配置如下所示:
- {
- "main": "Index.ets"
- }
ArkUI组件的导出方式与ts的导出方式一致,通过export导出ArkUI组件,示例如下:
- // library/src/main/ets/components/MainPage/MainPage.ets
- @Component
- export struct MainPage {
- @State message: string = 'Hello World'
- build() {
- Row() {
- Column() {
- Text(this.message)
- .fontSize(50)
- .fontWeight(FontWeight.Bold)
- }
- .width('100%')
- }
- .height('100%')
- }
- }
HAR对外暴露的接口,在Index.ets导出文件中声明如下所示:
- // library/Index.ets
- export { MainPage } from './src/main/ets/components/MainPage/MainPage'
通过export导出ts类和方法,支持导出多个ts类和方法,示例如下所示:
- // library/src/main/ts/test.ets
- export class Log {
- static info(msg: string) {
- console.info(msg);
- }
- }
-
- export function func() {
- return "har func";
- }
-
- export function func2() {
- return "har func2";
- }
HAR对外暴露的接口,在Index.ets导出文件中声明如下所示:
- // library/Index.ets
- export { Log } from './src/main/ts/test'
- export { func } from './src/main/ts/test'
- export { func2 } from './src/main/ts/test'
在HAR中也可以包含C++编写的so。对于so中的native方法,HAR通过以下方式导出,以导出libnative.so的加法接口add为例:
- // library/src/main/ets/utils/nativeTest.ts
- import native from "libnative.so"
-
- export function nativeAdd(a: number, b: number) {
- let result: number = native.add(a, b);
- return result;
- }
HAR对外暴露的接口,在Index.ets导出文件中声明如下所示:
- // library/Index.ets
- export { nativeAdd } from './src/main/ets/utils/nativeTest'
HAR模块编译打包时会把资源打包到HAR中。在编译构建HAP时,DevEco Studio会从HAP模块及依赖的模块中收集资源文件,如果不同模块下的资源文件出现重名冲突时,DevEco Studio会按照以下优先级进行覆盖(优先级由高到低):
引用HAR前,需要先配置对HAR的依赖,配置方式可参考引用HAR文件和资源。
HAR的依赖配置成功后,可以引用HAR的ArkUI组件。ArkUI组件的导入方式与ts的导入方式一致,通过import引入HAR导出的ArkUI组件,示例如下所示:
- // entry/src/main/ets/pages/Index.ets
- import { MainPage } from "library"
-
- @Entry
- @Component
- struct Index {
- @State message: string = 'Hello World'
- build() {
- Row() {
- // 引用HAR的ArkUI组件
- MainPage()
- Column() {
- Text(this.message)
- .fontSize(50)
- .fontWeight(FontWeight.Bold)
- }
- .width('100%')
- }
- .height('100%')
- }
- }
通过import引入HAR导出的ts类和方法,示例如下所示:
- // entry/src/main/ets/pages/Index.ets
- import { Log } from "library"
- import { func } from "library"
-
- @Entry
- @Component
- struct Index {
- build() {
- Row() {
- Column() {
- Button('Button')
- .onClick(()=>{
- // 引用HAR的类和方法
- Log.info("har msg");
- func();
- })
- }
- .width('100%')
- }
- .height('100%')
- }
- }
通过import引用HAR导出的native方法,示例如下所示:
- // entry/src/main/ets/pages/Index.ets
- import { nativeAdd } from "library"
-
- @Entry
- @Component
- struct Index {
- @State message: string = 'Hello World'
- build() {
- Row() {
- Column() {
- Text(this.message)
- .fontSize(50)
- .fontWeight(FontWeight.Bold)
- Button('nativeAdd(1, 2)')
- .onClick(()=> {
- this.message = "result: " + nativeAdd(1, 2);
- })
- }
- .width('100%')
- }
- .height('100%')
- }
- }
通过$r引用HAR中的资源,例如在HAR模块的src/main/resources里添加字符串资源(在string.json中定义,name:hello_har)和图片资源(icon_har.png),然后在Entry模块中引用该字符串和图片资源的示例如下所示:
- // entry/src/main/ets/pages/Index.ets
- @Entry
- @Component
- struct Index {
- build() {
- Row() {
- Column() {
- // 引用HAR的字符串资源
- Text($r("app.string.hello_har"))
- .fontSize(50)
- .fontWeight(FontWeight.Bold)
- // 引用HAR的图片资源
- Image($r("app.media.icon_har"))
- }
- .width('100%')
- }
- .height('100%')
- }
- }
参考:文档中心
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。