6

三方库移植之NAPI开发(三)通过IDE开发NAPI工程

 1 year ago
source link: https://www.51cto.com/article/721255.html
Go to the source link to view the article. You can view the picture content, updated content and better typesetting reading experience. If the link is broken, please click the button below to view the snapshot at that time.
neoserver,ios ssh client

三方库移植之NAPI开发(三)通过IDE开发NAPI工程

作者:离北况归 2022-10-25 15:05:17
在本篇文章中,笔者使用三方库移植之NAPI开发[1]—Hello OpenHarmony NAPI中一样的hellonapi.cpp和index.ets源码.
45152150654641db0af328d17f4f6e1d80be50.png

​想了解更多关于开源的内容,请访问:​

​51CTO 开源基础软件社区​

​https://ost.51cto.com​

  • 在三方库移植之NAPI开发[1]—Hello OpenHarmony NAPI一文中,笔者开发的是一个rom包的napi工程。该工程需要编译烧录固件,C ++的动态库会集成到开发板的ROM中。
  • 在本篇文章中,笔者使用三方库移植之NAPI开发[1]—Hello OpenHarmony NAPI中一样的hellonapi.cpp和index.ets源码,通过IDE开发一个RAM包的NAPI工程(集成C ++的动态库到开发板的RAM中),直接编译安装hap包到开发板即可。两个开发方式的hap包运行效果一致。

开发环境:

打开IDE,创建一个Native C++工程。

#打卡不停更#三方库移植之NAPI开发[3]通过IDE开发NAPI工程-开源基础软件社区

SDK选择API9,model选择Stage。

#打卡不停更#三方库移植之NAPI开发[3]通过IDE开发NAPI工程-开源基础软件社区
  • 新建的Native C++工程有一个默认的hello world教程,接下来需要编辑的文件如下:
#打卡不停更#三方库移植之NAPI开发[3]通过IDE开发NAPI工程-开源基础软件社区

C++方法实现

将默认的hello.cpp文件重命名为hellonapi.cpp,选中右键选中重构重命名。

#打卡不停更#三方库移植之NAPI开发[3]通过IDE开发NAPI工程-开源基础软件社区

hellonapi.cpp内容如下:

#include "napi/native_api.h"
#include <string>

//接口业务实现C/C++代码
//std::string 需要引入string头文件,#include <string>
static napi_value getHelloString(napi_env env, napi_callback_info info) {
  napi_value result;
  std::string words = "Hello OpenHarmony NAPI";
  //NAPI_CALL(env, napi_create_string_utf8(env, words.c_str(), words.length(), &result));
  napi_create_string_utf8(env, words.c_str(), words.length(), &result);
  
  return result;
}

// napi_addon_register_func
//2.指定模块注册对外接口的处理函数,具体扩展的接口在该函数中声明

static napi_value registerFunc(napi_env env, napi_value exports)
{
    static napi_property_descriptor desc[] = {
        // 声明该napi_module对外具体的提供的API
        { "getHelloString", nullptr, getHelloString, nullptr, nullptr, nullptr, napi_default, nullptr }
    };
    //NAPI_CALL(env, napi_define_properties(env, exports, sizeof(desc) / sizeof(desc[0]), desc));
    napi_define_properties(env, exports, sizeof(desc) / sizeof(desc[0]), desc);
    return exports;
}

// 1.先定义napi_module,指定当前NAPI模块对应的模块名
//以及模块注册对外接口的处理函数,具体扩展的接口在该函数中声明
// nm_modname: 模块名称,对应eTS代码为import nm_modname from '@ohos.ohos_shared_library_name'
//示例对应eTS代码为:import hellonapi from '@ohos.hellonapi'
static napi_module hellonapiModule = {
    .nm_version = 1,
    .nm_flags = 0,
    .nm_filename = nullptr,
    .nm_register_func = registerFunc, // 模块对外接口注册函数
    .nm_modname = "hellonapi",  // 自定义模块名
    .nm_priv = ((void*)0),
    .reserved = { 0 },
};

//3.模块定义好后,调用NAPI提供的模块注册函数napi_module_register(napi_module* mod)函数注册到系统中。
// register module,设备启动时自动调用此constructor函数,把模块定义的模块注册到系统中
extern "C" __attribute__((constructor)) void hellonapiModuleRegister()
{
    napi_module_register(&hellonapiModule);
}

此时的native_api.h文件是在sdk\native\3.2.7.5\sysroot\usr\include\napi目录下。

CMakeLists.txt编译配置文件编写

#打卡不停更#三方库移植之NAPI开发[3]通过IDE开发NAPI工程-开源基础软件社区
  • 和开发rom包的NAPI工程需要在BUILD.gn文件中指定编译so库需要的头文件和源文件、动态库名称、依赖的库一样,通过IDE开发ROM包时也需要在CMakeLists.txt中指定编译so库需要的头文件和源文件、动态库名称、依赖的库,内容如下:
cmake_minimum_required(VERSION 3.4.1)
project(MyApplication3)
set(NATIVERENDER_ROOT_PATH ${CMAKE_CURRENT_SOURCE_DIR})
include_directories(${NATIVERENDER_ROOT_PATH}
                    ${NATIVERENDER_ROOT_PATH}/include)

add_library(hellonapi SHARED hellonapi.cpp)
target_link_libraries(hellonapi PUBLIC libace_napi.z.so)
  • NATIVERENDER_ROOT_PATH路径指的是sdk\native\3.2.7.5\sysroot\usr
  • add_library(hellonapi SHARED hellonapi.cpp)表示编译libhellonapi.so需要的是hellonapi.cpp
  • target_link_libraries(hellonapi PUBLIC libace_napi.z.so)表示编译编译libhellonapi.so依赖libace_napi.z.so
  • 开发ROM包的NAPI工程时,libhellonapi.z.so也依赖libace_napi.z.so,以下为开发ROM包的NAPI工程时BUILD.gn文件
#打卡不停更#三方库移植之NAPI开发[3]通过IDE开发NAPI工程-开源基础软件社区

libhellonapi.so依赖的libace_napi.z.so在sdk\native\3.2.7.5\sysroot\usr\lib\aarch64-linux-ohos目录下。

#打卡不停更#三方库移植之NAPI开发[3]通过IDE开发NAPI工程-开源基础软件社区

sdk\native\3.2.7.5\sysroot\usr\lib\arm-linux-ohos目录下也有开发ROM包的NAPI时候可能依赖的动态库。

index.d.ts声明文件编写

#打卡不停更#三方库移植之NAPI开发[3]通过IDE开发NAPI工程-开源基础软件社区

index.d.ts内容如下:

export const getHelloString: () => string;
#打卡不停更#三方库移植之NAPI开发[3]通过IDE开发NAPI工程-开源基础软件社区

index.ets和​​三方库移植之NAPI开发[1]—Hello OpenHarmony NAPI​​一文中一致。

import prompt from '@system.prompt'
import hellonapi from 'libhellonapi.so'

@Entry
@Component
export struct HelloNAPI {
  build() {
    Flex({ direction: FlexDirection.Column, alignItems: ItemAlign.Center, justifyContent: FlexAlign.Center }) {
      Button("NAPI: hellonapi.getHelloString()").margin(10).fontSize(24).onClick(() => {
        // 调用getHelloString接口
        let strFromNAPI = hellonapi.getHelloString()
        prompt.showToast({ message: strFromNAPI })
      })
    }
    .width('100%')
    .height('100%')
  }
}

json配置文件编写

  • package.json内容如下:
resize,w_543,h_283
{
  "name": "libhellonapi.so",
  "types": "./index.d.ts"
}
  • entry/package-lock.json内容如下:
resize,w_820,h_732
"@types/libhellonapi.so":"file:./src/main/cpp/types/libhellonapi"
#打卡不停更#三方库移植之NAPI开发[3]通过IDE开发NAPI工程-开源基础软件社区
  • 有报错就删除原有的libentry.so符号链接。
#打卡不停更#三方库移植之NAPI开发[3]通过IDE开发NAPI工程-开源基础软件社区
  • entry/package.json内容如下:
resize,w_820,h_838
"@types/libhellonapi.so": {
      "version": "file:src/main/cpp/types/libhellonapi",
  • 修改原有的libentry为libhellonapi
resize,w_535,h_387
  • 设置hap为自动签名
resize,w_820,h_1191

hap包运行效果

和三方库移植之NAPI开发[1]—Hello OpenHarmony NAPI一文效果一致。

#打卡不停更#三方库移植之NAPI开发[3]通过IDE开发NAPI工程-开源基础软件社区

总结:RAM包的NAPI工程和ROM包的NAPI工程的异同

以下为个人总结,希望各位老师和同学批评指正

  • 动态库的命名方式的不同,RAM包的NAPI工程(通过IDE开发NAPI工程)使用的动态库libhellonapi.so,而ROM包的NAPI工程编译出来使用的动态库是libhellonapi.z.so。
#打卡不停更#三方库移植之NAPI开发[3]通过IDE开发NAPI工程-开源基础软件社区
  • libhellonapi.so位于hap包源码路径如下:
entry\build\default\intermediates\libs\default\arm64-v8a
entry\build\default\intermediates\cmake\default\obj\arm64-v8a
entry\build\default\intermediates\libs\default\armeabi-v7a
entry\build\default\intermediates\cmake\default\obj\armeabi-v7a
resize,w_418,h_134
  • 开发ROM包的NAPI工程需要加入OHOS编译体系,编写BULID.gn、ohos.build等,开发过程较为繁琐。而RAM包的NAPI工程不需要加入OHOS编译体系,编写CMakeLists.txt配置编译需要的源文件、头文件、依赖的库等。因此开发RAM包的NAPI工程相对简洁。
  • .d.ts声明文件的编写不同
  • 开发ROM包的NAPI工程时,笔者编写的@ohos.hellonapi.d.ts内容为
resize,w_820,h_387
  • 开发RAM包的NAPI工程时,笔者编写的@ohos.hellonapi.d.ts内容为:
#打卡不停更#三方库移植之NAPI开发[3]通过IDE开发NAPI工程-开源基础软件社区
编写.d.ts声明文件时,RAM包开发的NAPI工程定义功能方法getHelloString: () => string比ROM包多了=>符号。

知识点附送

  • 以下为开发ROM包的NAPI工程时,需要添加进入sdk的声明文件模板。
    @ohos.模块名.d.ts文件:
/**
* 模块描述
* @since API版本号,IT Release3 对应 4,以此类推
* @sysCap 系统能力
* @devices 支持设备
* @import 导入模块
* @permission 权限列表
*/
declare namespace 模块名 {
// 在此处定义功能方法
}
export default 模块名;

文章相关附件可以点击下面的原文链接前往下载:

​https://ost.51cto.com/resource/2351。​

​想了解更多关于开源的内容,请访问:​

​51CTO 开源基础软件社区​

​https://ost.51cto.com​​。

责任编辑:jianghua 来源: 51CTO开源基础软件社区

About Joyk


Aggregate valuable and interesting links.
Joyk means Joy of geeK