一.前言
在Android10之后,所有项目工程中,官方推荐使用Android.bp去编译构建,以前使用Android.mk构建的项目随着版本迭代升级,慢慢需要变更为Android.bp, 两者的语法都需要去了解并熟练使用。 笔者之前写过Android.mk的语句介绍,里面有介绍每句代码的含义编写Android.mk把Android studio项目编译到AOSP源码中
后来也总结过 Android.bp基本用法: Android.bp 语法和使用 比较基础,也是在项目中运用到了就记录下来。
本篇文章写的是在项目工程中编写Android.mk和 Android.bp 文件,引入第三方的jar包,aar包, so库,引入特许白名单权限xml文件。
二. Android.mk 编写
1. 引入jar包
比如,我们当前目录下的 libs 有okhttp-3.4.11.jar 包,我想引用它
需要两个步骤
第一步, 声明我们 jar 包所在的目录,我的是AndroidStudio工程目录,所以jar包的路径是app/libs/okhttp-3.4.11.jar
LOCAL_PREBUILT_STATIC_JAVA_LIBRARIES := okhttp3:app/libs/okhttp-3.4.11.jar
这行代码的意思大概可以理解成这样,声明一个变量 okhttp3,它的 value 是 app/libs/okhttp-3.4.11.jar
include $(CLEAR_VARS)
LOCAL_PREBUILT_STATIC_JAVA_LIBRARIES := okhttp3:app/libs/okhttp-3.4.11.jar \
okio:app/libs/okio-1.9.0.jar
include $(BUILD_MULTI_PREBUILT) #这里是多个jar包预编译
第二步. 引用我们声明 jar 包的变量 引用我们上面声明的 okhttp3
LOCAL_STATIC_JAVA_LIBRARIES := okhttp3
LOCAL_STATIC_JAVA_LIBRARIES := okhttp3 \
okio
2. 引入aar包
第一步:先声明 aar 包的位置
include $(CLEAR_VARS)
LOCAL_PREBUILT_STATIC_JAVA_LIBRARIES := \
lottie-2.8.0:app/libs/lottie-2.8.0.aar
include $(BUILD_MULTI_PREBUILT)
第二步:引用声明的 aar 变量 lottie-2.8.0
LOCAL_STATIC_JAVA_AAR_LIBRARIES := lottie-2.8.0
第三步:添加引用的 aar 包资源
LOCAL_AAPT_FLAGS := \
--auto-add-overlay \
--extra-packages com.airbnb.lottie
3. 引入so库
假如我们当前目录下的 lib 目录下 有 armeabi-v7a,arm64-v8a 目录,里面分别有 libaes-jni.so, 如果我们在编译 apk 的时候,想把这些 so 库 打包进去,在 mk 文件中要怎样配置呢?
第一步,直接在 mk 文件中配置以下内容,预编译处理
include $(CLEAR_VARS)
LOCAL_MODULE_TAGS := optional
#后缀
LOCAL_MODULE_SUFFIX := .so
#模块名
LOCAL_MODULE := libaes-jni
#编译到system/libs/目录下
LOCAL_MODULE_CLASS := SHARED_LIBRARIES
#另外一种写法,根据平台arm arm64 去选择编译对应的so文件
#ifeq ($(strip $(TARGET_ARCH)),arm64)
#LOCAL_SRC_FILES :=app/libs/arm64-v8a/libaes-jni.so
#else ifeq ($(strip $(TARGET_ARCH)),arm)
#LOCAL_SRC_FILES :=app/libs/armeabi-v7a/libaes-jni.so
#endif
#arm arm64都编译
LOCAL_SRC_FILES_arm :=app/libs/armeabi-v7a/libaes-jni.so
LOCAL_SRC_FILES_arm64 :=app/libs/arm64-v8a/libaes-jni.so
LOCAL_MODULE_TARGET_ARCHS:= arm arm64
LOCAL_MULTILIB := both
include $(BUILD_PREBUILT)
第二步: 引用目标 so 库
在include $(CLEAR_VARS) 和 include $(BUILD_PACKAGE) 之间添加以下内容
LOCAL_REQUIRED_MODULES := libaes-jni
#如果你写这句话 把这个libaes-jni.so 同时也打包 放在out/target/产品名路径/你的apk具体路径下/lib/#目录中
#LOCAL_JNI_SHARED_LIBRARIES := libaes-jni
备注:
LOCAL_MODULE_CLASS:(prebuilt)标识了所编译模块最后放置的位置,如果不指定,不会放到系统中。
LOCAL_MODULE_CLASS := ETC 放于system/etc目录
LOCAL_MODULE_CLASS := EXECUTABLES 放于/system/bin目录
LOCAL_MODULE_CLASS := SHARED_LIBRARIES 放在/system/lib目录
LOCAL_MODULE_CLASS := JAVA_LIBRARIES
LOCAL_MODULE_CLASS := STATIC_LIBRARIES
LOCAL_MODULE_CLASS := APPS 放在/system/app目录
LOCAL_JNI_SHARED_LIBRARIES变量主要是用在JNI的编译中,如果你要在你的Java代码中引用JNI中的共享库*.so,此变量就是共享库的名字。
那么你要注意的一点是:在你的Project根目录下的Android.mk中要定义此变量用来引用你要使用的JNI中的共享库*.so 定义了要包含的so库文件的名字,如果程序没有采用jni,就不需要
LOCAL_JNI_SHARED_LIBRARIES := libxxx 这样在编译的时候,NDK自动会把这个libxxx打包进apk; 放在out/target/产品名路径/你的apk具体路径下/lib/目录中
LOCAL_REQUIRED_MODULES 指定模块运行所依赖的模块(模块安装时将会同步安装它所依赖的模块)
4. 引入特许白名单权限xml
com.test.mtk.xml 内容:
<?xml version="1.0" encoding="utf-8"?>
<permissions>
<privapp-permissions package="com.test.mtk">
<permission name="android.permission.MASTER_CLEAR" />
</privapp-permissions>
</permissions>
第一步:预编译处理
######预编译priv-app 权限,输出路径为system/etc/permissions###########
# Permissions pre-grant
include $(CLEAR_VARS)
LOCAL_MODULE := com.test.mtk.xml
LOCAL_MODULE_CLASS := ETC
LOCAL_MODULE_PATH := $(TARGET_OUT_ETC)/permissions
LOCAL_SRC_FILES := $(LOCAL_MODULE)
include $(BUILD_PREBUILT)
第二步:指定app运行所依赖的模块
######编译priv-app 权限到apk中###########
LOCAL_REQUIRED_MODULES := com.test.mtk.xml