精品国产人成在线_亚洲高清无码在线观看_国产在线视频国产永久2021_国产AV综合第一页一个的一区免费影院黑人_最近中文字幕MV高清在线视频

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

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

3天內不再提示

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

開發(fā)板試用精選 ? 來源:開發(fā)板試用 ? 作者:電子發(fā)燒友論壇 ? 2022-10-13 10:19 ? 次閱讀

本文來源電子發(fā)燒友社區(qū),作者:soon順soon, 帖子地址:https://bbs.elecfans.com/jishu_2308771_1_1.html



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

1.新建OpenHarmony Native C++工程

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

輸入Project name,選擇SDK版本9

CreateProject2.png

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

CreateProject3.png

下載Native SDK
SDK.png

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

2.源碼修改

2.1 工程主要文件說明

工程初始化后目錄結構如下圖,主要文件為紅色框內文件

project_file.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)境等調用管理
    └── pages
        └── index.ets                                   // 主頁面

2.2 cpp源碼編寫

自帶的案例已經實現(xiàn)了加法運算的接口,本案例在此基礎上加入減法乘法除法,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;

}

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

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;

2.4 界面實現(xiàn)

src/main/ets/pages/index.ets
中通過import testNapi from 'libentry.so'引入SO包,當點擊按鈕時調用對應的方法

import testNapi from 'libentry.so'

@Entry
@Component
struct Index {
  private textInputController1: TextInputController = new TextInputController()
  private textInputController2: TextInputController = new TextInputController()
  private tittle: string = '調用C標準庫示例'
  private message: string = '對給定的兩個數(shù)進行加減乘除運算'
  private tipsNum1: string = '請輸入第一個數(shù):'
  private tipsNum2: string = '請輸入第二個數(shù):'
  private tipsResult: string = '結果:'
  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%')
  }
}

3 運行效果演示

簽名后運行效果如下

加法

加法.jpg

減法

減法.jpg

乘法
乘法.jpg

除法

除法.jpg

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

    關注

    22

    文章

    2104

    瀏覽量

    73489
  • 軟通動力
    +關注

    關注

    1

    文章

    758

    瀏覽量

    15131
  • 鴻湖萬聯(lián)

    關注

    1

    文章

    65

    瀏覽量

    623
收藏 人收藏

    評論

    相關推薦

    動力及子公司聯(lián)當選GIIC聯(lián)盟理事單位

    操作系統(tǒng)研發(fā)和產業(yè)化服務的較早參與者、鴻蒙生態(tài)建設的先鋒企業(yè),動力及其子公司聯(lián)雙雙被授
    的頭像 發(fā)表于 11-24 11:43 ?207次閱讀

    動力子公司聯(lián)發(fā)布SwanLinkOS 5

    在近日圓滿閉幕的首屆H?I3 AI探索峰會上,動力憑借其深厚的技術實力與創(chuàng)新精神,在鴻蒙生態(tài)領域再次邁出堅實步伐。會上,動力攜手子公司
    的頭像 發(fā)表于 09-04 16:50 ?772次閱讀

    動力子公司聯(lián)重磅發(fā)布SwanLinkOS 5,擘畫開源鴻蒙AI PC新篇章

    在剛剛落下帷幕的首屆H?I3AI探索峰會上,動力再次于鴻蒙生態(tài)領域實現(xiàn)突破。此次活動中,動力高級副總裁、
    的頭像 發(fā)表于 09-03 11:37 ?496次閱讀
    <b class='flag-5'>軟</b>通<b class='flag-5'>動力</b>子公司<b class='flag-5'>鴻</b><b class='flag-5'>湖</b><b class='flag-5'>萬</b><b class='flag-5'>聯(lián)</b>重磅發(fā)布SwanLinkOS 5,擘畫開源鴻蒙AI PC新篇章

    動力子公司聯(lián)榮獲礦OSV生態(tài)合作伙伴授牌

    圓滿舉行。此次授牌旨在表彰和認可礦生態(tài)圈內的優(yōu)秀合作伙伴,激發(fā)礦領域新動能。動力子公司
    的頭像 發(fā)表于 08-14 17:58 ?287次閱讀
    <b class='flag-5'>軟</b>通<b class='flag-5'>動力</b>子公司<b class='flag-5'>鴻</b><b class='flag-5'>湖</b><b class='flag-5'>萬</b><b class='flag-5'>聯(lián)</b>榮獲礦<b class='flag-5'>鴻</b>OSV生態(tài)合作伙伴授牌

    動力旗下聯(lián)榮獲礦OSV生態(tài)合作伙伴授牌

    近日,鄂爾多斯臨港經濟區(qū)見證了礦OSV生態(tài)合作伙伴授牌儀式的隆重舉行。在這場匯聚行業(yè)精英的盛會中,動力旗下的
    的頭像 發(fā)表于 08-14 14:50 ?535次閱讀

    動力子公司聯(lián)攜多款重磅創(chuàng)新產品亮相華為開發(fā)者大會

    如何引領行業(yè)進步,共同探索鴻蒙生態(tài)與AI大模型的發(fā)展新契機。作為本次大會鉆石級合作伙伴,動力攜子公司
    的頭像 發(fā)表于 06-25 11:38 ?318次閱讀
    <b class='flag-5'>軟</b>通<b class='flag-5'>動力</b>子公司<b class='flag-5'>鴻</b><b class='flag-5'>湖</b><b class='flag-5'>萬</b><b class='flag-5'>聯(lián)</b>攜多款重磅創(chuàng)新產品亮相華為<b class='flag-5'>開發(fā)</b>者大會

    動力子公司聯(lián)獲評首批華為礦OSV伙伴

    產業(yè)的新技術、新產品、新工藝、新成果,助力煤炭全產業(yè)鏈實現(xiàn)轉型突破,并打造一個專業(yè)化、國際化、市場化、高水平的煤炭及能源成果交流交易平臺,以促進煤炭及能源產業(yè)的合作與發(fā)展。動力子公司
    的頭像 發(fā)表于 05-18 09:42 ?428次閱讀
    <b class='flag-5'>軟</b>通<b class='flag-5'>動力</b>子公司<b class='flag-5'>鴻</b><b class='flag-5'>湖</b><b class='flag-5'>萬</b><b class='flag-5'>聯(lián)</b>獲評首批華為礦<b class='flag-5'>鴻</b>OSV伙伴

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

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

    生態(tài)“加速跑” 動力子公司聯(lián)榮膺華為“礦生態(tài)使能合作伙伴”

    。在本次展會上,動力子公司聯(lián)受邀參與了華為礦
    的頭像 發(fā)表于 04-02 15:43 ?523次閱讀
    礦<b class='flag-5'>鴻</b>生態(tài)“加速跑” <b class='flag-5'>軟</b>通<b class='flag-5'>動力</b>子公司<b class='flag-5'>鴻</b><b class='flag-5'>湖</b><b class='flag-5'>萬</b><b class='flag-5'>聯(lián)</b>榮膺華為“礦<b class='flag-5'>鴻</b>生態(tài)使能合作伙伴”

    共譜開源新篇章 動力子公司聯(lián)與鴻蒙生態(tài)服務公司簽署戰(zhàn)略合作協(xié)議

    近日,動力子公司聯(lián)與鴻蒙生態(tài)服務(深圳)有限公司(以下簡稱“鴻蒙生態(tài)服務公司”)成功簽
    的頭像 發(fā)表于 04-02 15:23 ?464次閱讀
    共譜開源新篇章 <b class='flag-5'>軟</b>通<b class='flag-5'>動力</b>子公司<b class='flag-5'>鴻</b><b class='flag-5'>湖</b><b class='flag-5'>萬</b><b class='flag-5'>聯(lián)</b>與鴻蒙生態(tài)服務公司簽署戰(zhàn)略合作協(xié)議

    人才儲備再升級!動力子公司聯(lián)多名講師榮獲首批“鴻蒙原生應用開發(fā)培訓講師”認證

    近日,由鴻蒙生態(tài)服務公司組織開展的國內首批“鴻蒙原生應用開發(fā)培訓講師”認證順利完成。作為此次認證的重要參與者,聯(lián)申報的四位鴻蒙資深專家
    的頭像 發(fā)表于 03-25 10:25 ?595次閱讀
    人才儲備再升級!<b class='flag-5'>軟</b>通<b class='flag-5'>動力</b>子公司<b class='flag-5'>鴻</b><b class='flag-5'>湖</b><b class='flag-5'>萬</b><b class='flag-5'>聯(lián)</b>多名講師榮獲首批“鴻蒙原生應用<b class='flag-5'>開發(fā)</b>培訓講師”認證

    動力子公司聯(lián)多名講師榮獲首批“鴻蒙原生應用開發(fā)培訓講師”認證

    近日,由鴻蒙生態(tài)服務公司組織開展的國內首批“鴻蒙原生應用開發(fā)培訓講師”認證順利完成。作為此次認證的重要參與者,聯(lián)申報的四位鴻蒙資深專家
    的頭像 發(fā)表于 03-25 09:24 ?408次閱讀

    動力子公司聯(lián)戰(zhàn)略簽約鄂爾多斯工業(yè)互聯(lián)網平臺

    多方力量,旨在通過構建創(chuàng)新交流平臺,凝聚智慧力量,進一步鞏固鄂爾多斯市工業(yè)互聯(lián)網建設成果,充分發(fā)揮礦產業(yè)優(yōu)勢,加快工業(yè)互聯(lián)網基礎設施建設。動力子公司
    的頭像 發(fā)表于 01-22 13:57 ?499次閱讀

    精彩回顧·2023開放原子開發(fā)者大會 動力攜子公司聯(lián)助推開源生態(tài)破浪前行

    原文標題:精彩回顧·2023開放原子開發(fā)者大會 動力攜子公司
    的頭像 發(fā)表于 12-20 18:40 ?368次閱讀

    擁抱開源力量,動力子公司聯(lián)助陣OpenHarmony城市推介會·武漢市成功舉辦

    動力子公司聯(lián)受邀參會并參與主題分享。 在題為 “開源驅動創(chuàng)新,
    的頭像 發(fā)表于 12-08 20:45 ?583次閱讀