Gradle高级自定义、多项目构建

本文详细介绍了Gradle在Android项目中的高级自定义,包括使用共享库、批量生成Apk文件名、动态配置AndroidManifest、自定义BuildConfig、动态添加资源、Java编译选项、adb操作选项配置等。此外,还探讨了多项目构建,讲解了如何引用Android Lib和Java Lib项目,以及库项目的发布与依赖配置。
摘要由CSDN通过智能技术生成

一、高级自定义

1.1、使用共享库

Android的包(比如android.app、android.content、android.view、android.widget等)默认都是包含在Android SDK里面的,所有的应用都可以直接使用它们,系统会帮我们自动链接它们,不会出现找不到相关类的情况。还有一些库,比如com.google.android.maps、android.test.runner等,这些库是独立的,并不会被系统自动链接,所以我们使用它们的话,需要单独的进行生成使用,这些类库我们称为共享库。

在AndroidManifest.xml文件中,指定要使用的库:
<uses-library 
android:name="com.google.android.maps"
android:required="true"/>

这样就声明了需要使用maps这个共享库。声明之后,在安装生成的apk的时候,系统会根据我们的定义,帮助我们检测手机系统是否有我们需要的共享库。因为我们设置了android:required="true",如果手机系统不满足,将不能安装该应用。

在Android中,除了标准的SDK,还存在两种库:

- add-ons附件库,位于add-ons目录下,这些库大部分是第三方厂商或者公司开发的,一般是为了让开发者使用,但是又不愿意暴露具体标准实现的;对于该类库,Android Gradle会自动解析,帮我们添加到classpath里。

- 另一类是optional可选库,位于platforms/android-xx/optional目录下,一般是为了兼容旧版本的api,比如org.apache.http.legacy,这是一个HttpClient库。对于该类库,则不会帮我们添加到classpath里。

如何自己把这个可选库添加到classpath中?Android Gradle提供了useLibrary方法,让我们可以把一个库添加到classpath中。

android{
useLibrary 'org.apache.http.legacy'
}

除了上述配置,最好在AndroidManifest文件中配置一下use-library标签,以防出现问题。通过PackageManager.getSystemSharedLibraryNames()获取共享库的所有名字。

1.2、批量生成Apk的文件名

Android相对于Java工程要复杂的多,Java工程通过project.tasks.xx就可以访问xx任务,但是对Android来说,因为它有很多相同的任务,这些任务的名字都是通过buildTypes和Product Flavors生成的,是动态创建和生成的,而且生成的时间是比较靠后的,如果你还是像原来一样在某个闭包里通过project.tasks获取一个任务,会提示找不到任务,因为还没有生成。

android {
    compileSdkVersion 28
    defaultConfig {
        applicationId "com.example.test.gradletest"
        minSdkVersion 14
        targetSdkVersion 28
        versionCode 1
        versionName "1.0"
        testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
    }
    buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
            zipAlignEnabled true
        }
        debug {

        }
    }

    productFlavors {
        google {
            applicationIdSuffix '.
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值