기사 디렉토리
I. CMake 소개
. 1 CMake 소개 :
① 빌드 도구 : CMake 안드로이드 C / C ++ 빌드 도구 기본 기본 라이브러리에 사용된다;
크로스 플랫폼 ② : CMake 제작 도구 플랫폼은 다른 유형이 될 수 크로스 플랫폼이며, 컴파일러의 종류는 대응 메이크 생성;
③ 자연 : CMake 직접 프로젝트를 컴파일하지만, 빌드 스크립트를 생성 할 수 있도록 메이크 파일 또는 프로젝트를 빌드하기 위해 사용하는 메이크업을 대응
안드로이드 생성 ③ 스크립트 : 안드로이드 Studio에서, CMake 스크립트를 생성 닌자, 닌자 빠르게 구축 할 수있는 경량의 도구입니다 (참조 용으로 만 사용)
. 2 CMake 및 Android.mk : Android.mk를위한 Google 점차 포기 지원은 현재 지역 도서관을 구축 CMake 새로운 프로젝트에 대한 추천, 이전 프로젝트 제안 것이다 Android.mk CMake 빌드로, 더 나은 코드를 유지 보수;
II. 정적 라이브러리 프로세스에서 안드로이드 스튜디오 CMake를 도입
정적 라이브러리 CMake 도입 과정에서 안드로이드 스튜디오 :
. 1 build.gradle CMake 컴파일러 구성 옵션 : 모듈 수준 build.gradle 스크립트의 구성 CMake 컴파일러 옵션을;
// I . NDK 配置 1 : 配置 AS 工程中的 C/C++ 源文件的编译
// defaultConfig 内部的 externalNativeBuild 配置的是配置 AS 工程的 C/C++ 源文件编译参数
// defaultConfig 外部的 externalNativeBuild 配置的是 CMakeList.txt 或 Android1.mk 构建脚本的路径
externalNativeBuild {
cmake {
cppFlags ""
//配置编译 C/C++ 源文件为哪几个 CPU 指令集的函数库 (arm , x86 等)
abiFilters "armeabi-v7a"
}
/*ndkBuild{
abiFilters "armeabi-v7a" *//*, "arm64-v8a", "x86", "x86_64"*//*
}*/
}
. 2 build.gradle 구성 NDK 패키징 옵션 : 구성 NDK는 모듈 수준 build.gradle 스크립트의 옵션을 포장;
// II . NDK 配置 2 : 配置 AS 工程中的 C/C++ 源文件的编译
//配置 APK 打包 哪些动态库
// 示例 : 如在工程中集成了第三方库 , 其提供了 arm, x86, mips 等指令集的动态库
// 那么为了控制打包后的应用大小, 可以选择性打包一些库 , 此处就是进行该配置
ndk{
// 打包生成的 APK 文件指挥包含 ARM 指令集的动态库
abiFilters "armeabi-v7a" /*, "arm64-v8a", "x86", "x86_64"*/
}
. 3 build.gradle CMake 빌드 스크립트 CMakeList.txt 경로 구성 : 구성 모듈 Android.mk 스크립트에 빌드 스크립트 build.gradle 수준 경로;
// III . NDK 配置 : 配置 AS 工程中的 C/C++ 源文件的编译构建脚本
// 配置 NDK 的编译脚本路径
// 编译脚本有两种 ① CMakeList.txt ② Android1.mk
// defaultConfig 内部的 externalNativeBuild 配置的是配置 AS 工程的 C/C++ 源文件编译参数
// defaultConfig 外部的 externalNativeBuild 配置的是 CMakeList.txt 或 Android1.mk 构建脚本的路径
externalNativeBuild {
// 配置 CMake 构建脚本 CMakeLists.txt 脚本路径
cmake {
path "src/main/cpp/CMakeLists.txt"
version "3.10.2"
}
// 配置 Android1.mk 构建脚本路径
/*ndkBuild{
//path "src/main/ndkBuild_Shared/Android.mk"
path "src/main/ndkBuild_Static/Android.mk"
}*/
}
. 4 CMake 빌드 스크립트는 정적 라이브러리를 도입 CMakeList.txt :
# 引入静态库
# ① 参数 1 ( add ) : 设置引入的静态库名称
# ② 参数 2 ( SHARED ) : 设置引入的函数库类型 : ① 静态库 STATIC ② 动态库 SHARED
# ③ 参数 3 ( IMPORTED ) : 表示引入第三方静态库 , 导入静态库 , 相当于预编译静态库
# 后续还需要设置导入路径 , 配合该配置使用
add_library(
# 设置引入的静态库名称
add
# 设置引入的函数库类型为静态库
STATIC
# 表示引入第三方静态库
IMPORTED)
. 5 CMake 빌드 스크립트 CMakeList.txt은 정적 라이브러리 경로를 설정 :
# 设置上述静态库的导入路径
# 设置目标属性参数 :
# ① 参数 1 ( add ) : 要设置哪个函数库的属性
# ② 参数 2 ( PROPERTIES ) : 设置目标属性
# ③ 参数 3 ( IMPORTED_LOCATION ) : 设置导入路径
# ④ 参数 4 : 配置静态库的文件路径
set_target_properties(
# 设置目标
add
# 设置属性
PROPERTIES
# 导入路径
IMPORTED_LOCATION
# ${CMAKE_SOURCE_DIR} 是本 CMakeList.txt 构建脚本的路径 , 是 CMake 工具内置的变量
# Android CMake 也内置了一些变量 , 如 ANDROID_ABI
${CMAKE_SOURCE_DIR}/../jniLibs/armeabi-v7a/libadd.a)
. 6 CMake 빌드 스크립트 CMakeList.txt 링크 정적 라이브러리 :
# 链接函数库
# 参数 1 : 本构建脚本要生成的动态库目 标
# 参数 2 ~ ... : 后面是之前预编译的动态库或静态库 , 或引入的动态库
target_link_libraries(
native-lib
# 表示 编译 native-lib 模块, 要链接 add 模块
add
${log-lib})
III. CMake는 최소 버전 번호를 지정
지정 CMake의 최소 버전 : 에서 CMakeList.txt CMake 빌드 스크립트 파일, CMake는 반드시 최소 버전 번호를 지정하는 첫 번째 줄;
cmake_minimum_required(VERSION 3.4.1)
IV. 임포트 라이브러리 (정적 라이브러리 / 동적 라이브러리) 구성 컴파일
라이브러리 (정적 라이브러리 / DLL) 컴파일 된 구성 : 세 개의 매개 변수를 전달하는 라이브러리 컴파일러 필요성
① 1 파라미터 : 동적 라이브러리 이름의 세트가 생성;
② 파라미터 2 : 제공되는 라이브러리 생성 타입 : DLL SHARED B 정적 라이브러리 STATIC; ..
③ 매개 변수 3 : 구성 소스 파일을 컴파일하려면,
# 引入静态库
# ① 参数 1 ( add ) : 设置引入的静态库名称
# ② 参数 2 ( SHARED ) : 设置引入的函数库类型 : ① 静态库 STATIC ② 动态库 SHARED
# ③ 参数 3 ( IMPORTED ) : 表示引入第三方静态库 , 导入静态库 , 相当于预编译静态库
# 后续还需要设置导入路径 , 配合该配置使用
add_library(
# 设置引入的静态库名称
add
# 设置引入的函数库类型为静态库
STATIC
# 表示引入第三方静态库
IMPORTED)
2. 특별한주의 : 이 방법을 소개하는 동적 라이브러리의 사용은 시스템 이상 6.0 사용하지 않는 것이 좋습니다 세트 () -L 매개 변수 모드 동적 오브젝트가 도입 설정하는 단계;
# 设置变量
# CMAKE_CXX_FLAGS 表示会将 C++ 的参数传给编译器
# CMAKE_C_FLAGS 表示会将 C 参数传给编译器
# 参数设置 : 传递 CMAKE_CXX_FLAGS C+= 参数给编译器时 , 在 该参数后面指定库的路径
# CMAKE_SOURCE_DIR 指的是当前的文件地址
# -L 参数指定动态库的查找路径
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -L${CMAKE_SOURCE_DIR}/../jniLibs/armeabi-v7a")
타사 라이브러리의 V. 경로 구성
타사 라이브러리의 경로 구성 : 라이브러리 경로 set_target_properties ()를 호출하여 제 3자를 설정하는 단계;
① 파라미터 1 (추가) 설정 될 라이브러리 속성;
② 2 파라미터 (특성) : 목표 특성을 설정하는 단계;
③ 3 파라미터 (IMPORTED_LOCATION) 세트 도입 통로;
④ 매개 변수 4 : 구성 파일 경로 정적 라이브러리;
# 设置上述静态库的导入路径
# 设置目标属性参数 :
# ① 参数 1 ( add ) : 要设置哪个函数库的属性
# ② 参数 2 ( PROPERTIES ) : 设置目标属性
# ③ 参数 3 ( IMPORTED_LOCATION ) : 设置导入路径
# ④ 参数 4 : 配置静态库的文件路径
set_target_properties(
# 设置目标
add
# 设置属性
PROPERTIES
# 导入路径
IMPORTED_LOCATION
# ${CMAKE_SOURCE_DIR} 是本 CMakeList.txt 构建脚本的路径 , 是 CMake 工具内置的变量
# Android CMake 也内置了一些变量 , 如 ANDROID_ABI
${CMAKE_SOURCE_DIR}/../jniLibs/armeabi-v7a/libadd.a)
VI. 출력 로그 정보
전화 메시지 () 메서드를 출력 할 수 로그 정보 :
# 打印日志信息
# ${ANDROID_ABI} 的作用是获取当前的 CPU 指令集架构
# 当本次编译 armeabi-v7a CPU 架构时 , ${ANDROID_ABI} 值为 armeabi-v7a
# 当本次编译 x86 CPU 架构时 , ${ANDROID_ABI} 值为 x86
message("CMAKE_SOURCE_DIR : ${CMAKE_SOURCE_DIR}, ANDROID_ABI : ${ANDROID_ABI}")
VII. 링크 라이브러리
링크 라이브러리 : 여기에 첫 번째 인수는 동적 라이브러리 모듈을 생성해야합니다;
# 链接函数库
# 参数 1 : 本构建脚本要生成的动态库目标
# 参数 2 ~ ... : 后面是之前预编译的动态库或静态库 , 或引入的动态库
target_link_libraries(
native-lib
# 表示 编译 native-lib 模块, 要链接 add 模块
add
${log-lib})
VIII. 전체 구성 코드 build.gradle 모듈 수준
apply plugin: 'com.android.application'
android {
compileSdkVersion 29
buildToolsVersion "29.0.0"
defaultConfig {
applicationId "kim.hsl.cmake"
minSdkVersion 15
targetSdkVersion 29
versionCode 1
versionName "1.0"
testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
// I . NDK 配置 1 : 配置 AS 工程中的 C/C++ 源文件的编译
// defaultConfig 内部的 externalNativeBuild 配置的是配置 AS 工程的 C/C++ 源文件编译参数
// defaultConfig 外部的 externalNativeBuild 配置的是 CMakeList.txt 或 Android1.mk 构建脚本的路径
externalNativeBuild {
cmake {
cppFlags ""
//配置编译 C/C++ 源文件为哪几个 CPU 指令集的函数库 (arm , x86 等)
abiFilters "armeabi-v7a"
}
/*ndkBuild{
abiFilters "armeabi-v7a" *//*, "arm64-v8a", "x86", "x86_64"*//*
}*/
}
// II . NDK 配置 2 : 配置 AS 工程中的 C/C++ 源文件的编译
//配置 APK 打包 哪些动态库
// 示例 : 如在工程中集成了第三方库 , 其提供了 arm, x86, mips 等指令集的动态库
// 那么为了控制打包后的应用大小, 可以选择性打包一些库 , 此处就是进行该配置
ndk{
// 打包生成的 APK 文件指挥包含 ARM 指令集的动态库
abiFilters "armeabi-v7a" /*, "arm64-v8a", "x86", "x86_64"*/
}
}
// III . NDK 配置 : 配置 AS 工程中的 C/C++ 源文件的编译构建脚本
// 配置 NDK 的编译脚本路径
// 编译脚本有两种 ① CMakeList.txt ② Android1.mk
// defaultConfig 内部的 externalNativeBuild 配置的是配置 AS 工程的 C/C++ 源文件编译参数
// defaultConfig 外部的 externalNativeBuild 配置的是 CMakeList.txt 或 Android1.mk 构建脚本的路径
externalNativeBuild {
// 配置 CMake 构建脚本 CMakeLists.txt 脚本路径
cmake {
path "src/main/cpp/CMakeLists.txt"
version "3.10.2"
}
// 配置 Android1.mk 构建脚本路径
/*ndkBuild{
//path "src/main/ndkBuild_Shared/Android.mk"
path "src/main/ndkBuild_Static/Android.mk"
}*/
}
buildTypes {
release {
minifyEnabled false
proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'
}
}
}
dependencies {
implementation fileTree(dir: 'libs', include: ['*.jar'])
implementation 'androidx.appcompat:appcompat:1.1.0'
implementation 'androidx.constraintlayout:constraintlayout:1.1.3'
testImplementation 'junit:junit:4.12'
androidTestImplementation 'androidx.test:runner:1.2.0'
androidTestImplementation 'androidx.test.espresso:espresso-core:3.2.0'
}
IX. CMakeList.txt 전체 구성 코드
# 指定 CMake 最低版本
cmake_minimum_required(VERSION 3.4.1)
# 设置函数库编译
add_library( # 参数 1 : 设置生成的动态库名称
native-lib
# 参数 2 : 设置生成的函数库类型 : ① 静态库 STATIC ② 动态库 SHARED
SHARED
# 参数 3 : 配置要编译的源文件
native-lib.cpp)
# 引入静态库
# ① 参数 1 ( add ) : 设置引入的静态库名称
# ② 参数 2 ( SHARED ) : 设置引入的函数库类型 : ① 静态库 STATIC ② 动态库 SHARED
# ③ 参数 3 ( IMPORTED ) : 表示引入第三方静态库 , 导入静态库 , 相当于预编译静态库
# 后续还需要设置导入路径 , 配合该配置使用
add_library(
# 设置引入的静态库名称
add
# 设置引入的函数库类型为静态库
STATIC
# 表示引入第三方静态库
IMPORTED)
# 设置上述静态库的导入路径
# 设置目标属性参数 :
# ① 参数 1 ( add ) : 要设置哪个函数库的属性
# ② 参数 2 ( PROPERTIES ) : 设置目标属性
# ③ 参数 3 ( IMPORTED_LOCATION ) : 设置导入路径
# ④ 参数 4 : 配置静态库的文件路径
set_target_properties(
# 设置目标
add
# 设置属性
PROPERTIES
# 导入路径
IMPORTED_LOCATION
# ${CMAKE_SOURCE_DIR} 是本 CMakeList.txt 构建脚本的路径 , 是 CMake 工具内置的变量
# Android CMake 也内置了一些变量 , 如 ANDROID_ABI
${CMAKE_SOURCE_DIR}/../jniLibs/armeabi-v7a/libadd.a)
# 打印日志信息
# ${ANDROID_ABI} 的作用是获取当前的 CPU 指令集架构
# 当本次编译 armeabi-v7a CPU 架构时 , ${ANDROID_ABI} 值为 armeabi-v7a
# 当本次编译 x86 CPU 架构时 , ${ANDROID_ABI} 值为 x86
message("CMAKE_SOURCE_DIR : ${CMAKE_SOURCE_DIR}, ANDROID_ABI : ${ANDROID_ABI}")
# 到预设的目录查找 log 库 , 将找到的路径赋值给 log-lib
# 这个路径是 NDK 的 ndk-bundle\platforms\android-29\arch-arm\usr\lib\liblog.so
# 不同的 Android 版本号 和 CPU 架构 需要到对应的目录中查找 , 此处是 29 版本 32 位 ARM 架构的日志库
find_library(
log-lib
log)
# 设置变量
# CMAKE_CXX_FLAGS 表示会将 C++ 的参数传给编译器
# CMAKE_C_FLAGS 表示会将 C 参数传给编译器
# 参数设置 : 传递 CMAKE_CXX_FLAGS C+= 参数给编译器时 , 在 该参数后面指定库的路径
# CMAKE_SOURCE_DIR 指的是当前的文件地址
# -L 参数指定动态库的查找路径
#set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -L${CMAKE_SOURCE_DIR}/../jniLibs/armeabi-v7a")
# 链接函数库
# 参数 1 : 本构建脚本要生成的动态库目 标
# 参数 2 ~ ... : 后面是之前预编译的动态库或静态库 , 或引入的动态库
target_link_libraries(
native-lib
# 表示 编译 native-lib 模块, 要链接 add 模块
add
${log-lib})
X. 블로그 자원
CSDN 블로그 주소 : [개발] 안드로이드 NDK 안드로이드 스튜디오 CMake 수입 정적 라이브러리를 사용하는 (CMake 소개 | 빌드 스크립트 경로 구성 | 수입 정적 라이브러리 | 정적 라이브러리 경로를 지정 | 동적 링크 라이브러리)
블로그 자료 다운로드 : https://download.csdn.net/download/han1202012/12162132
샘플 코드 GitHub의 주소 : https://github.com/han1202012/008_NDK_CMake_Static