Android-NDK/JNI

Android NDK开发-CMake

2018-07-08  本文已影响17人  编码前线

概述

在Android Studio 2.2及更高的版本,可以使用CMake将C/C++代码编译到一个native library(即.so文件),然后打包到APK中。

在Gradle中配置CMake变量

android {
  ...
  defaultConfig {
    ...
    // 用于配置Cmake构建参数
    externalNativeBuild {
      cmake {
        ...
        // 将参数传递给变量时,请使用以下语法:
        // arguments "-DVAR_NAME=ARGUMENT".
        arguments "-DANDROID_ARM_NEON=TRUE",
        // 如果要将多个参数传递给变量, 使用以下语法一起传递:
        // arguments "-DVAR_NAME=ARG_1 ARG_2"
        // 下面一行将 'rtti' 和 'exceptions' 传递给 'ANDROID_CPP_FEATURES'.
                  "-DANDROID_CPP_FEATURES=rtti exceptions"
      }
    }
  }
  buildTypes {...}

  // 用于链接CMake脚本
  externalNativeBuild {
      cmake {
          path "CMakeLists.txt"
      }
  }
}

CMake部分构建变量列表:

变量名 参数 描述
ANDROID_TOOLCHAIN clang(默认) 指定CMake应该使用的编译器工具链
ANDROID_PLATFORM android-19 指定Android的目标平台
ANDROID_CPP_FEATURES 默认为空,可配置:<br />rtti(RunTime Type Information):运行时类型信息<br /> exceptions: 指示代码使用C++异常 指定CMake编译时需要使用某些C++特性
ANDROID_ARM_MODE thumb(默认)<br />arm 指定是arm还是以thumb模式生成ARM目标二进制库

CMake构建命令

Android Studio在cmake_build_command.txt文件中保存用于执行CMake构建的构建参数。

Android Studio会为每个ABI和每个构建类型创建cmake_build_command.txt,放置在如下目录:

<project-root>/<module-root>/.externalNativeBuild/cmake/<build-type>/<ABI>/

cmake_build_cmd.png

示例:debug模式下的armeabi-v7a的CMake构建命令

Executable : /Users/xch/Library/Android/sdk/cmake/3.6.4111459/bin/cmake
arguments : 
-H/Users/xch/debug/Android/NDKDemo2/app
-B/Users/xch/debug/Android/NDKDemo2/app/.externalNativeBuild/cmake/debug/armeabi-v7a
-DANDROID_ABI=armeabi-v7a
-DANDROID_PLATFORM=android-19
-DCMAKE_LIBRARY_OUTPUT_DIRECTORY=/Users/xch/debug/Android/NDKDemo2/app/build/intermediates/cmake/debug/obj/armeabi-v7a
-DCMAKE_BUILD_TYPE=Debug
-DANDROID_NDK=/Users/xch/Library/Android/sdk/ndk-bundle
-DCMAKE_CXX_FLAGS=-frtti -fexceptions
-DCMAKE_TOOLCHAIN_FILE=/Users/xch/Library/Android/sdk/ndk-bundle/build/cmake/android.toolchain.cmake
-DCMAKE_MAKE_PROGRAM=/Users/xch/Library/Android/sdk/cmake/3.6.4111459/bin/ninja
-GAndroid Gradle - Ninja
jvmArgs : 

这些构建参数是Gradle插件基于build.gradle的配置自动生成。

CMake构建参数列表:

构建参数 描述
-G <build-system> Android Gradle - Ninja是Android Studio唯一支持的C/C++构建系统.CMake会生成android_gradle_build.json文件。 其中包含有关CMake构建的Gradle插件的元数据,例如编译器标志和目标名称。
-DANDROID_ABI <abi> 目标ABI
-DCMAKE_LIBRARY_OUTPUT_DIRECTORY <path> CMake生成的库的位置
-DCMAKE_TOOLCHAIN_FILE <path> CMake用于交叉编译的android.toolchain.cmake文件的路径

CMakeList.txt文件说明

# 指定CMake编译器的最低版本
cmake_minimum_required(VERSION 3.4.1)

# 要求CMake根据指定的源文件生成库
add_library( # 生成的库的名称
             native-lib

             # 设置生成的库的类型
             SHARED

             # 所有需要加入到这个库的源文件
             src/main/cpp/native-lib.cpp )

# 如果需要使用系统预构建库,可以使用该方法来查找,比如这里的log库
find_library( # 该变量保存所要关联库的路径
              log-lib

              # 需要关联的库名称
              log )

# 指定需要关联的库
target_link_libraries( # 目标库文件
                       native-lib

                       # 需要在目标库文件中使用的库
                       ${log-lib} )

在上面使用add_library来添加系统的预构建库。如果要添加其他的非系统的预构建库,比较FFmpeg的相关库,需要按如下格式:

# 添加第三方非系统预构建库
add_library( # 导入的库的名称
             imported-lib
            
             # 导入的库的类型
             SHARED
            
             # 表示是导入第三方库
             IMPORTED )

# 指定库的路径
set_target_properties( # 指定导入的库的名称
                       imported-lib

                       # Specifies the parameter you want to define.
                       PROPERTIES IMPORTED_LOCATION

                       # 指定要导入的库的路径
                       imported-lib/src/${ANDROID_ABI}/libimported-lib.so )

# 包含头文件的路径
include_directories( imported-lib/include/ ) 

如果要显示执行构建过程中的详细信息,比如为了得到更详细的出错信息。

# 开启输出详细的编译和链接信息
set(CMAKE_VERBOSE_MAKEFILE on)

message("要打印的信息")

自定义变量

set(变量名 变量值)

常用变量

# 引用变量格式:${变量名}

# 工程的源文件目录
PROJECT_SOURCE_DIR 
# CMakeList.txt文件所在的目录
CMAKE_SOURCE_DIR

参考链接

  1. CMake
  2. 使用 CMake 进行 NDK 开发之如何编写 CMakeLists txt 脚本
  3. JNI和NDK编程-使用AndroidStudio进行NDK开发
  4. Android NDK开发扫盲及最新CMake的编译使用
  5. cmake-commands
  6. 通过CMake来进行ndk开发之补充篇
    编码前线.jpg
上一篇下一篇

猜你喜欢

热点阅读