指定可选配置
您可以在模块级 build.gradle 文件的 defaultConfig {} 块中配置另一个 externalNativeBuild {} 块,为 CMake指定可选参数和标志。
android {
...
defaultConfig {
...
externalNativeBuild {
cmake {
// 配置CMake可选参数
arguments "-DANDROID_ARM_NEON=TRUE", "-DANDROID_TOOLCHAIN=clang"
// 为C 编译器设置可选 flags
cFlags "-D_EXAMPLE_C_FLAG1", "-D_EXAMPLE_C_FLAG2"
// 为c++编译器设置flag :使支持格式化 macro constants
cppFlags "-D__STDC_FORMAT_MACROS"
}
}
}
}
与 defaultConfig {} 块中的其他属性类似,您也可以在构建配置中为每个产品风味重写这些属性。
android {
productFlavors {
...
demo {
...
externalNativeBuild {
cmake {
...
// 针对项目中有多个原生库,不同的flavor用不同的库就可以这样指定,如果不指定gradle会为所有的flavor构建所有的库
targets "native-lib-demo"
}
}
}
paid {
...
externalNativeBuild {
cmake {
...
targets "native-lib-paid"
}
}
}
}
}
指定 ABI
默认情况下,Gradle 会针对 NDK 支持的 所有ABI将您的原生库构建到单独的 .so文件中,并将其全部封装到您的 APK 中。如果您希望 Gradle 仅构建和封装原生库的特定 ABI 配置,您可以在模块级 build.gradle 文件中使用 ndk.abiFilters
标志指定这些配置,如下所示:
android {
...
defaultConfig {
...
ndk {
// Specifies the ABI configurations of your native
// libraries Gradle should build and package with your APK.
abiFilters 'x86', 'x86_64', 'armeabi', 'armeabi-v7a',
'arm64-v8a'
}
}
}
**配置ABI拆分
把一个apk拆成几个apk,每个apk仅包含特定的ABI
android {
...
splits {
abi {
enable true
// include和exclude之前先reset一下
reset()
// 指定只包含的abi库
include "x86", "armeabi-v7a", "mips"
// 指定不产生一个包含所有abi的apk
universalApk false
}
}
}
==========================================================
eclipse时代玩过ndk,现在studio时代,应该是大同小异,使用各自的工具,遵守各自的规则即可;参照官网,进行提炼,总结,学习计划如下(本系列只关注cmake,如需学习ndk-build,请自行查阅其他资料):
jni相关,未完待续…
官网参考链接
https://developer.android.google.cn/studio/projects/add-native-code.html