赞
踩
对于64位系统的编译规则,可参考:http://source.android.com/source/64-bit-builds.html
实际工程中,我们通常会遇到下面这样的场景:
A. APK有源码,SO库有源码 - 应用及so库我们都能自己编译出来
B. APK有源码,SO库没有源码 - 我们开发的应用使用了第三方的so库,如ScanService
C. APK和SO库都没有源码 - 预置第三方的应用(应用中包括so库)
只要我们编译默认对应的APP和SO库(32bit+64bit)即可。
此种场景最为普通,本文不做详细讲解。
如果APK需要加载的库里面有64bit的,则需要全部的库都使用64bit。
如果APK调用的第三方so库中有32bit的,则:要么让第三方提供64bit版本的so库,要么强制使所以的so库都使用32bit版本。
使用特定的预置规则即可。
- LOCAL_PATH:= $(call my-dir)
- include $(CLEAR_VARS)
- LOCAL_MODULE_TAGS := optional
- LOCAL_CERTIFICATE := platform
- LOCAL_SRC_FILES := $(call all-subdir-java-files)
- LOCAL_JAVA_LIBRARIES := odm conscrypt sp
- LOCAL_PACKAGE_NAME := PosService
-
- # to support on 64-bit system
- LOCAL_JNI_SHARED_LIBRARIES := \
- libmiscjni \
- libttyjni \
- libIAL \
- libSDL \
- libbarcodereader \
- libHsmKil \
- libHHPScanInterface \
- libHSMDecoderAPI
- LOCAL_MULTILIB := 32
-
- include $(BUILD_PACKAGE)

其中某个本地编译so的规则:
- LOCAL_PATH := $(call my-dir)
- include $(CLEAR_VARS)
- LOCAL_SRC_FILES := \
- com_odm_tty.cpp
- LOCAL_C_INCLUDES := $(JNI_H_INCLUDE)
- LOCAL_SHARED_LIBRARIES := \
- libcutils \
- libutils
- LOCAL_PRELINK_MODULE := false
- LOCAL_MODULE_TAGS := optional
- LOCAL_MODULE := libttyjni
- LOCAL_MULTILIB := 32
- include $(BUILD_SHARED_LIBRARY)
某个第三方so的规则:
- LOCAL_PATH := $(call my-dir)
-
- include $(CLEAR_VARS)
- LOCAL_MODULE_TAGS := optional
- LOCAL_MODULE_CLASS := SHARED_LIBRARIES
- LOCAL_MODULE_SUFFIX := .so
- LOCAL_MODULE := libHHPScanInterface
- LOCAL_SRC_FILES := $(LOCAL_MODULE).so
- LOCAL_MODULE_PATH := $(TARGET_OUT)/lib
- LOCAL_MULTILIB := 32
- include $(BUILD_PREBUILT)
- LOCAL_PATH := $(my-dir)
- include $(CLEAR_VARS)
- LOCAL_MODULE := BaiduIME
- LOCAL_MODULE_TAGS := optional
- LOCAL_SRC_FILES := baidu_input_for_xiaomiV5.apk
- LOCAL_MODULE_CLASS := APPS
- LOCAL_MODULE_SUFFIX := $(COMMON_ANDROID_PACKAGE_SUFFIX)
- LOCAL_CERTIFICATE := PRESIGNED
- LOCAL_MULTILIB := 32
- LOCAL_PREBUILT_JNI_LIBS := \
- @lib/armeabi/libBDVoiceRecognitionClient_V1.so \
- @lib/armeabi/libchiperencoder_v1_2_1.so \
- @lib/armeabi/librabjni-1.so \
- @lib/armeabi/libshare_v2.so
- include $(BUILD_PREBUILT)
原文地址
http://blog.csdn.net/diaoxuesong/article/details/51121646
一、将无源码的 APK 和它 依赖的库预置进系统,此apk可以升级
---------- cut here ------------------ LOCAL_PATH := $(call my-dir) #预置aliuyi.apk include $(CLEAR_VARS) LOCAL_MODULE := wwwa.apk LOCAL_SRC_FILES := aliuyi.apk LOCAL_MODULE_TAGS := optional LOCAL_MODULE_CLASS := APPS LOCAL_CERTIFICATE := PRESIGNED LOCAL_MODULE_PATH := $(TARGET_OUT)/app include $(BUILD_PREBUILT) #方法一:预置so等资源文件 include $(CLEAR_VARS) LOCAL_MODULE := wanghai.so LOCAL_SRC_FILES := wanghai.so LOCAL_MODULE_TAGS := optional LOCAL_MODULE_CLASS := SHARED_LIBRARIES LOCAL_MODULE_PATH := $(TARGET_OUT)/lib/ include $(BUILD_PREBUILT) #方法二:预置so等资源文件include $(CLEAR_VARS) LOCAL_MODULE_TAGS := optional LOCAL_PREBUILT_LIBS := sdfapk.so sdffff.so include $(BUILD_MULTI_PREBUILT)
#方法三:预置so等资源文件,在Android.mk里 添加 这样一句,注意:这样的方式 如果路径不存在,这条指令 执行 失败,但 不会 报错!$(shell cp -rf $(LOCAL_PATH)/libs/*.so $(TARGET_OUT)/lib)
---------- cut here ------------------解释:
LOCAL_MODULE 指定 拷贝后的apk的名字(全名),这个变量里可以有路径,但路径也会被拷贝,创建,如果 是在编译整个Android的源码,这个apk必须已经添加到了PRODUCT_PACKAGES 变量里,否则 不会拷贝到,相应的位置,
LOCAL_MODULE_PATH 指定拷贝的路径,如果路径不存在自己创建
LOCAL_SRC_FILES 指定 源apk
LOCAL_CERTIFICATE := PRESIGNED 表示 这个apk已经签过名了,系统不需要再次 签名;
LOCAL_MODULE_CLASS 指定文件类型,apk文件用APPS, 并且 会检查 是否是apk文件,动态库so文件用SHARED_LIBRARIES ,bin文件用EXECUTABLES,其他文件 用ETC
注意:若是被预置的apk里有so库,需要将从Test.apk的 so库拷贝到 out/target/product/xxx/system/lib/目录下,若无 so 库,则去掉此步;
方法一 只能针对 一个文件,方法二 可以 针对多个文件,但 只能 把 文件 拷贝到 system/lib/ 下,
android提供了Prebuilt编译方法,两个文件prebuilt.mk和multi_prebuilt.mk,对应的方法宏是BUILD_PREBUILT和 BUILD_MULTI_PREBUILT。
prebuilt.mk就是prebuilt的具体实现,它是针对独立一个文件的操作,multi_prebuilt.mk 可以针对多个文件的,它对多个文件进行判断,然后调用prebuilt对独立一个文件进行处理。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。