Android.mk编译脚本 & AndroidManifest.xml编写及注释

更新时间: 2019.04.17AndroidManifest.xml:android:sharedUserId="android.uid.systemui" //SystemUI属于系统apkcoreApp="true" //SystemUI属于核心apkandroid:persistent="true" //SystemUI不会被KILL,即被KILL后会自动重...
摘要由CSDN通过智能技术生成

更新时间: 2019.04.17

AndroidManifest.xml:

android:sharedUserId="android.uid.systemui"    //SystemUI属于系统apk
coreApp="true"    //SystemUI属于核心apk
android:persistent="true"    //SystemUI不会被KILL,即被KILL后会自动重启

Android.mk

# 每个Android.mk文件必须以定义LOCAL_PATH为开始。它用于在开发tree中查找源文件。  
# my-dir 则由Build System提供。返回包含Android.mk的目录路径。固定写法  
LOCAL_PATH := $(call my-dir)  

# CLEAR_VARS 变量由Build System提供。并指向一个指定的GNU Makefile,负责清理多余的LOCAL_xxx.  
# 这个清理动作是必须的,因为所有的编译控制文件由同一个GNU Make解析和执行,其变量是全局的  
# 所以清理后才能避免相互影响 比如LOCAL_MODULE, LOCAL_SRC_FILES, LOCAL_STATIC_LIBRARIES  
include $(CLEAR_VARS)  

# 定义引用的jar包:名字自定义,后面会针对名字进行路径说明  
LOCAL_STATIC_JAVA_LIBRARIES := supportinternal supportannotions  

# 定义引用的aar包:名字自定义,后面会针对名字进行路径说明  
# aar包内如果有jar包,需要导出引用比如V4包有jar包  
LOCAL_STATIC_JAVA_AAR_LIBRARIES := support4  

# 定义src文件路径  
LOCAL_SRC_FILES := $(call all-subdir-Java-files) $(call all-java-files-under, src) $(call all-renderscript-files-under, src)  

# 定义res文件路径  
LOCAL_RESOURCE_DIR := $(LOCAL_PATH)/res  

# 编译后名称  
LOCAL_PACKAGE_NAME := SysemUI
# 预置到 /system/pri-app/;不添加此属性,编译后的路径为/system/app/SystemUI
# 在同样具有系统权限情况下,/system/pri-app下的apk权限比/system/app下大
LOCAL_PRIVILEGED_MODULE := true
# 编译生成目标的安装路径
# 在build/core/envsetup.mk中定义;TARGET_ROOT_OUT:表示根文件系统;TARGET_OUT:表示system文件系统;TARGET_OUT_DATA:表示data文件系统。
# 预置的apk用户可以卸载,恢复出厂设置不可恢复
LOCAL_MODULE_PATH := $(TARGET_OUT_DATA_APPS)    
# 预置的apk用户可以卸载,恢复出厂设置可恢复
LOCAL_MODULE_PATH := $(TARGET_OUT)/vendor/operator/app    

# 定义生成的apk使用的key  
# 指定平台签名,生成Settings.apk文件之后,系统会使用如下两个文件对Settings.apk进行签名,这个系统设置就拥有系统权限了
# (源码根目录)MSM8939_AndroidL/build/target/product/security/platform.pk8
# (源码根目录)MSM8939_AndroidL/build/target/product/security/platform.x509.pem
# Settings光使用Platform签名还不行,需要在AndroidManifest.xml文件package="xxx"后指定共享用户ID,并将添加属性: coreApp="true",才会变成内核应用
# 任何一个Android应用,如果使用前面的配置,并在Android源代码中使用mm/mmm命令进行编译,其权限就会和Settings完全一样
# 每一个版本(包括同一版本不同分支)Android源代码所带的Platform签名都不一样,使用不同的签名会导致apk程序认证不通过,尽管system/app下已存在对应apk
# 设置coreApp="true"和android:sharedUserId="android.uid.system"的apk将用于系统级的权限(不需要root权限),Android采用了Linux的ACL权限管理方式 
LOCAL_CERTIFICATE := platform
# 指定混淆标识文件
LOCAL_PROGUARD_FLAG_FILES := proguard.flags
# 定义jar包 aar包的路径 :后面跟的是相对Android.mk文件的相对路径  
LOCAL_PREBUILT_STATIC_JAVA_LIBRARIES := supportinternal:lib/support-annotations-22.2.1-sources.jar \  
                                        supportannmtions:lib/internal_impl-22.2.1.jar \  
                                        support4:lib/support-v4-22.2.1.aar \  

include $(CLEAR_VARS)   

# 因为aar包的存在,这个主要是用于合并AndroidManifest.xml 和res资源文件   
LOCAL_AAPT_FLAG := \   
                   --auto-add-overlay \   
                   --extra-package android.support.v4 \   
                   --extra-package com.openthos.launcher.openthoslauncher   

# 指明合并后的AndroidManifest.xml的路径 (一般不用指定)   
LOCAL_MANIFEST_FILE := $(LOCAL_PATH)/AndroidManifest.xml   

# 因引入jar包或aar包,须加上这句   
include $(BUILD_MULTI_PREBUILT)   

include $(call all-makefiles-under,$(LOCAL_PATH))  

<

  • 6
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 8
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值