因爲工作需要,經常要開發和合入系統App,所以在此開篇作爲收集和記錄Android合入系統應用的方法,以備日後查閱。
一、預置apk方法
Case 1:如何將帶源碼的APK預置進系統
- 在 packages/apps 下面以需要預置的 APK的 名字創建一個新文件夾,以預置一個名爲Test的APK 爲例
- 將 Test APK的Source code 拷貝到 Test 文件夾下,刪除 /bin 和 /gen 目錄
- 在 Test 目錄下創建一個名爲 Android.mk的文件,內容如下:
-
LOCAL_PATH:= $(call my-dir)
-
include $(CLEAR_VARS)
-
LOCAL_MODULE_TAGS := optional
-
LOCAL_SRC_FILES := $(call all-subdir-java-files)
-
LOCAL_PACKAGE_NAME := Test
-
include $(BUILD_PACKAGE)
- 打開文件 device\mediatek\common\device.mk,將 Test 添加到 PRODUCT_PACKAGES 裏面。
PRODUCT_PACKAGES += Test
- 重新 build 整個工程
Case 2:如何將無源碼的 APK 預置進系統?
- 在 packages/apps 下面以需要預置的 APK 名字創建文件夾,以預置一個名爲Test的APK爲例
- 將 Test.apk 放到 packages/apps/Test 下面
- 在 packages/apps/Test 下面創建文件 Android.mk,文件內容如下:
-
LOCAL_PATH := $(call my-dir)
-
include $(CLEAR_VARS)
-
# Module name should match apk name to be installed
-
LOCAL_MODULE := Test
-
LOCAL_MODULE_TAGS := optional
-
LOCAL_SRC_FILES := $(LOCAL_MODULE).apk
-
LOCAL_MODULE_CLASS := APPS
-
LOCAL_MODULE_SUFFIX := $(COMMON_ANDROID_PACKAGE_SUFFIX)
-
LOCAL_PREBUILT_JNI_LIBS:= \
-
@lib/armeabi/libtest.so \
-
@lib/armeabi/libtest2.so
-
LOCAL_CERTIFICATE := PRESIGNED
-
include $(BUILD_PREBUILT)
若無so,刪除LOCAL_PREBUILT_JNI_LIBS
若有so,使用LOCAL_PREBUILT_JNI_LIBS列出所有so的路徑,不要忘記使用@。@標識符會將apk中的so抽離出來build進apk同級目錄下的lib文件夾中
若apk支持不同cpu類型的so,針對so的部分的處理:
-
Ifeq ($(TARGET_ARCH),arm)
-
LOCAL_PREBUILT_JNI_LIBS := \
-
@lib/armeabi-v7a/xxx.so\
-
@ lib/armeabi-v7a/xxxx.so
-
else ifeq ($(TARGET_ARCH),x86)
-
LOCAL_PREBUILT_JNI_LIBS := \
-
@lib/x86/xxx.so
-
else ifeq ($(TARGET_ARCH),arm64)
-
LOCAL_PREBUILT_JNI_LIBS := \
-
@lib/armeabi-v8a/xxx.so
-
…
即將和TARGET_ARCH對應的so抽離出來
- 打開文件 device\mediatek\common\device.mk
將 Test 添加到 PRODUCT_PACKAGES 裏面。
PRODUCT_PACKAGES += Test - 重新 build 整個工程
tip:
如果App使用System Level的permission,需要預置到/system/priv-app底下 (原在/system/app)。
修改Android.mk,增加LOCAL_PRIVILEGED_MODULE := true,以聲明app需要放在/system/priv-app下。
Case 3:如何預置APK使得用戶可以卸載,恢復出廠設置時不能恢復?
- 在 packages/apps 下面以需要預置的 APK 名字創建文件夾,以預置一個名爲Test的APK爲例
- 將 Test.apk 放到 packages/apps/Test 下面
- 在 packages/apps/Test 下面創建文件 Android.mk,文件內容如下:
-
LOCAL_PATH := $(call my-dir)
-
include $(CLEAR_VARS)
-
# Module name should match apk name to be installed
-
LOCAL_MODULE := Test
-
LOCAL_MODULE_TAGS := optional
-
LOCAL_SRC_FILES := $(LOCAL_MODULE).apk
-
LOCAL_MODULE_CLASS := APPS
-
LOCAL_MODULE_SUFFIX := $(COMMON_ANDROID_PACKAGE_SUFFIX)
-
# LOCAL_PRIVILEGED_MODULE := true
-
LOCAL_MODULE_PATH := $(TARGET_OUT_DATA_APPS)
-
LOCAL_CERTIFICATE := PRESIGNED
-
include $(BUILD_PREBUILT)
- 打開文件 device\mediatek\common\device.mk
將 Test 添加到 PRODUCT_PACKAGES 裏面。
PRODUCT_PACKAGES += Test
- 重新 build 整個工程
注意:這個比不能卸載的多了一句
-
LOCAL_MODULE_PATH := $(TARGET_OUT_DATA_APPS)
Case 4:如何預置APK使得用戶可以卸載,並且恢復出廠設置時能夠恢復?
- 在 vendor\mediatek\proprietary\binary\3rd-party\free下面以需要預置的 APK 名字創建文件夾,以預置一個名爲Test的APK爲例
- 將Test.apk 放入vendor\mediatek\proprietary\binary\3rd-party\free\Test下面
- 在vendor\mediatek\proprietary\binary\3rd-party\free\Test 下面創建文件 Android.mk,文件內容如下:
-
LOCAL_PATH := $(call my-dir)
-
include $(CLEAR_VARS)
-
# Module name should match apk name to be installed
-
LOCAL_MODULE := Test
-
LOCAL_MODULE_TAGS := optional
-
LOCAL_SRC_FILES := $(LOCAL_MODULE).apk
-
LOCAL_MODULE_CLASS := APPS
-
LOCAL_MODULE_SUFFIX := $(COMMON_ANDROID_PACKAGE_SUFFIX)
-
LOCAL_CERTIFICATE := PRESIGNED
-
LOCAL_MODULE_PATH := $(TARGET_OUT)/vendor/operator/app
-
include $(BUILD_PREBUILT)
- 打開文件device\mediatek\common\device.mk
將 Test 添加到 PRODUCT_PACKAGES 裏面。
PRODUCT_PACKAGES += Test
- 然後重新build整個工程
若需要apk作爲32bit的apk運行,則需要在Android.mk中定義
LOCAL_MULTILIB :=32
二、Android.mk文件參數說明
LOCAL_MODULE_TAGS := optional | optional,指該模塊在所有版本下都編譯 |
---|---|
LOCAL_SRC_FILES := $(LOCAL_MODULE).apk | 獲取目錄下的java文件 |
LOCAL_PACKAGE_NAME := Test | 包名 |
LOCAL_CERTIFICATE := platform | 簽名,PRESIGNED表示保留apk文件之前的簽名,platform是對apk重新進行簽名 |
LOCAL_PROGUARD_ENABLED := disabled | 不要使用代碼混淆的工具進行混淆 |