OpenHarmony开发者论坛

标题: 北向应用使用三方库二进制文件 [打印本页]

作者: 枫₠    时间: 2023-10-11 15:26
标题: 北向应用使用三方库二进制文件
[md]## 简介

北向应用集成三方库的方法除了通过[源码方式集成](https://gitee.com/openharmony-si ... adapter_thirdlib.md),也可以直接集成已交叉编译好的二进制文件。本文主要介绍如何将二进制文件集成到应用中。

**注意:集成到北向应用的二进制文件必须是通过OpenHarmony的linux下的SDK交叉编译生成的,不能是通过rom方式编译生成的。**

## 集成方法

### 交叉编译三方库

交叉编译的方法可以参照文档[OpenHarmony Linux 环境 SDK 使用说明](https://gitee.com/openharmony-si ... k/OHOS_SDK-Usage.md),也可以直接使用[lycium工具](https://gitee.com/openharmony-si ... /blob/master/lycium)进行交叉编译.

### 应用中调用三方库

1. 将三方库生成的二进制文件拷贝到应用工程目录
   
   为了更好的管理应用集成的三方库,在应用工程的cpp目录新建一个thirdparty目录,将生成的二进制文件以及头文件拷贝到该目录下,如下图所示,xxx代表的是三方库名称,xxx文件夹下包含了arm架构以后aarch64架构2种方式生成的二进制文件,每种架构目录下包含了该库的头文件(include)以及二进制文件(lib):
   ![lib_location.png](data/attachment/forum/202310/11/150814et3236tpglg3223z.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/300 "lib_location.png")
   
   如果该三方库二进制文件为so文件,还需要将so文件拷贝到工程目录的entry/libs/${OHOS_ARCH}/`目录下,如下图: ![so_location.png](data/attachment/forum/202310/11/150907c9yi9mpws919f1iz.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/300 "so_location.png")
   
   **动态库引用事项注意: IDE只识别不带版本号的库(即libxxx.so),而一般的动态库的soname是带主版本号的(libxxx.so.1),所以我们需要同时将不带版本号以及带主版本号的so文件拷贝到entry/libs/\${OHOS\_ARCH}/\`目录下。另外,不带版本号的动态库以及带主版本号的动态库在linux下是一个软连接,但拷贝到windows目录后变为实体,因此不需要做任何单独处理。**
2. 配置对应链接
   配置链接只需要在cpp目录的CMakeLists.txt文件中添加对应`target_link_libraries`即可

- 配置静态库链接

```cmake
target_link_libraries(entry PRIVATE ${CMAKE_CURRENT_SOURCE_DIR}/thirdparty/xxx/${OHOS_ARCH}/lib/libxxx.a)
```

- 配置动态库链接

```cmake
target_link_libraries(entry PRIVATE ${CMAKE_CURRENT_SOURCE_DIR}/thirdparty/xxx/${OHOS_ARCH}/lib/libxxx.so)
```

![so_link.png](data/attachment/forum/202310/11/151929dnjznn7p911tctip.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/300 "so_link.png")

3. 配置头文件路径
   配置链接只需要在cpp目录的CMakeLists.txt文件中添加对应`target_include_directories`
   
   ```cmake
   target_include_directories(entry PRIVATE ${CMAKE_CURRENT_SOURCE_DIR}/thirdparty/xxx/${OHOS_ARCH}/include)
   ```
4. 编写NAPI接口
   配置完三方库的链接和头文件路径后,可以根据各自的业务逻辑调用三方库对应的接口完成NAPI接口的编写,NAPI接口开发可以参照文档[NAPI学习](https://gitee.com/openharmony-si ... D%E4%BD%BF%E7%94%A8).
5. 编译构建
   请参考文档[DevEco Studio编译构建指南](https://gitee.com/link?target=ht ... catalogVersion%3DV3)

### 测试验证

请参照文档[在OpenHarmony开发板上验证hap包中集成的三方库](https://gitee.com/openharmony-si ... er/docs/test_hap.md)

[/md]




欢迎光临 OpenHarmony开发者论坛 (https://forums.openharmony.cn/) Powered by Discuz! X3.5