HAR

2024-01-25 11:55 更新

HAR(Harmony Archive)是靜態(tài)共享包,可以包含代碼、C++庫、資源和配置文件。通過HAR可以實現(xiàn)多個模塊或多個工程共享ArkUI組件、資源等相關代碼。HAR不同于HAP,不能獨立安裝運行在設備上,只能作為應用模塊的依賴項被引用。

創(chuàng)建HAR模塊

通過DevEco Studio創(chuàng)建一個HAR模塊,詳見創(chuàng)建庫模塊。HAR模塊默認不開啟混淆能力,開啟混淆能力,需要把HAR模塊的build-profile.json5文件中的artifactType字段設置為obfuscation,配置如下所示:

  1. {
  2. "apiType": "stageMode",
  3. "buildOption": {
  4. "artifactType": "obfuscation"
  5. }
  6. }

artifactType字段有以下兩種取值,默認缺省為original。

  • original:不混淆。
  • obfuscation:混淆。

需要對代碼資產(chǎn)進行保護時,建議開啟混淆能力,混淆能力開啟后,DevEco Studio在構建HAR時,會對代碼進行編譯、混淆及壓縮處理,保護代碼資產(chǎn)。

注意:artifactType字段設置為obfuscation時,apiType字段必須設置為stageMode,因為Stage模型才支持混淆。

HAR開發(fā)注意事項

  • HAR不支持在配置文件中聲明abilities、extensionAbilities組件。
  • HAR不支持在配置文件中聲明pages頁面。
  • HAR不支持在build-profile.json5文件的buildOption中配置worker。
  • FA模型與Stage模型的HAR不支持相互引用。
  • Stage模型的HAR,不能引用AppScope內(nèi)的內(nèi)容。在編譯構建時AppScope中的內(nèi)容不會打包到HAR中,導致HAR資源引用失敗。

導出HAR的ArkUI組件、接口、資源

Index.ets文件是HAR導出聲明文件的入口,HAR需要導出的接口,統(tǒng)一在Index.ets文件中導出。Index.ets文件是DevEco Studio默認自動生成的,用戶也可以自定義,在模塊的oh-package.json5文件中的main字段配置入口聲明文件,配置如下所示:

  1. {
  2. "main": "Index.ets"
  3. }

導出ArkUI組件

ArkUI組件的導出方式與ts的導出方式一致,通過export導出ArkUI組件,示例如下:

  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類和方法

通過export導出ts類和方法,支持導出多個ts類和方法,示例如下所示:

  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模塊及依賴的模塊中收集資源文件,如果不同模塊下的資源文件出現(xiàn)重名沖突時,DevEco Studio會按照以下優(yōu)先級進行覆蓋(優(yōu)先級由高到低):

  • AppScope(僅API9的Stage模型支持)。
  • HAP包自身模塊。
  • 依賴的HAR模塊,如果依賴的多個HAR之間有資源沖突,會按照依賴順序進行覆蓋(依賴順序在前的優(yōu)先級較高)。

引用HAR的ArkUI組件、接口、資源

引用HAR前,需要先配置對HAR的依賴,配置方式可參考引用HAR文件和資源。

引用HAR的ArkUI組件

HAR的依賴配置成功后,可以引用HAR的ArkUI組件。ArkUI組件的導入方式與ts的導入方式一致,通過import引入HAR導出的ArkUI組件,示例如下所示:

  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類和方法

通過import引用HAR導出的ts類和方法,示例如下所示:

  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方法

通過import引用HAR導出的native方法,示例如下所示:

  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的資源

通過$r引用HAR中的資源,例如在HAR模塊的src/main/resources里添加字符串資源(在string.json中定義,name:hello_har)和圖片資源(icon_har.png),然后在Entry模塊中引用該字符串和圖片資源的示例如下所示:

  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. }
以上內(nèi)容是否對您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號
微信公眾號

編程獅公眾號