0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

觸覺智能RK3568使用體驗:NAPI 類對象導出及其生命周期管理(上)

電子發(fā)燒友開源社區(qū) ? 來源:未知 ? 2023-02-17 09:10 ? 次閱讀

寫在開頭:

OpenHarmony 中的 N-API組件定義了由ArkTS (JS/ETS)語言編寫的代碼和 native 代碼(使用 C/C++ 編寫)交互的方式,由 Node.js Node-API 框架擴展而來。

什么是Node.js Node-API 框架


Node.js Node-API為開發(fā)者提供了一套C/C++ API用于開發(fā)Node.js的Native擴展模塊。從Node.js 8.0.0開始,Node-API以實驗性特性作為Node.js本身的一部分被引入,并且從Node.js 10.0.0開始正式全面支持Node-API。

本文以O(shè)penHarmony 3.2beta3源碼中的node.js三方庫為例,從third_party/node/README.OpenSource中可得知3.2beta3移植的node版本為14.19.1,因此可參考的Node.js N-API鏈接為14.19.1版本,如下:https://nodejs.org/docs/latest-v14.x/api/n-api.html

  • 接口名方面,OpenHarmony 中的 N-API 組件提供的接口名與三方庫Node.js一致,目前支持部分接口,詳情見libnapi.ndk.json文件。

本篇是該系列文章的第5篇上半部分。有離北況歸的地方就一定會有樣例源碼,本文提供了一個IDE開發(fā)的NAPI工程用來學習本篇知識點,下半部分將對源碼進行解析。通過本文您將熟悉:

  • NAPI 導出類對象

  • NAPI 對象生命周期管理

1.NAPI 類對象導出

  • OpenHarmony NAPI提供了一種“包裝”C ++類和實例的方法,以便JS應用可以調(diào)用類的構(gòu)造函數(shù)和方法。

  • Node.js Node-API中關(guān)于導出類對象的內(nèi)容,參考鏈接 : https://nodejs.org/docs/latest-v14.x/api/n-api.html#n_api_object_wrap

1.1. NAPI導出類對象流程

  • 通過napi_define_class定義一個JS類

    • 它包含了與 C++ 類對應的構(gòu)造函數(shù)、靜態(tài)屬性、方法、實例屬性和方法。

  • 通過napi_wrap將 C++ 實例綁定在 JS對象中

    • 當 JS代碼調(diào)用構(gòu)造函數(shù)時,構(gòu)造函數(shù)回調(diào)會使用napi_wrap將一個新的 C++ 實例綁定在 JS對象中,然后返回綁定的C++ 實例。

  • 通過napi_unwrap獲取作為調(diào)用目標的C++ 實例

    • 當 JS調(diào)用C++ 類 的方法或?qū)傩詴r,會調(diào)用相應的napi_callback C++ 函數(shù)。對于實例回調(diào),napi_unwrap獲取作為調(diào)用目標的 C++ 實例 。

這里的napi_callback C++ 函數(shù)是指被 Node.js Node-API調(diào)用的C++ 函數(shù)

348998de-ae5f-11ed-bfe3-dac502259ad0.png

2. NAPI 對象生命周期

34a90ed0-ae5f-11ed-bfe3-dac502259ad0.png

以下是Node-API 中關(guān)于對象生命周期的解釋:

  • 程序的生命周期是指程序從啟動,運行到結(jié)束的整個過程。

  • NAPI 對象的生命周期代表著從對象創(chuàng)建到釋放的整個過程,如下圖所示:

    • 在ArkTS應用啟動時會加載NAPI模塊,而在NAPI模塊加載過程中會創(chuàng)建一個對象A提供給應用使用,在應用退出或者主動釋放A對象前,A對象必須一直保持"活躍"狀態(tài)。從A對象創(chuàng)建到釋放的整個過程也代表著A對象的生命周期。

    • 當調(diào)用Node-API時,底層虛擬機在堆中對象的句柄可能以napi_values的形式返回。這些句柄必須保持對象“活動”,直到本地代碼不再需要它們。參考鏈接//nodejs.org/docs/latest-v14.x/api/n-api.html#n_api_object_lifetime_management

句柄是一個標識符,是用來標識對象的。

NAPI 環(huán)境生命周期API的內(nèi)容參考鏈接如下:https://nodejs.org/docs/latest-v14.x/api/n-api.html#n_api_environment_life_cycle_apis

3. 關(guān)于本文提供的樣例工程

本文提供了一個IDE開發(fā)的NAPI工程用來學習NAPI 類對象導出對象生命周期管理

  • 筆者運行環(huán)境:

    • 觸覺智能 IDO-EVB3568-V1 開發(fā)板

    • OpenHarmony 3.2Beta2

    • DevEco Studio 3.1.0.100

3.1 觸覺智能 IDO-EVB3568-V1 開發(fā)板

觸覺智能的這個rk3568開發(fā)板是筆者去年8月份網(wǎng)上沖浪購買的,4GB+32GB開發(fā)板 + 一塊10.1英寸的MIPI屏幕 + 電源適配器+usb調(diào)試器(搞開源鴻蒙用不上) 一共 739米 。筆者認為是性價比無敵的開源鴻蒙標準系統(tǒng)開發(fā)板。

34c20d4a-ae5f-11ed-bfe3-dac502259ad0.png

觸覺智能一直在給 IDO-EVB3568-V1 開發(fā)板適配最新的OpenHarmony版本。例如2月1號發(fā)布Beta5,作為消費者的筆者立馬收到了適配了IDO-EVB3568-V1的Beta5鏡像包,有MIPI版本的和HDMI版本。購買后的體驗是非常不錯的。

35053228-ae5f-11ed-bfe3-dac502259ad0.jpg
351a2afc-ae5f-11ed-bfe3-dac502259ad0.jpg

3.2. 樣例工程運行

1、樣例安裝運行后,觸覺智能 IDO-EVB3568-V1開發(fā)板顯示如下

354436a8-ae5f-11ed-bfe3-dac502259ad0.png

以下圖片通過OpenHarmony預置的屏幕截圖功能獲取。截圖文件放在下面這四個文件夾下
/data/service/el2/100/hmdfs/account/files/Pictures/Screenshots/
/storage/media/100/local/files/Pictures/Screenshots/
/mnt/hmdfs/100/account/device_view/local/files/Pictures/Screenshots/
/mnt/hmdfs/100/account/merge_view/files/Pictures/Screenshots/
然后通過hdc工具導出到PC端。

2、再點擊中間的"導出對象"后,PC端DevEco Studio工具的Log窗口查看到對應的調(diào)試信息

系統(tǒng)的調(diào)試信息也在Hilog窗口顯示,且信息量大,不方便查看自己的調(diào)試信息,可以在log窗口設(shè)置過濾信息,讓窗口只顯示我們過濾關(guān)鍵字NapiTest的信息。

356c5cfa-ae5f-11ed-bfe3-dac502259ad0.jpg

(左右移動查看全部內(nèi)容)

調(diào)試信息如下:

08-05 11:09:03.413 1802-1802/com.example.objectwraptest I A0fefe/JsApp: [NapiTest] Test NAPI 2 + 3 = 5
08-05 11:09:03.414 1802-1802/com.example.objectwraptest I A0fefe/JsApp: [NapiTest] Test NAPI add(2, 3) 1
08-05 1103.414 1802-1802/com.example.objectwraptest I A0fefe/JsApp: [NapiTest] Test NAPI add(2, 3) 2
08-05 1103.415 1802-1802/com.example.objectwraptest I A0fefe/JsApp: [NapiTest] Test NAPI add(2, 3) 3
08-05 1103.415 1802-1802/com.example.objectwraptest I A0fefe/JsApp: [NapiTest]Test NAPI 2+3 = 5
08-05 11:09:52.123 1802-1802/com.example.objectwraptest I A0fefe/JsApp: [NapiTest] Test NAPI 2 + 3 = 5
08-05 11:09:52.123 1802-1802/com.example.objectwraptest I A0fefe/JsApp: [NapiTest] Test NAPI add(0, 0) 1
08-05 1152.123 1802-1802/com.example.objectwraptest I A0fefe/JsApp: [NapiTest] Test NAPI add(0, 0) 2
08-05 1152.124 1802-1802/com.example.objectwraptest I A0fefe/JsApp: [NapiTest] Test NAPI add(0, 0) 3
08-05 1152.124 1802-1802/com.example.objectwraptest I A0fefe/JsApp: [NapiTest]Test NAPI 4+5 = 0

	

3、再在index.ets中取消下面這四行代碼的注釋。

35952a54-ae5f-11ed-bfe3-dac502259ad0.jpg

Hilog窗口打印調(diào)試信息如下:

35bc42c4-ae5f-11ed-bfe3-dac502259ad0.png

08-05 09:03:38.156 1911-1911/com.example.objectwraptest I A0fefe/JsApp: [NapiTest] Test NAPI 2 + 3 = 5
08-05 09:03:38.157 1911-1911/com.example.objectwraptest I A0fefe/JsApp: [NapiTest]Test NAPI error{}
08-05 09:03:38.157 1911-1911/com.example.objectwraptest I A0fefe/JsApp: [NapiTest]Test NAPI hello NapiTest = undefined

(左右移動查看全部內(nèi)容)

以上HiLog窗口打印信息中的com.example.objectwraptest是樣例工程的包名,在樣例應用工程AppScopeapp.json5文件中定義。AppScopeapp.json5中還可以定義樣例應用hap的其他屬性。

entrysrcmainmodule.json5中startWindowBackground字段可以查看應用開啟時過渡動畫的顏色,但是在指向的同級目錄下具體的文件中設(shè)置


35e9e10c-ae5f-11ed-bfe3-dac502259ad0.jpg

    • 在樣例應用工程entrysrcmain esourcesaseelementstring.json中可以查看 應用名稱

    • 樣例圖標修改entrysrcmain esourcesasemediaicon.png,大小是114*114像素

知識點附送

OpenHarmony截屏命令:

# 進入sdk版本號	oolchain輸入cmd打開命令行
hdc_std shell
snapshot_display
# 截圖默認保存在/data/目錄下
exit
hdc_std file recv OpenHarmony設(shè)備端截圖文件路徑 PC端路徑

(左右移動查看全部內(nèi)容)

36056c9c-ae5f-11ed-bfe3-dac502259ad0.png


更多熱點文章閱讀
  • 重磅官宣,OpenHarmony技術(shù)峰會來啦
  • 基于小凌派RK2206的智能垃圾桶設(shè)計
  • 開源硬件系列05期:HDLgen—IC設(shè)計自動化利器
  • ArkUI新能力,助力應用開發(fā)更便捷
  • 30張開放原子開源基金會OpenHarmony技術(shù)峰會門票免費送!

提示:本文由電子發(fā)燒友論壇發(fā)布,轉(zhuǎn)載請注明來源。如需社區(qū)合作及入群交流,請?zhí)砑游⑿臙EFans0806,或者發(fā)郵箱liuyong@huaqiu.com。


原文標題:觸覺智能RK3568使用體驗:NAPI 類對象導出及其生命周期管理(上)

文章出處:【微信公眾號:電子發(fā)燒友開源社區(qū)】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。


聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 電子發(fā)燒友
    +關(guān)注

    關(guān)注

    33

    文章

    548

    瀏覽量

    32682
  • 開源社區(qū)
    +關(guān)注

    關(guān)注

    0

    文章

    93

    瀏覽量

    380

原文標題:觸覺智能RK3568使用體驗:NAPI 類對象導出及其生命周期管理(上)

文章出處:【微信號:HarmonyOS_Community,微信公眾號:電子發(fā)燒友開源社區(qū)】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    瑞芯微RK3568鴻蒙開發(fā)板OpenHarmony系統(tǒng)修改cfg文件權(quán)限方法

    本文適用于OpenHarmony開源鴻蒙系統(tǒng)修改cfg文件權(quán)限方法,深圳觸覺智能研發(fā)的RK3566、RK3568、RK3588等開發(fā)板、主板
    的頭像 發(fā)表于 09-11 13:26 ?432次閱讀
    瑞芯微<b class='flag-5'>RK3568</b>鴻蒙開發(fā)板OpenHarmony系統(tǒng)修改cfg文件權(quán)限方法

    RK3568開發(fā)板支持AMP雙系統(tǒng)

    RK3568開發(fā)板支持AMP雙系統(tǒng)
    的頭像 發(fā)表于 06-04 15:33 ?427次閱讀
    <b class='flag-5'>RK3568</b>開發(fā)板支持AMP雙系統(tǒng)

    基于HD-RK3568-CORE設(shè)計的HD-RK3568-OPS主板新!

    HD-RK3568-OPS主板基于HD-RK3568-CORE 工業(yè)級核心板設(shè)計,支持標準OPS接口,具有即插即用、操作簡單的特點,適用于數(shù)字標牌、自助終端、教育一體機等應用場景。
    的頭像 發(fā)表于 04-19 18:08 ?867次閱讀
    基于HD-<b class='flag-5'>RK3568</b>-CORE設(shè)計的HD-<b class='flag-5'>RK3568</b>-OPS主板<b class='flag-5'>上</b>新!

    支持標準OPS接口,通用型RK3568工控板新!

    HD-RK3568-OPS主板基于HD-RK3568-CORE 工業(yè)級核心板設(shè)計,搭載1.8GHz主頻的高性能ARM處理器,適用于工業(yè)現(xiàn)場應用需求。
    的頭像 發(fā)表于 04-17 11:32 ?407次閱讀
    支持標準OPS接口,通用型<b class='flag-5'>RK3568</b>工控板<b class='flag-5'>上</b>新!

    rv1126和rk3568對比

    rv1126和rk3568對比: 瑞芯微智能視覺芯片RV1126是瑞芯微新一代智能視覺芯片,基于四核ARM Cortex-A7內(nèi)核,內(nèi)置2T算力 NPU,支持4K30FPS H.264/H.265
    的頭像 發(fā)表于 01-23 18:05 ?9292次閱讀
    rv1126和<b class='flag-5'>rk3568</b>對比

    RK3568-GDB程序調(diào)試方法說明

    RK3568-GDB程序調(diào)試方法說明
    的頭像 發(fā)表于 01-19 16:16 ?1490次閱讀
    <b class='flag-5'>RK3568</b>-GDB程序調(diào)試方法說明

    RK3568-MQTT通信協(xié)議案例

    RK3568-MQTT通信協(xié)議案例
    的頭像 發(fā)表于 01-19 15:31 ?1553次閱讀
    <b class='flag-5'>RK3568</b>-MQTT通信協(xié)議案例

    RK3568-IgH EtherCAT主站開發(fā)案例

    RK3568-IgH EtherCAT主站開發(fā)案例
    的頭像 發(fā)表于 01-19 15:20 ?1465次閱讀
    <b class='flag-5'>RK3568</b>-IgH EtherCAT主站開發(fā)案例

    RK3568--Acontis EtherCAT主站開發(fā)案例

    RK3568--Acontis EtherCAT主站開發(fā)案例
    的頭像 發(fā)表于 01-19 14:59 ?595次閱讀
    <b class='flag-5'>RK3568</b>--Acontis EtherCAT主站開發(fā)案例

    RK3568--系統(tǒng)啟動階段LOGO顯示

    RK3568--系統(tǒng)啟動階段LOGO顯示
    的頭像 發(fā)表于 01-19 14:44 ?760次閱讀
    <b class='flag-5'>RK3568</b>--系統(tǒng)啟動階段LOGO顯示

    RK3568---NPU開發(fā)案例

    RK3568---NPU開發(fā)案例
    的頭像 發(fā)表于 01-19 13:50 ?669次閱讀
    <b class='flag-5'>RK3568</b>---NPU開發(fā)案例

    RK3568-ISP圖像處理開發(fā)案例

    RK3568-ISP圖像處理開發(fā)案例
    的頭像 發(fā)表于 01-19 11:46 ?738次閱讀
    <b class='flag-5'>RK3568</b>-ISP圖像處理開發(fā)案例

    RK3568-ARM+FPGA通信案例開發(fā)手冊 (一)

    RK3568-ARM+FPGA通信案例開發(fā)手冊 (一)
    的頭像 發(fā)表于 01-19 10:31 ?835次閱讀
    <b class='flag-5'>RK3568</b>-ARM+FPGA通信案例開發(fā)手冊 (一)

    RK3568--基于AMP的多通道AD采集開發(fā)案

    RK3568--基于AMP的多通道AD采集開發(fā)案
    的頭像 發(fā)表于 01-19 10:03 ?680次閱讀
    <b class='flag-5'>RK3568</b>--基于AMP的多通道AD采集開發(fā)案

    RK3568-視頻開發(fā)案例

    RK3568-視頻開發(fā)案例
    的頭像 發(fā)表于 01-18 15:51 ?610次閱讀
    <b class='flag-5'>RK3568</b>-視頻開發(fā)案例