# 如何在CMake工程中使用OpenHarmony SDK的Native API(NDK) ## 什么是Native API 请参看[Native API](../reference/native-api-intro.md) ## 如何下载Native API开发包(NDK) 1. 推荐使用OpenHarmony正式发布的SDK包 ,下载链接可以从OpenHarmony正式发布版本的[release-notes](../../release-notes/OpenHarmony-v3.2-release.md)中获取,点击release notes中【从站点镜像获取】章节下载。 2. IDE OpenHarmony SDK Manager中下载。 3. 从每日构建中下载,下载地址 http://ci.openharmony.cn/workbench/cicd/dailybuild/dailylist ,形态组件选择ohos-sdk。 ![](figures/ci_download.png) ## 解压Native API开发包 下载完成之后,将压缩包放入创建好的文件夹下解压,解压完成效果如下图所示: ![](figures/sdk-structure.png) 配置Linux下的环境,如果只是在IDE中使用,跳过下面几步: 将NDK自带的CMake编译工具添加到环境变量中。 ``` #打开.bashrc文件 vim ~/.bashrc #在文件最后添加CMake路径,具体路径用实际放置SDK路径代替 export PATH=~/ohos-sdk/ohos-sdk/linux/native/build-tools/cmake/bin:$PATH #在命令行执行source ~/.bashrc使环境变量生效 source ~/.bashrc ``` 查看CMake默认路径。 ``` #在命令行输入which命令查询当前CMake所在路径 which cmake #结果路径与.bashrc中设置一致 ~/ohos-sdk/ohos-sdk/linux/native/build-tools/cmake/bin/cmake ``` ## 如何使用Native API开发包编译一个native程序 应用开发者可以通过Native API开发包快速的开发出native动态库,静态库与可执行文件,ArkUI应用程序框架可以通过NAPI框架调用到native的动态库中。开发包提供CMake作为官方的编译构建工具。下面通过编写一个C/C++ demo工程来演示如何使用Native API开发包来编译C/C++动态库。 ### NDK中的文件夹简介 #### build目录中工具链文件ohos.toolchain.cmake CMake编译时需要读取该文件中的默认值,比如编译器架构、C++库链接方式等,这个需要在编译时通过CMAKE_TOOLCHAIN_FILE指出该文件的路径,便于CMake在编译时定位到该文件。在编译的时候需要为CMake指定参数来控制编译目标的属性,具体要指定的参数在下面的[命令行构建](#命令行构建)会具体介绍。 #### build-tools文件夹放的是NDK提供的编译工具 ``` #键入下一行命令查看CMake的版本 cmake -version #结果 cmake version 3.16.5 CMake suite maintained and supported by Kitware (kitware.com/cmake). ``` #### llvm文件夹放的是NDK提供的编译器 ![](figures/images.png) ### NDK使用的简单demo #### demo目录图 ``` demo ├── CMakeLists.txt ├── include └── sum.h └── src ├── CMakeLists.txt ├── sum.cpp └── hello.cpp ``` #### CMakeLists.txt内容 ``` # 指定CMake的最小版本 CMAKE_MINIMUM_REQUIRED(VERSION 3.16) # 工程名称,这里我们就叫HELLO PROJECT(HELLO) #添加一个子目录并构建该子目录。 ADD_SUBDIRECTORY(src bin) ``` #### 内部CMakeLists.txt内容 ``` SET(LIBHELLO_SRC hello.cpp) # 设置编译参数 SET(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -O0") # 设置链接参数,具体参数可以忽略,纯粹为了举例 SET(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} -Wl,--emit-relocs --verbose") # 添加一个libsum动态库目标,编译成功会生成一个libsum.so ADD_LIBRARY(sum SHARED sum.cpp) # 生成可执行程序,添加一个Hello的可执行程序目标,编译成功会生成一个Hello可执行程序 ADD_EXECUTABLE(Hello ${LIBHELLO_SRC}) # 指定Hello目标include目录路径 TARGET_INCLUDE_DIRECTORIES(Hello PUBLIC ../include) # 指定Hello目标需要链接的库名字 TARGET_LINK_LIBRARIES(Hello PUBLIC sum) ``` 详细CMake手册参考 https://cmake.org/cmake/help/v3.16/guide/tutorial/ 。 #### 源码内容 hello.cpp 源码 ``` #include #include "sum.h" int main(int argc,const char **argv) { std::cout<< "hello world!" <