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

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

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

基于OpenHarmony開發(fā)板上測試Native C++應(yīng)用開發(fā)

電子發(fā)燒友開源社區(qū) ? 來源:電子發(fā)燒友開源社區(qū) ? 作者:電子發(fā)燒友開源社 ? 2022-10-08 14:37 ? 次閱讀

本文主要分享在軟通動力揚帆系列“競”OpenHarmony開發(fā)板上測試Native C++應(yīng)用開發(fā),實現(xiàn)eTS調(diào)用Native C++ 程序?qū)崿F(xiàn)對給定的兩個數(shù)進行加減乘除運算示例(eTS)

1.新建OpenHarmony Native C++工程

選擇File->New->Create Project -> OpenHarmony -> Native C++點擊Next

d1b01fda-46c1-11ed-96c9-dac502259ad0.png

輸入Project name,選擇SDK版本9

d1dc80ac-46c1-11ed-96c9-dac502259ad0.png

點擊Finish,如果Native SDK 沒有下載則會出現(xiàn)以下界面,點擊Configure Now

d22dafa4-46c1-11ed-96c9-dac502259ad0.png

下載Native SDK

d27395b4-46c1-11ed-96c9-dac502259ad0.png

Native SDK下載完成后點擊Finish 進入工程

d2cdab3a-46c1-11ed-96c9-dac502259ad0.png

2.源碼修改

2.1 工程主要文件說明

工程初始化后目錄結(jié)構(gòu)如下圖,主要文件為紅色框內(nèi)文件

d2e93d64-46c1-11ed-96c9-dac502259ad0.png

主要文件文件說明如下:

├── cpp:C++代碼區(qū)         
│  ├── types:                     // 接口存放文件夾
│  │  └── libentry       
│  │    ├── index.d.ts               // 接口文件
│  │    └── package.json              // 接口注冊配置文件
│  ├── CmakeList.txt                  // Cmake打包配置文件
│  └── hello.cpp                    // C++源代碼
└── ets                         // ets代碼區(qū)
  └── Application
  │  └── AbilityStage.ts               // Hap包運行時類
  ├── MainAbility
  │  └── MainAbility.ts               // Ability,提供對Ability生命周期、上下文環(huán)境等調(diào)用管理
  └── pages
    └── index.ets                  // 主頁面

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

2.2 cpp源碼編寫

自帶的案例已經(jīng)實現(xiàn)了加法運算的接口,本案例在此基礎(chǔ)上加入減法乘法除法,entrysrcmaincpphello.cpp主要修改如下

參考“Add”方法,實現(xiàn)Sub、Mul、Div

static napi_value Sub(napi_env env, napi_callback_info info)
{
  size_t requireArgc = 2;
  size_t argc = 2;
  napi_value args[2] = {nullptr};


  napi_get_cb_info(env, info, &argc, args , nullptr, nullptr);


  napi_valuetype valuetype0;
  napi_typeof(env, args[0], &valuetype0);


  napi_valuetype valuetype1;
  napi_typeof(env, args[1], &valuetype1);


  double value0;
  napi_get_value_double(env, args[0], &value0);


  double value1;
  napi_get_value_double(env, args[1], &value1);


  napi_value sum;
  napi_create_double(env, value0 - value1, &sum);


  return sum;


}
static napi_value Mul(napi_env env, napi_callback_info info)
{
  size_t requireArgc = 2;
  size_t argc = 2;
  napi_value args[2] = {nullptr};


  napi_get_cb_info(env, info, &argc, args , nullptr, nullptr);


  napi_valuetype valuetype0;
  napi_typeof(env, args[0], &valuetype0);


  napi_valuetype valuetype1;
  napi_typeof(env, args[1], &valuetype1);


  double value0;
  napi_get_value_double(env, args[0], &value0);


  double value1;
  napi_get_value_double(env, args[1], &value1);


  napi_value sum;
  napi_create_double(env, value0*value1, &sum);


  return sum;


}
static napi_value Div(napi_env env, napi_callback_info info)
{
  size_t requireArgc = 2;
  size_t argc = 2;
  napi_value args[2] = {nullptr};


  napi_get_cb_info(env, info, &argc, args , nullptr, nullptr);


  napi_valuetype valuetype0;
  napi_typeof(env, args[0], &valuetype0);


  napi_valuetype valuetype1;
  napi_typeof(env, args[1], &valuetype1);


  double value0;
  napi_get_value_double(env, args[0], &value0);


  double value1;
  napi_get_value_double(env, args[1], &value1);


  napi_value sum;
  napi_create_double(env, value0/value1, &sum);


  return sum;


}

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

Init中注冊對外接口名為“sub”、“mul”、“div”

EXTERN_C_START
static napi_value Init(napi_env env, napi_value exports)
{
  napi_property_descriptor desc[] = {
    { "add", nullptr, Add, nullptr, nullptr, nullptr, napi_default, nullptr },
    { "sub", nullptr, Sub , nullptr, nullptr, nullptr, napi_default, nullptr },
    { "mul", nullptr, Mul , nullptr, nullptr, nullptr, napi_default, nullptr },
    { "div", nullptr, Div , nullptr, nullptr, nullptr, napi_default, nullptr },
  };
  napi_define_properties(env, exports, sizeof(desc) / sizeof(desc[0]), desc);
  return exports;
}
EXTERN_C_END

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

2.3 index.d.ts接口文檔編寫

src/main/cpp/types/libentry/index.d.ts添加以下接口:

export const sub: (a: number, b: number) => number;
export const mul: (a: number, b: number) => number;
export const div: (a: number, b: number) => number;

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

2.4 界面實現(xiàn)

src/main/ets/pages/index.ets中通過import testNapi from 'libentry.so'引入SO包,當(dāng)點擊按鈕時調(diào)用對應(yīng)的方法

import testNapi from 'libentry.so'


@Entry
@Component
struct Index {
 private textInputController1: TextInputController = new TextInputController()
 private textInputController2: TextInputController = new TextInputController()
 private tittle: string = '調(diào)用C標準庫示例'
 private message: string = '對給定的兩個數(shù)進行加減乘除運算'
 private tipsNum1: string = '請輸入第一個數(shù):'
 private tipsNum2: string = '請輸入第二個數(shù):'
 private tipsResult: string = '結(jié)果:'
 private buttonAdd: string = '加'
 private buttonSub: string = '減'
 private buttonMul: string = '乘'
 private buttonDiv: string = '除'
 @State result: number = 0
 @State num1: number = 0.0
 @State num2: number = 0.0


 build() {
  Row() {
   Column() {
    Row(){
     Text(this.tittle).height('100%').align(Alignment.Center).fontSize(40).fontWeight(800)
    }.height('10%').width('100%').justifyContent(FlexAlign.Center)
    Row(){
     Text(this.message).height('100%').align(Alignment.Center).fontSize(24).fontWeight(500)
    }.height('15%').width('100%').justifyContent(FlexAlign.Center)
    Row(){
     Text(this.tipsNum1).fontColor(Color.Black).fontSize(24).width('30%').height('100%').margin({left:30})
     TextInput({ placeholder: '請輸入第一個數(shù)字:', controller:this.textInputController1}).type(InputType.Number)
      .height('100%').width('60%').margin({left:10,right:30})
      .onChange(value =>{this.num1 = parseFloat(value)})
    }.height('5%').width('100%').justifyContent(FlexAlign.Start)
    Row(){
     Text(this.tipsNum2).fontColor(Color.Black).fontSize(24).width('30%').height('100%').margin({left:30})
     TextInput({ placeholder: '請輸入第二個數(shù)字:', controller:this.textInputController2}).type(InputType.Number)
      .height('100%').width('60%').margin({left:10,right:30})
      .onChange(value =>{this.num2 = parseFloat(value)})
    }.height('5%').width('100%').margin({top:20})
    Row(){
     Text(this.tipsResult).fontColor(Color.Black).fontSize(24).width('40%').height('100%').margin({left:30})
     Text(''+this.result).fontColor(Color.Black).fontSize(30).width(60).height(200).width('60%').height('100%')
    }.height('10%').width('100%').touchable(false)
    Row(){
     Button(this.buttonAdd)
      .fontSize(40)
      .fontWeight(FontWeight.Bold)
      .margin({top:5})
      .height(100)
      .width(100)
      .onClick(() => {
       this.result = testNapi.add(this.num1,this.num2)
      })
     Button(this.buttonSub)
      .fontSize(40)
      .fontWeight(FontWeight.Bold)
      .margin({top:5})
      .height(100)
      .width(100)
      .onClick(() => {
       this.result = testNapi.sub(this.num1,this.num2)
      })
     Button(this.buttonMul)
      .fontSize(40)
      .fontWeight(FontWeight.Bold)
      .margin({top:5})
      .height(100)
      .width(100)
      .onClick(() => {
       this.result = testNapi.mul(this.num1,this.num2)
      })
     Button(this.buttonDiv)
      .fontSize(40)
      .fontWeight(FontWeight.Bold)
      .margin({top:5})
      .height(100)
      .width(100)
      .onClick(() => {
       this.result = testNapi.div(this.num1,this.num2)
      })
    }.height('30%').width('100%').justifyContent(FlexAlign.Center)
   }
   .width('100%')
  }
  .height('100%')
 }
}

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

3.運行效果演示

簽名后運行效果如下:

加法:

d320b014-46c1-11ed-96c9-dac502259ad0.jpg

減法:

d3679b64-46c1-11ed-96c9-dac502259ad0.jpg

乘法:

d39ade7a-46c1-11ed-96c9-dac502259ad0.jpg

除法:

d3b7e9fc-46c1-11ed-96c9-dac502259ad0.jpg

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

    關(guān)注

    33

    文章

    8659

    瀏覽量

    151480
  • C++
    C++
    +關(guān)注

    關(guān)注

    22

    文章

    2113

    瀏覽量

    73738
  • 開發(fā)板
    +關(guān)注

    關(guān)注

    25

    文章

    5087

    瀏覽量

    97785
  • OpenHarmony
    +關(guān)注

    關(guān)注

    25

    文章

    3730

    瀏覽量

    16424

原文標題:揚帆系列“競”O(jiān)penHarmony開發(fā)板實現(xiàn)對給定的兩個數(shù)進行加減乘除運算

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

收藏 人收藏

    評論

    相關(guān)推薦

    【軟通動力鴻湖萬聯(lián)揚帆系列“競”開發(fā)板試用體驗】Native C++應(yīng)用Demo示例(eTS)

    OpenHarmony開發(fā)板測試Native C++應(yīng)用
    的頭像 發(fā)表于 10-13 10:19 ?1082次閱讀
    【軟通動力鴻湖萬聯(lián)揚帆系列“競”<b class='flag-5'>開發(fā)板</b>試用體驗】<b class='flag-5'>Native</b> <b class='flag-5'>C++</b>應(yīng)用Demo示例(eTS)

    鴻蒙next開發(fā)-OpenHarmony的NDK開發(fā)

    Native API是OpenHarmony SDK提供的一組native開發(fā)接口與工具集合(也稱為NDK),方便
    的頭像 發(fā)表于 01-20 11:35 ?1841次閱讀
    鴻蒙next<b class='flag-5'>開發(fā)</b>-<b class='flag-5'>OpenHarmony</b>的NDK<b class='flag-5'>開發(fā)</b>

    鴻蒙OS開發(fā)實例:【Native C++

    使用DevEco Studio創(chuàng)建一個Native C++應(yīng)用。應(yīng)用采用Native C++模板,實現(xiàn)使用NAPI調(diào)用C標準庫的功能。使用
    的頭像 發(fā)表于 04-14 11:43 ?2690次閱讀
    鴻蒙OS<b class='flag-5'>開發(fā)</b>實例:【<b class='flag-5'>Native</b> <b class='flag-5'>C++</b>】

    【軟通動力鴻湖萬聯(lián)揚帆系列“競”開發(fā)板試用體驗】試用測評報告五 –開源鴻蒙C/C++軟件開發(fā)

    鴻湖萬聯(lián)揚帆系列“競”開發(fā)板試用測評報告五 –開源鴻蒙C/C++軟件開發(fā)大信(QQ:8125036)在成功的建立了開源鴻蒙的集成開發(fā)環(huán)境以后
    發(fā)表于 09-22 17:29

    【軟通動力鴻湖萬聯(lián)揚帆系列“競”開發(fā)板試用體驗】Native C++應(yīng)用Demo示例(eTS)

    本文主要分享在軟通動力揚帆系列“競”OpenHarmony開發(fā)板測試Native C++應(yīng)用
    發(fā)表于 10-06 00:12

    如何使用DevEco Studio創(chuàng)建Native C++應(yīng)用

    展示點擊輸入框輸入兩個數(shù),再點擊計算按鈕調(diào)用接口,將數(shù)據(jù)傳入到C++端,C++端計算后再作為返回值到ArkTS端。環(huán)境搭建我們首先要完成應(yīng)用開發(fā)環(huán)境的搭建,本示例運行RK3568開發(fā)板
    發(fā)表于 02-22 14:24

    openharmony開發(fā)openharmony開發(fā)板

    現(xiàn)在市面上支持OpenHarmony開發(fā)板已經(jīng)非常多了,OpenHarmony不僅僅只能在海思系列芯片運行,比較常見的有HiSpark、小熊派系列。這些
    的頭像 發(fā)表于 06-24 09:03 ?3708次閱讀

    OpenHarmony3.0編譯C控制Hi3516開發(fā)板的LED閃爍

    使用的是比較新的 OpenHarmony 3.0 LTS 版本,Linux 內(nèi)核,編譯標準系統(tǒng)。 官方文檔已經(jīng)說明了,如何使用 DevEco Studio 開發(fā) hap 包,并運行在開發(fā)板,但是 ACE
    的頭像 發(fā)表于 09-28 09:42 ?3717次閱讀
    <b class='flag-5'>OpenHarmony</b>3.0<b class='flag-5'>上</b>編譯<b class='flag-5'>C</b>控制Hi3516<b class='flag-5'>開發(fā)板</b>的LED閃爍

    如何移植OpenHarmony 3.0 到星空派開發(fā)板

    9 月 30 日,OpenHarmony 3.0 LTS 版本發(fā)布。本文將介紹如何移植 OpenHarmony 3.0 到星空派開發(fā)板。 星空派
    的頭像 發(fā)表于 10-19 09:08 ?2530次閱讀
    如何移植<b class='flag-5'>OpenHarmony</b> 3.0 到星空派<b class='flag-5'>開發(fā)板</b><b class='flag-5'>上</b>

    如何把OpenHarmony燒錄進博流BL-HWC-G1開發(fā)板

    作者:HonestQiao|喬楚 在上一篇【博流 BL-HWC-G1 開發(fā)板試用】開箱及編譯燒錄官方程序(BL602 IoT SDK)中,我們講了這塊開發(fā)板使用官方SDK進行編譯燒錄,這一篇,我們
    的頭像 發(fā)表于 11-08 09:59 ?2536次閱讀
    如何把<b class='flag-5'>OpenHarmony</b>燒錄進博流BL-HWC-G1<b class='flag-5'>開發(fā)板</b><b class='flag-5'>上</b>

    怎么樣把OpenHarmony燒錄到開發(fā)板

    ? 在上一篇【博流 BL-HWC-G1 開發(fā)板試用】開箱及編譯燒錄官方程序(BL602 IoT SDK)中,我們講了這塊開發(fā)板使用官方SDK進行編譯燒錄,這一篇,我們來講OpenHarmony的編譯
    的頭像 發(fā)表于 11-10 09:17 ?1874次閱讀
    怎么樣把<b class='flag-5'>OpenHarmony</b>燒錄到<b class='flag-5'>開發(fā)板</b><b class='flag-5'>上</b>

    OpenHarmony開發(fā)板適配經(jīng)驗分享--王城

    OpenHarmony開發(fā)板適配經(jīng)驗分享 審核編輯:金巧
    的頭像 發(fā)表于 12-28 14:46 ?1739次閱讀
    <b class='flag-5'>OpenHarmony</b><b class='flag-5'>開發(fā)板</b>適配經(jīng)驗分享--王城

    如何使用DevEco Studio創(chuàng)建Native C++應(yīng)用

    for OpenAtom OpenHarmony (以下簡稱“OpenHarmony”)創(chuàng)建一個Native C++應(yīng)用。應(yīng)用采用“Native
    的頭像 發(fā)表于 02-21 14:30 ?1467次閱讀

    開發(fā)板如何適配OpenHarmony 3.2

    科技基于RK3568設(shè)計的HCPAD-100開發(fā)板以及基于RK3566設(shè)計的中控屏HongzPad2022在OpenHarmony 3.2 Beta5版本的適配過程。 涉及到開發(fā)板
    的頭像 發(fā)表于 04-04 01:35 ?1576次閱讀

    OpenHarmony C++公共基礎(chǔ)類庫應(yīng)用案例:HelloWorld

    1、程序簡介該程序是基于OpenHarmonyC++公共基礎(chǔ)類庫的簡單案例:HelloWorld。該應(yīng)用案例已在OpenHarmony凌蒙派-RK3568開發(fā)板(即
    的頭像 發(fā)表于 11-23 08:22 ?719次閱讀
    <b class='flag-5'>OpenHarmony</b> <b class='flag-5'>C++</b>公共基礎(chǔ)類庫應(yīng)用案例:HelloWorld