成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

新手入門ArkTS調用NATIVE庫的學習筆記

系統 OpenHarmony
本篇簡單了解一下ArkTS調用Native函數的方法,雖然了解的不是很深入,但對大體框架有了一定的掌握,為以后更復雜的Native調用開發奠定了基礎。

想了解更多關于開源的內容,請訪問:

51CTO 開源基礎軟件社區

https://ost.51cto.com

前言

本來想這周跟著HarmonyOS官網的codelabs學習一下ArkTS下對Native庫的調用,不料harmonyos官網直接把這個Codelabs課程下線了,不知以后還會不會上線。上周五還看的挺正常的,自己還加入了瀏覽器的收藏夾,結果兩天之后的今天就下線了,印象中那個課程講的還挺詳細的,想嘗試在網上搜索一下同樣的課程,看看有沒有副本,結果也沒找到。沒法跟著官方學的太詳細了,就自己盲學一下吧。原來的課程是基于Native C++模板,實現通過Native API調用C標準庫的功能,我計劃也按照這個步驟學習一下,首先了解一下新建Native工程的框架,然后在這個基礎上增加對調用C標準庫的支持。

框架介紹

新建Native C++工程,選中Stage模型。

項目創建完成后,工程目錄結構如下。

很明顯,在entry/src/main目錄下,與ets目錄同級有一個cpp目錄,這個目錄就包含了native部分的代碼,包括功能實現和編譯腳本。這個工程是可以直接運行的,不過運行效果只是一個HelloWorld,需要點擊這個組件才會執行native調用,結果顯示在標簽log中。

預覽器不支持native調用的預覽,會報錯。

09-11 11:32:40.806 12536-15828 E C03900/Ace: [Engine Log]Lifetime: 0.000000s
09-11 11:32:40.806 12536-15828 E C03900/Ace: [Engine Log]Js-Engine: ark
09-11 11:32:40.806 12536-15828 E C03900/Ace: [Engine Log]page: pages
09-11 11:32:40.806 12536-15828 E C03900/Ace: [Engine Log]Error message: Cannot read property add of undefined
09-11 11:32:40.806 12536-15828 E C03900/Ace: [Engine Log]Cannot get SourceMap info, dump raw stack:
09-11 11:32:40.806 12536-15828 E C03900/Ace: [Engine Log]Stacktrace:
09-11 11:32:40.806 12536-15828 E C03900/Ace: [Engine Log]    at anonymous (entry

我們通過模擬器運行一下。

點擊這個文本標簽,會在log窗口打印如下日志。

演示不夠直觀,操作繁瑣,看log也不方便,我們改一下,讓調用結果直接顯示在界面上。

Index.ets:

import hilog from '@ohos.hilog';
import testNapi from 'libentry.so'

@Entry
@Component
struct Index {
  @State message: string = 'Result of Native call:'

  build() {
    Row() {
      Column() {
        Text(this.message)
          .fontSize(30)
          .fontWeight(FontWeight.Bold)
          .onClick(() => {
            hilog.info(0x0000, 'testTag', 'Test NAPI 2 + 3 = %{public}d', testNapi.add(2, 3));
          })

        Text(testNapi.add(2, 3).toString())
          .fontSize(50)
          .fontColor(Color.Red)
      }
      .width('100%')
      .height('100%')
      .justifyContent(FlexAlign.Center)
    }
    .height('100%')
  }
}

現在的運行結果是這樣的。

現在已經證實了項目是完整的可以正常運行,下面分析一下具體的項目結構。

基本項目結構:

1、Entry/src/main/cpp/types/libentry/index.d.ts

export const add: (a: number, b: number) => number;

接口描述文件,描述C++接口的方法名、入參、返回參數等信息,用來暴露lib庫相關的聲明。

2、Entry/src/main/cpp/types/libentry/oh-package.json5

{
  "name": "libentry.so",
  "types": "./index.d.ts",
  "version": "",
  "description": "Please describe the basic information."
}

native庫的配置文件。

3、Entry/src/main/cpp/types/CMakeLists.txt

# the minimum version of CMake.
cmake_minimum_required(VERSION 3.4.1)
project(MyNativeApp)

set(NATIVERENDER_ROOT_PATH ${CMAKE_CURRENT_SOURCE_DIR})

include_directories(${NATIVERENDER_ROOT_PATH}
                    ${NATIVERENDER_ROOT_PATH}/include)

add_library(entry SHARED hello.cpp)
target_link_libraries(entry PUBLIC libace_napi.z.so)

編譯腳本。
cmake_minimum_required用于設定需要的最低版本的CMakeproject指定工程名為MyNativeAppSet 設置變量,指定NATIVERENDER_ROOT_PATH的位置include_directories命令用于在構建(build)中添加包含目錄add_library 使用指定的代碼向項目中增加一個庫。
target_link_libraries指定鏈接給定目標和/或其依賴項時要使用的庫或標志。將傳播鏈接庫目標的使用要求。目標依賴項的使用要求會影響其自身源的編譯。

4、Entry/src/main/cpp/types/hello.cpp

#include "napi/native_api.h"

static napi_value Add(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;

}

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 }
    };
    napi_define_properties(env, exports, sizeof(desc) / sizeof(desc[0]), desc);
    return exports;
}
EXTERN_C_END

static napi_module demoModule = {
    .nm_version =1,
    .nm_flags = 0,
    .nm_filename = nullptr,
    .nm_register_func = Init,
    .nm_modname = "entry",
    .nm_priv = ((void*)0),
    .reserved = { 0 },
};

extern "C" __attribute__((constructor)) void RegisterEntryModule(void)
{
    napi_module_register(&demoModule);
}

功能具體實現的源文件。
napi_module_register進行模塊注冊,nm_modname指的是模塊名稱,nm_register_func是模塊對外接口注冊函數。

5、Entry/build-profile.json5

{
  "apiType": 'stageMode',
  "buildOption": {
    "externalNativeOptions": {
      "path": "./src/main/cpp/CMakeLists.txt",
      "arguments": "",
      "cppFlags": "",
    }
  },
  "targets": [
    {
      "name": "default",
      "runtimeOS": "HarmonyOS"
    },
    {
      "name": "ohosTest",
    }
  ]
}

當前的模塊信息、編譯信息配置項,包括buildOption、targets配置等。
buildOption中的externalNativeOptions代表cpp相關編譯的一些配置信息,里面的參數簡介如下:

  • Path:CMake配置文件,提供CMake構建腳本
  • Arguments:傳遞給CMake的可選編譯參數
  • cppFlags:設置C++編譯器的可選參數

6、Entry/oh-package.json5

{
  "name": "entry",
  "version": "1.0.0",
  "description": "Please describe the basic information.",
  "main": "",
  "author": "",
  "license": "",
  "dependencies": {},
  "devDependencies": {
    "@types/libentry.so": "file:./src/main/cpp/types/libentry"
  }
}

應用/服務支持通過ohpm來安裝、共享、分發代碼,管理項目的依賴關系,這里的devDependencies參數指的是開發時的需要依賴,用于本地環境開發時候所需要的依賴包。

新增功能

新增一個計算平方根的功能,輸入數字,實時計算該數的平方根。

修改頁面布局文件entry/src/ets/pages/Index.ets

import hilog from '@ohos.hilog';
import testNapi from 'libentry.so'

@Entry
@Component
struct Index {
  @State message: string = 'Test NAPI 2 + 3 = '
  @State numX: number = 0.0;
  private textInputControllerX: TextInputController = new TextInputController();

  build() {
    Column() {
      Row() {
        Text(this.message)
          .fontSize(30)
          .fontWeight(FontWeight.Bold)
          .onClick(() => {
            hilog.info(0x0000, 'testTag', 'Test NAPI 2 + 3 = %{public}d', testNapi.add(2, 3));
          })

        Text(testNapi.add(2, 3).toString())
          .fontSize(40)
          .fontColor(Color.Red)
      }
      .width('100%')
      .justifyContent(FlexAlign.Center)


      Column() {
        Row() {
          TextInput({ controller: this.textInputControllerX })
            .width(100)
            .type(InputType.Number)
            .onChange(value => {
              let temp = parseFloat(value);
              this.numX = testNapi.sqrt(temp);
            })
          Text("的平方根=")
            .fontSize(40)
          Text(this.numX.toString())
            .fontSize(40)
            .fontColor(Color.Green)

        }
        .width('100%')
        .justifyContent(FlexAlign.Center)
      }
      .width('100%')
      .justifyContent(FlexAlign.Center)
      .margin({ top: 100 })

    }
    .height('100%')
    .justifyContent(FlexAlign.Center)
  }
}

修改底層庫實現文件Entry/src/main/cpp/types/hello.cpp

#include "napi/native_api.h"
#include "math.h"

static napi_value Add(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 Sqrt(napi_env env, napi_callback_info info) 
{
    size_t requireArgc = 1;
    size_t argc = 1;
    napi_value args[1] = {nullptr};

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

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


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

    napi_value result;
    napi_create_double(env, sqrt(value0), &result);

    return result;
}

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 },
        { "sqrt", nullptr, Sqrt, nullptr, nullptr, nullptr, napi_default, nullptr }
    };
    napi_define_properties(env, exports, sizeof(desc) / sizeof(desc[0]), desc);
    return exports;
}
EXTERN_C_END

static napi_module demoModule = {
    .nm_version =1,
    .nm_flags = 0,
    .nm_filename = nullptr,
    .nm_register_func = Init,
    .nm_modname = "entry",
    .nm_priv = ((void*)0),
    .reserved = { 0 },
};

extern "C" __attribute__((constructor)) void RegisterEntryModule(void)
{
    napi_module_register(&demoModule);
}

在模擬器上查看一下效果:

學習總結

通過這次學習,簡單了解了ArkTS調用native函數的方法,雖然了解的不是很深入,但對大體框架有了一定的掌握,為以后更復雜的native調用開發奠定了基礎。

想了解更多關于開源的內容,請訪問:

51CTO 開源基礎軟件社區

https://ost.51cto.com

責任編輯:jianghua 來源: 51CTO 開源基礎軟件社區
相關推薦

2011-02-21 17:51:39

Zimbra入門新手

2013-12-24 10:04:01

PostgreSQL

2011-03-22 11:06:52

Nagios安裝

2011-05-31 16:47:47

SEO

2011-01-10 14:36:00

新手linux基礎

2010-06-23 15:00:50

Fix協議

2010-09-09 13:40:19

XML DOM

2009-06-17 14:36:02

學習Java心得

2010-05-28 18:22:51

MySQL基本操作

2011-06-30 17:41:46

SEO

2010-06-19 13:47:39

AMF協議

2010-06-21 15:27:38

Linux apt-g

2009-07-16 09:07:46

Linux使用技巧Linux入門Linux開發

2010-05-14 18:31:17

MySQL 定時數據備

2010-05-17 09:52:55

虛擬化VMware Play

2010-06-10 10:31:36

MySQL出錯代碼列表

2009-03-19 09:24:50

XML標記XML結構XML入門

2011-05-18 09:52:28

2010-06-08 16:22:20

2010-07-26 10:01:01

虛擬化
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产精品久久久久久久久久免费看 | 亚洲成人一区二区在线 | av网站免费观看 | 欧美精品二区 | 欧美在线一区视频 | 久久宗合色 | 久久国产亚洲 | 久久精品国产亚洲一区二区三区 | 91麻豆精品国产91久久久更新资源速度超快 | 国产精品成av人在线视午夜片 | 日韩精品一区二区三区中文在线 | 日日干天天操 | 国产伦一区二区三区视频 | 99久久99热这里只有精品 | www.亚洲精品 | 国产九九九| 国产.com | aaa大片免费观看 | 日本一卡精品视频免费 | 日韩一区二区三区视频在线播放 | 亚洲精品一区国语对白 | 成年免费在线观看 | 51ⅴ精品国产91久久久久久 | 狠狠亚洲| 国产精品久久久久久久久久 | 欧美综合国产精品久久丁香 | 午夜影院在线 | 99亚洲精品视频 | 欧美视频一区二区三区 | 一区二区三区视频在线 | 久久精品99久久 | 韩日一区 | 日本精品一区二区在线观看 | 日韩不卡一区二区 | 久久亚洲一区二区 | 亚洲麻豆| 国产一级久久久久 | 日韩一区二区在线播放 | 黄色免费在线观看网站 | 免费看国产片在线观看 | 一级毛片视频在线 |