同步操作将从 OpenHarmony-SIG/tpc_c_cplusplus 强制同步,此操作会覆盖自 Fork 仓库以来所做的任何修改,且无法恢复!!!
确定后同步将在后台操作,完成时将刷新页面,请耐心等待。
北向应用集成三方库的方法除了通过源码方式集成,也可以直接集成已交叉编译好的二进制文件。本文主要介绍如何将二进制文件集成到应用中。
注意:集成到北向应用的二进制文件必须是通过OpenHarmony的SDK交叉编译生成的,不能是通过rom方式编译生成的。
交叉编译的方法可以参照文档OpenHarmony SDK 使用说明,也可以直接使用lycium工具进行交叉编译.
将三方库生成的二进制文件拷贝到应用工程目录
为了更好的管理应用集成的三方库,在应用工程的cpp目录新建一个thirdparty目录,将生成的二进制文件以及头文件拷贝到该目录下,如下图所示,xxx代表的是三方库名称,xxx文件夹下包含了arm架构以后aarch64架构2种方式生成的二进制文件,每种架构目录下包含了该库的头文件(include)以及二进制文件(lib):
如果该三方库二进制文件为so文件,还需要将so文件拷贝到工程目录的entry/libs/${OHOS_ARCH}/
目录下,如下图:
动态库引用事项注意: IDE只识别不带版本号的库(即libxxx.so),而一般的动态库的soname是带主版本号的(libxxx.so.1),所以我们需要同时将不带版本号以及带主版本号的so文件拷贝到entry/libs/${OHOS_ARCH}/`目录下。另外,不带版本号的动态库以及带主版本号的动态库在linux下是一个软连接,但拷贝到windows目录后变为实体,因此不需要做任何单独处理。
配置对应链接
配置链接只需要在cpp目录的CMakeLists.txt文件中添加对应target_link_libraries
即可:
target_link_libraries(entry PRIVATE ${CMAKE_CURRENT_SOURCE_DIR}/thirdparty/xxx/${OHOS_ARCH}/lib/libxxx.a)
target_link_libraries(entry PRIVATE ${CMAKE_CURRENT_SOURCE_DIR}/thirdparty/xxx/${OHOS_ARCH}/lib/libxxx.so)
配置头文件路径
配置链接只需要在cpp目录的CMakeLists.txt文件中添加对应target_include_directories
target_include_directories(entry PRIVATE ${CMAKE_CURRENT_SOURCE_DIR}/thirdparty/xxx/${OHOS_ARCH}/include)
编写NAPI接口
配置完三方库的链接和头文件路径后,可以根据各自的业务逻辑调用三方库对应的接口完成NAPI接口的编写,NAPI接口开发可以参照文档NAPI学习.
编译构建
请参考文档DevEco Studio编译构建指南
请参照文档在OpenHarmony开发板上验证hap包中集成的三方库
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。