原文地址:http://tools.android.com/tech-docs/new-build-system/user-guide#TOC-Dependencies-Android-Libraries-and-Multi-project-setup

4、Dependencies。Android Libraries and Multi-project setup(依赖关系,Android库和多项目设置)

Gradle项目能够依赖于其他组件。这些组件能够是外部二进制包,或者是其他的Gradle项目。

4.1 Dependencies on binary packages(依赖二进制包)

4.1.1 Local packages(本地包)

配置一个外部库的jar包依赖。你须要在compile配置中加入一个依赖。

    dependencies {
compile files('libs/foo.jar')
} android {
...
}

注意:这个dependencies DSL标签是标准Gradle API中的一部分。所以它不属于android标签。

这个compile配置将被用于编译main application。它里面的全部东西都被会被加入到编译的classpath中,同一时候也会被打包进终于的APK。

下面是加入依赖时可能用到的其他一些配置选项:

    * compile:main application(主module)。

    * androidTestCompile:test application(測试module)。

    * debugCompile:debug Build Type(debug类型的编译)。

    * releaseCompile:release Build Type(公布类型的编译)。

由于没有可能去构建一个没有关联不论什么Build Type(构建类型)的APK,APK默认配置了两个或两个以上的编译配置:compile和<buildtype>Compile.

创建一个新的Build Type将会自己主动创建一个基于它名字的新配置。

这对于debug版本号须要使用一个自己定义库(为了反馈实例化的崩溃信息等)但公布版本号不须要。或者它们依赖于同一个库的不同版本号时会很实用。

4.2.2 Remote artifacts(远程文件)

Gradle支持从Maven或者Ivy仓库中拉取文件。

首先必须将仓库加入到列表中,然后必须在依赖中声明Maven或者Ivy声明的文件。

    repositories {
mavenCentral()
} dependencies {
compile 'com.google.guava:guava:11.0.2'
} android {
...
}

注意:mavenCentral()是指定仓库URL的简单方法。Gradle支持远程和本地仓库。

注意:Gradle会遵循依赖关系的传递性。这意味着假设一个依赖本身依赖于其他东西,这些东西也会一并被拉取回来。

很多其它关于设置依赖关系的信息,请參考Gradle用户指南DSL文档

4.2 Multi project setup(多项目设置)

Gradle项目也能够通过使用多项目配置依赖于其他Gradle项目。

多项目配置的实现一般是在一个根项目路径下将全部项目作为子目录包括进去。

比如,给定下面项目结构:

    MyProject/
+ app/
+ libraries/
+ lib1/
+ lib2/

我们能够定义3个项目。

Grand将会依照下面名字映射它们:

    :app

    :libraries:lib1

    :libraries:lib2

每个项目都拥有自己的build.gradle文件来声明自己怎样构建。

另外,在根文件夹下另一个setting.gradle文件用于声明全部项目。

这些文件的结构例如以下:

    MyProject/
| settings.gradle
+ app/
| build.gradle
+ libraries/
+ lib1/
| build.gradle
+ lib2/
| build.gradle

当中setting.gradle的内容很easy:

    include ':app', ':libraries:lib1', ':libraries:lib2'

这里定义了哪一个目录才是真正的Gradle项目。

当中:app项目可能依赖于这些库,这是通过下面依赖配置声明的:

    dependencies {
compile project(':libraries:lib1')
}

很多其它关于多项目配置的信息请參考这里

4.3 Library projects(库项目)

在上面的多项目配置中。:libraries:lib1和:libraries:lib2可能是一个Java项目,而且:app这个Android项目将会使用它们的jar包输出。

可是。假设你想要共享代码来訪问Android API或者使用Android样式的资源,那么这些库就不能是通常的Java项目,而应该是Android库项目。

4.3.1 Creating a Library Project(创建一个库项目)

一个库项目与通常的Android项目很类似,仅仅是有一点小差别。

虽然构建库项目不同于构建应用程序,它们使用了不同的plugin。可是在内部这些plugin共享了大部分同样的代码。而且它们都由同样的com.android.tools.build.gradle.jar提供。

    buildscript {

        repositories {

            mavenCentral()

        }

        dependencies {

            classpath 'com.android.tools.build:gradle:0.5.6'

        }

    }

    apply plugin: 'android-library'

    android {

        compileSdkVersion 15

    }

这里创建了一个使用API 15编译SourceSet的库项目,而且依赖关系的配置方法与应用程序项目的配置方法一样,相同也支持自己定义配置。

4.3.2 Differences between a Project and a Library Project(普通项目和库项目之间的差别)

一个库项目的main输出是一个.aar包(它代表Android的归档文件)。它组合了编译代码(比如jar包或者是本地的.so文件)和资源(manifest。res。assets)。

一个库项目相同也能够独立于应用程序生成一个測试用的apk来測试。

标识Task相同适用于库项目(assembleDebug,assembleRelease),因此在命令行上与构建一个项目没有什么不同。

其余的部分,库项目与应用程序项目一样。它们都拥有build type和product flavor,也能够生成多个aar版本号。

记住大部分Build Type的配置不适用于库项目。可是你能够依据库项目是否被其他项目使用或者是否用来測试来使用自己定义的sourceSet改变库项目的内容。

4.3.3 Referencing a Library(引用一个库项目)

引用一个库项目的方法与引用其他项目的方法一样:

    dependencies {

        compile project(':libraries:lib1')

        compile project(':libraries:lib2')

    }

注意:假设你要引用多个库,那么排序将很重要。这类似于旧构建系统里面的project.properties文件里的依赖排序。

4.3.4 Library Publication(库项目公布)

普通情况下一个库仅仅会公布它的release Variant(变种)版本号。

这个版本号将会被全部引用它的项目使用,而无论它们本身自己构建了什么版本号。这是因为Gradle的限制,我们正在努力消除这个问题,所以这仅仅是暂时的限制。

你能够控制哪一个Variant版本号作为发行版:

    android {

        defaultPublishConfig "debug"

    }

注意这里的公布配置名称引用的是完整的Variant版本号名称.Relesae,debug仅仅适用于项目中没有其他特性版本号的时候使用。假设你想要使用其他Variant版本号代替默认的公布版本号,你能够:

    android {

        defaultPublishConfig "flavor1Debug"

    }

将库项目的全部Variant版本号都公布也是可能的。我们计划在一般的项目依赖项目(类似于上述所说的)情况下同意这样的做法,可是因为Gradle的限制(我们也在努力修复这个问题)如今还不太可能。

默认情况下没有启用公布全部Variant版本号。能够通过下面启用:

    android {

        publishNonDefault true

    }

理解公布多个Variant版本号意味着公布多个arr文件而不是一个arr文件包括全部Variant版本号是很重要的。每个arr包都包括一个单一的Variant版本号。

公布一个变种版本号意味着构建一个可用的arr文件作为Gradle项目的输出文件。

不管是公布到一个maven仓库,还是其他项目须要创建一个这个库项目的依赖都能够使用到这个文件。

Gradle有一个默认文件的概念。当加入下面配置后就会被使用到:

    compile project(':libraries:lib2')

创建一个其他公布文件的依赖,你须要指定详细使用哪一个:

    dependencies {

        flavor1Compile project(path: ':lib1', configuration: 'flavor1Release')

        flavor2Compile project(path: ':lib1', configuration: 'flavor2Release')

    }

重要:注意已公布的配置是一个完整的Variant版本号。当中包含了build type,而且须要像以上一样被引用。

重要:当启用非默认公布,maven公布插件将会公布其他Variant版本号作为扩展包(按分类器分类)。这意味着不能真正的兼容公布到maven仓库。

你应该另外公布一个单一的Variant版本号到仓库中,或者同意公布全部配置以支持跨项目依赖。

Android Gradle Plugin指南(三)——依赖关系、android库和多项目配置的更多相关文章

  1. Android Gradle Plugin指南(六)——高级构建定制

    原文地址:http://tools.android.com/tech-docs/new-build-system/user-guide#TOC-Advanced-Build-Customization ...

  2. Android Gradle Plugin指南(五)——Build Variants(构建变种版本号)

    原文地址:http://tools.android.com/tech-docs/new-build-system/user-guide#TOC-Build-Variants 6. Build Vari ...

  3. Android Gradle Plugin指南(四)——測试

    原文地址:http://tools.android.com/tech-docs/new-build-system/user-guide#TOC-Testing 5.Testing(測试) 构建一个測试 ...

  4. Gradle之Android Gradle Plugin 主要 Task 分析(三)

    [Android 修炼手册]Gradle 篇 -- Android Gradle Plugin 主要 Task 分析 预备知识 理解 gradle 的基本开发 了解 gradle task 和 plu ...

  5. Gradle之Android Gradle Plugin 主要流程分析(二)

    [Android 修炼手册]Gradle 篇 -- Android Gradle Plugin 主要流程分析 预备知识 理解 gradle 的基本开发 了解 gradle task 和 plugin ...

  6. 读书笔记--Android Gradle权威指南(下)

    前言 最近看了一本书<Android Gradle 权威指南>,收获挺多,就想着来记录一些读书笔记,方便后续查阅. 本篇内容是基于上一篇:读书笔记--Android Gradle权威指南( ...

  7. 读书笔记--Android Gradle权威指南(上)

    本篇文章已授权微信公众号 dasu_Android(大苏)独家发布 最近看了一本书<Android Gradle 权威指南>,对于 Gradle 理解又更深了,但不想过段时间就又忘光了,所 ...

  8. The Android Gradle Plugin and Gradle version-compatibility

    http://tools.android.com/tech-docs/new-build-system/version-compatibility Version Compatibility Post ...

  9. Android AS升级3.1 编译报错:The SourceSet 'instrumentTest' is not recognized by the Android Gradle Plugin.

    AndroidStudio升级到3.1后编译报错:The SourceSet ‘instrumentTest’ is not recognized by the Android Gradle Plug ...

随机推荐

  1. vue 刷新当前页面的方式

    1.使用window.location.href window.location.replace() window.location.reload() 会出现空白,体验不是很好 2.先进入一个空路由, ...

  2. BZOJ2244: [SDOI2011]拦截导弹(CDQ分治,二维LIS,计数)

    Description 某国为了防御敌国的导弹袭击,发展出一种导弹拦截系统.但是这种导弹拦截系统有一个缺陷:虽然它的第一发炮弹能够到达任意的高度.并且能够拦截任意速度的导弹,但是以后每一发炮弹都不能高 ...

  3. 斜率优化dp练习

    1.HDU3507 裸题,有助于理解斜率优化的精髓. dp[i]=min(dp[j]+m+(sum[i]-sum[j])2) 很显然不是单调队列. 根据斜率优化的的定义,就是先设两个决策j,k 什么时 ...

  4. 用py2exe打包成一个exe文件

    用py2exe打包成一个exe文件 http://blog.csdn.net/franktan2010/article/details/46514607

  5. asp.net 查询sql数据表的网页模板

    最近因为工作需求,要制作一个网页模板,主要是用于快速开发,可以查询Sql数据表信息的模板, 昨天做好了,这个只是一个Demo,但是功能已经齐全了, 开发新的网站时,需要新增一个xml,复制粘贴网页的前 ...

  6. php线性表数组实现的删除操作

    php线性表数组实现的删除操作 一.总结 1.array_pop(): 函数删除数组中的最后一个元素. 二.代码 代码一: //线性表的删除(数组实现) function delete_array_e ...

  7. PHP服务器环境打开配置文件

    MAC 1.  cd /usr/local/etc/nginx/servers vim www.xxx.com 2. 在/usr/local/etc/nginx/servers目录下,不同的 .con ...

  8. CView::OnPreparePrinting

    http://technet.microsoft.com/zh-cn/subscriptions/a59dff1e(v=vs.71).aspx CView::OnPreparePrinting Cal ...

  9. C# mongodb帮助类

    这是在C#连接MongoDB的帮助类,所使用的驱动是在Vs2015的Nuget管理器中下载的mongodb驱动. 下载第一个,会自动下载下面的两个,不要删除. 在配置文件中配置连接字符串connStr ...

  10. C++组合数(combination)的实现

    实现: (nm) 既需要计算组合的总数 (32)=3: 也需要分别获得每一种组合的情形,用于穷举搜索: 1, 2; 1, 3; 2, 3 1. 递归实现 // picked + toPick == m ...