国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

OpenHarmony 源碼解析之JavaScriptAPI-NAPI 實踐

開發 前端
本文以最簡單的NAPI接口函數為例,詳細說明在OpenHarmony系統如何編寫模塊文件、本地調試、系統集成、上機測試。

[[439364]]

想了解更多內容,請訪問:

51CTO和華為官方合作共建的鴻蒙技術社區

https://harmonyos.51cto.com

1、簡介

開源鴻蒙(OpenHarmony)的APP開發框架是ACE,開發語言是JS/eTS。有時候需要增加一些額外功能,依賴現有的C/C++ 開源庫,或者遇到一些CPU密集計算的場合,就需要使用C/C++ 語言來編寫更底層的函數,供上層JS調用。

OpenHarmony提供了統一的NAPI接口函數,通過編譯系統的裁剪,方便增加新的JS功能模塊。

本文以最簡單的NAPI接口函數為例,詳細說明在OpenHarmony系統如何編寫模塊文件、本地調試、系統集成、上機測試。

1.1 UI架構相關系列

  • 《OpenHarmony 源碼解析之ACE (JavaScript運行環境初始化)》
  • 《OpenHarmony 源碼解析之JavaScript API框架(NAPI)》
  • 《OpenHarmony 源碼解析之JavaScript API框架(NAPI-C接口)》
  • 《OpenHarmony 源碼解析之JavaScript API框架(NAPI實踐)》
  • 《OpenHarmony 源碼解析之JavaScript(文件管理API)》

1.2 OpenHarmony架構圖

#星光計劃2.0# OpenHarmony 源碼解析之JavaScriptAPI-NAPI實踐-鴻蒙HarmonyOS技術社區

1.3 JS UI架構

JS UI框架包括應用層(Application)、前端框架層(Framework)、引擎層(Engine)和平臺適配層(Porting Layer),其架構如下圖所示:

#星光計劃2.0# OpenHarmony 源碼解析之JavaScriptAPI-NAPI實踐-鴻蒙HarmonyOS技術社區

2、快速實現

建立模塊目錄,編寫基礎編譯文件

模塊目錄理論上可以建立在OpenHarmony代碼庫的任何地方,為行文方便,假設OpenHarmony代碼庫的目錄為OHOS_SRC,在OHOS_SRC目錄下,建立此次測試模塊目錄:myapp。

此時,OHOS_SRC目錄下應該有 ark, foundation, device, …, myapp 等目錄,其中myapp就是剛剛建立的,在myapp目錄下,建立以下文件:

  1. |-- BUILD.gn 
  2. |-- app.cpp 
  3. |-- ohos.build 

BUILD.gn:

  1. import("//build/ohos.gni"
  2.    ohos_shared_library("myapp") { 
  3.      # 指定編譯源文件 
  4.      sources = [ 
  5.        "app.cpp"
  6.      ] 
  7.      # 指定編譯依賴,如果依賴第三方庫,需要在此添加 
  8.      deps = [ "//foundation/ace/napi:ace_napi" ] 
  9.      # 指定庫生成的路徑 
  10.      relative_install_dir = "module" 
  11.      # 子系統及其組件,后面會引用 
  12.      subsystem_name = "myapp" 
  13.      part_name = "myapp_part" 
  14.    }    

 最終會生成system/lib/module/libmyapp.z.so,并且在APP中:import myapp from '@ohos.myapp'

這幾處的myapp都是統一名稱:

  1. “module_list”: [ “//myapp:myapp” ] 

//myapp指的是myapp目錄,:myapp指的是上面BUILD.gn中的目標ohos_shared_library("myapp")

ohos.build:

  1.   "subsystem""myapp"
  2.   "parts": { 
  3.     "myapp_part": { 
  4.       "module_list": [ 
  5.         "//myapp:myapp" 
  6.       ], 
  7.       "test_list": [ ] 
  8.     } 
  9.   } 

app.cpp:

  1. #include <assert.h> 
  2.  
  3. #include "napi/native_api.h" 
  4. #include "napi/native_node_api.h" 
  5.  
  6. static napi_value Method(napi_env env, napi_callback_info info) { 
  7.   napi_status status; 
  8.   napi_value world; 
  9.   status = napi_create_string_utf8(env, "Hello, world!", 13, &world); 
  10.   assert(status == napi_ok); 
  11.   return world; 
  12.  
  13. static napi_value Init(napi_env env, napi_value exports) { 
  14.   napi_status status; 
  15.     napi_property_descriptor desc[] = { 
  16.         DECLARE_NAPI_FUNCTION("hello", Method), 
  17.     }; 
  18.   status = napi_define_properties(env, exports, sizeof(desc) / sizeof(desc[0]), desc); 
  19.   assert(status == napi_ok); 
  20.   return exports; 
  21.  
  22. NAPI_MODULE(myapp, Init) 

這里只簡單寫了一個JS模塊,只有一個hello函數,返回"Hello, world!"字符串。

3、本地測試

利用 node-gyp進行本地測試,先確保系統安裝了node.js。

  1. node --version 

在myapp目錄下,建立test目錄,然后編寫binding.gyp和test.js文件:

  1. |-- BUILD.gn 
  2. |-- app.cpp 
  3. |-- ohos.build 
  4. `-- test 
  5.     |-- binding.gyp 
  6.     `-- test.js 

binding.gyp:

按自己系統的實際情況,填寫編譯器、源代碼(sources)、頭文件目錄(include_dirs)、依賴庫(dependencies)、編譯參數(cflags、cflags_cc)、鏈接參數(link_settings: libraries)。

這里的目標名稱(target_name)就是下一步test.js引用測試的名稱。

  1.   'targets': [ 
  2.     { 
  3.       'cc''clang'
  4.       'c++''clang++'
  5.       'target_name''test-native'
  6.       'sources': [ '../app.cpp'], 
  7.       'include_dirs': ["/OHOS_SRC/foundation/ace/napi/interfaces/kits"], 
  8.       'dependencies': [], 
  9.       'cflags!': [ '-DTESTDEBUG''-std=gnu2x' ], 
  10.       'cflags_cc': [ '-DTESTDEBUG''-std=c++17' ], 
  11.       'link_settings': { 
  12.           'libraries': [''
  13.       }, 
  14.     } 
  15.   ] 

接下來,確保系統安裝了node-gyp

  1. node-gyp --version 

如果系統沒有安裝,那么在測試目錄下臨時安裝也是可以的。

  1. cd OHOS_SRC/myapp/test 
  2. npm install node-gyp 
  3. ./node_modules/.bin/node-gyp --version 

運行如下命令,確保app.cpp文件無語法錯誤,可以正確通過編譯鏈接。

  1. cd OHOS_SRC/myapp/test 
  2. node-gyp configure 
  3. node-gyp build 

 之后如果修改了binding.gyp文件,需要node-gyp rebuild,

test.js:

  1. var myapp = require('./build/Release/test-native'
  2. console.log(myapp) 
  3. console.log(myapp.hello) 
  4. console.log(myapp.hello()) 

 如果編譯正常,那么就可以進行本地測試了:

  1. node test.js 

4、集成

集成到系統,在本地測試通過后,各種功能看起來正常,那么就可以集成到OpenHarmony系統,燒錄上機測試了。

集成到OpenHarmony的步驟參考鴻蒙子系統的集成步驟:標準系統編譯構建指導

這里簡單描述一下:

在OHOS_SRC/build/subsystem_config.json文件中,增加(注意前后逗號,保持文件格式正確):

  1. "myapp": { 
  2.     "project""hmf/myapp"
  3.     "path""myapp"
  4.     "name""myapp"
  5.     "dir""" 

 在產品配置中添加上述子系統的功能模塊,編譯到產品產出文件中(注意前后逗號,保持文件格式正確)

  1. OHOS_SRC/productdefine/common/products/產品名稱.json 
  1. “myapp:myapp_part”:{} 

即可開始編譯。

  1. ./build.sh --product-name 產品名稱 

編譯完成后,可以在OHOS_SRC/out目錄找到生成的.so文件。

  1. root@1fe862aba551:/home/openharmony# find out -name 'libmyapp*' 
  2. out/ohos-arm-release/packages/phone/NOTICE_FILES/system/lib/module/libmyapp.z.so.txt 
  3. out/ohos-arm-release/packages/phone/system/lib/module/libmyapp.z.so 
  4. out/ohos-arm-release/lib.unstripped/myapp/myapp_part/libmyapp.z.so 
  5. out/ohos-arm-release/myapp/myapp_part/libmyapp.z.so 

 鏡像輸出在 out/ohos-arm-release/packages/phone/images/ 目錄下。

5、上機測試及小技巧

第一次編寫完成后,需要燒錄鏡像文件。之后再修改,就可以利用hdc工具,只上傳.so文件覆蓋原文件即可。

  1. hdc.exe file send libmyapp.z.so system/lib/module/libmyapp.z.so 

編寫測試HAP:

  1. import myapp from '@ohos.myapp' 
  2. export default { 
  3.   testGetAppName() { 
  4.     console.log(myapp.hello()) 
  5.   } 

假設測試APP的包是com.example.testmyapp,可以使用hdc工具很方便進行的安裝、啟動、關閉APP等操作。

安裝:

  1. hdc install -r 安裝包的本地路徑.hap 

卸載:

  1. hdc uninstall com.example.testmyapp 

列出已經安裝的包:

  1. hdc shell bm dump -a 

啟動:

  1. hdc shell aa start -b com.example.testmyapp -a com.example.testmyapp.MainAbility 

關閉:

  1. hdc shell killall com.example.testmyapp 

hdc工具查看日志,可以根據進程號只看測試進程的,這樣就更清晰方便了。:

  1. hdc.exe shell 
  2. ps -elf |grep com.example.testmyapp # 輸出的第二列是pid 
  3. hilog -P pid #這里的pid是上面第二列的數字 

6、小結

OpenHarmony系統的ACE框架已經具備了基礎的APP功能,可以很方便的利用NAPI擴展來增強APP,補充JS的不足之處。

想了解更多內容,請訪問:

51CTO和華為官方合作共建的鴻蒙技術社區

https://harmonyos.51cto.com

 

責任編輯:jianghua 來源: 鴻蒙社區
相關推薦

2021-12-06 06:19:03

鴻蒙HarmonyOS應用

2021-09-16 15:08:08

鴻蒙HarmonyOS應用

2022-07-19 20:04:31

NAPI模塊鴻蒙

2022-02-14 14:47:11

SystemUIOpenHarmon鴻蒙

2022-10-11 15:04:28

NAPI開發鴻蒙

2022-05-17 10:42:36

reboot源碼解析

2022-07-05 16:03:29

電源管理子系統鴻蒙

2021-09-18 14:40:37

鴻蒙HarmonyOS應用

2021-11-08 15:04:47

鴻蒙HarmonyOS應用

2022-02-17 20:57:07

OpenHarmon操作系統鴻蒙

2021-11-25 09:54:54

鴻蒙HarmonyOS應用

2022-01-06 16:17:58

鴻蒙HarmonyOS應用

2021-12-17 16:42:09

鴻蒙HarmonyOS應用

2022-06-13 14:18:39

電源管理子系統耗電量服務

2022-05-20 10:32:49

事件循環器事件隊列鴻蒙

2024-01-03 15:41:49

2021-08-30 18:09:57

鴻蒙HarmonyOS應用

2022-01-10 15:30:11

鴻蒙HarmonyOS應用

2023-04-12 15:31:11

系統服務管理鴻蒙

2022-01-20 14:33:29

openharmonwayland協議鴻蒙
點贊
收藏

51CTO技術棧公眾號

91碰在线视频| 国产成人精品一区二区三区网站观看| 亚洲韩国欧洲国产日产av| 亚洲精品一区二区| 国产成人免费视频一区| 伊人久久大香线蕉成人综合网| 制服诱惑一区二区| 99在线视频播放| 色天天久久综合婷婷女18| 欧美一区二区三区…… | 成人免费看的视频| 亚洲图片欧洲图片日韩av| 日韩国产一区二| 一区不卡视频| 精品一区二区免费在线观看| 热这里只有精品| 成人丝袜高跟foot| 99999精品视频| 国产精品嫩草影院com| 羞羞在线视频| 亚洲午夜影视影院在线观看| 伊人春色在线| 欧美特级限制片免费在线观看| 在线观看麻豆| 日韩午夜小视频| 亚洲最大网站| 久久福利视频网| 亚洲三级网址| 亚洲最大av在线| 石原莉奈在线亚洲二区| 亚洲午夜激情| 91在线观看视频| 男人艹女人网站| 日韩欧美亚洲成人| 午夜成年人在线免费视频| 国产午夜精品一区理论片飘花| 青草伊人久久| 成人免费xxxxx在线观看| 先锋影音久久久| 你懂的av在线| 久久久久久久久久看片| 淫视频在线观看| 日韩欧美成人激情| 国产午夜久久av| 国产成人综合一区二区三区| 伊人成人在线| 日韩欧美国产免费| 五月天激情综合| 激情国产在线| 欧美在线视频一区二区| 久久高清国产| 色婷婷狠狠18| 欧美中文字幕一区二区三区亚洲 | 黄色一级视频片| 亚洲精选视频在线| 97caopron在线视频| www高清在线视频日韩欧美| 久草在线成人| 亚洲区一区二区三区| 国产精品情趣视频| 二区在线播放| 91精品国产91久久久久久最新| 亚洲看片一区| 欧美伦理视频在线观看| 欧洲精品一区二区| 美女国产精品久久久| 国产三区精品| 日本一区二区三级电影在线观看 | 午夜精品亚洲一区二区三区嫩草| 久久你懂得1024| 成人午夜在线观看视频| 久久精品亚洲国产| 很黄很黄激情成人| 国产免费视频传媒| 精品日韩欧美在线| 日本久久综合| 国产xxxxx在线观看| 日韩一级视频免费观看在线| 日本亚洲不卡| av影院在线播放| 欧美四级电影在线观看| 成人激情自拍| 一级黄色免费在线观看| 日韩欧美国产网站| 亚洲精品在线a| 香蕉久久免费影视| 日韩欧美在线观看| 麻豆精品少妇| 日韩中文字幕在线免费| 91精品国产福利| 亚洲一本二本| 2018高清国产日本一道国产| 中文字幕亚洲情99在线| 视频一区欧美精品| 国产女人在线观看| 欧美自拍大量在线观看| 成人免费高清在线观看| 欧美1—12sexvideos| 91一区二区三区| 亚洲午夜在线观看视频在线| 一本色道69色精品综合久久| 蜜臀av.com| 91高清视频在线| 成人在线丰满少妇av| 日韩中文字幕a| 久久亚洲私人国产精品va| 国产精品资源站在线| a毛片在线看免费观看| 99re在线视频观看| 亚洲成a人片在线观看中文| 2020国产精品极品色在线观看| av网站大全免费| 亚洲新中文字幕| 国产乱码字幕精品高清av| 91福利区在线观看| 午夜免费电影一区在线观看| 欧美一区二区在线看| 99精品欧美| 永久av在线| 蜜桃91精品入口| 欧美一区二区三区视频在线| 性xx色xx综合久久久xx| 精品美女在线观看视频在线观看| 91久久精品国产91久久性色tv| 亚洲444eee在线观看| 日韩av久操| 日韩欧美亚洲系列| 日韩精品一区二区三区swag | 午夜在线网站| 日本不卡免费高清视频| 中文字幕精品一区二区三区精品| 日韩精品成人| 国产精品igao| 欧洲成人性视频| 偷窥国产亚洲免费视频| 欧美精品18| 成人黄视频在线观看| 亚洲v国产v在线观看| 精品久久一区二区| 精品一区二区三区久久| 自拍偷自拍亚洲精品被多人伦好爽 | 久久99精品久久久久久青青日本| 在线观看av一区二区| 亚洲一区二区伦理| 超黄网站在线观看| 日本免费a视频| 欧美黄色www| 亚洲一级在线观看| 欧美99久久| 福利写真视频网站在线| 日韩一级性生活片| 4k岛国日韩精品**专区| 91精品福利视频| 毛片一区二区三区| 日韩欧美激情| 午夜影院在线| 美女被啪啪一区二区| 中文字幕无线精品亚洲乱码一区 | 亚洲成国产人片在线观看| 欧美限制电影| 免费**毛片在线| 国产成年人在线观看| 久久99久久99精品免观看粉嫩| 一区二区欧美在线观看| 亚洲综合日韩| 日韩美香港a一级毛片| 影音先锋导航| 亚洲最大色综合成人av| 欧美夫妻性生活视频| 欧美性大战久久久| 成人小视频免费观看| 国产精品嫩模av在线| 国产偷倩在线播放| 超碰在线97免费| 激情欧美一区二区三区中文字幕| 亚洲日本成人女熟在线观看| 国产精品国产a级| 国产精品亚洲产品| 神马影院一区二区| 天天噜天天色| 青青草在线免费观看| av电影在线播放高清免费观看| 91热门视频在线观看| 国产乱论精品| 自拍视频在线| 日韩av高清在线看片| 国产精品va在线| 亚洲第一综合天堂另类专| 国产精品毛片高清在线完整版| 亚洲影院一区| 久久电影在线| 国产羞羞视频在线播放| 麻豆免费网站| 国产午夜精品视频一区二区三区| 国产精品偷伦免费视频观看的| 亚洲欧洲在线免费| 在线免费观看一区| 中文字幕国产一区二区| 天堂影院一区二区| 日韩在线精品|