gradle编译Android,Android Gradle编译学习

转自:http://www.th7.cn/Program/Android/201412/331706.shtml

一、配置 Gradle 的资源路径

为了让 Gradle 能够找到响应的源文件和资源文件,我们先看一下Gradle 的目录结构,从第二张图中我们能够发现 Gradle 的默认编译结构中将程序源码分为了几个不同的部分:java、jni、rs、aidl,而 Eclipse 的目录中java 和 aidl 是放置在同一个目录下的,所以我们需要在 build.gradle 文件根据项目结构定义好对应的路径。

定义路径位置的代码如下:

android { sourceSets { main { manifest.srcFile 'AndroidManifest.xml' java.srcDirs = ['src'] resources.srcDirs = ['src'] aidl.srcDirs = ['src'] renderscript.srcDirs = ['src'] res.srcDirs = ['res'] assets.srcDirs = ['assets'] } androidTest.setRoot('tests') }}

请把 sourceSets 部分添加到 build.gradle 中的 android 域内。

其实 Gradle 默认的源码路径设置位置应该是在最外层,但是由于Andorid 插件拥有自己的代码设置,因此我们将 sourceSets 放置到 android 域内。

之后执行

二、引入项目依赖包

What?你出错了,不可能吧?

当然其实这是可能的,注意查看第一张图,里面除了 TestGradle 目录以外,还有一个 appcompat_v7,这是项目的依赖包,如果你不进行配置,那么 Android 编译时无法找到他,自然会报错。

现在我们来看看如何将依赖包引入 Android,让他能够正常编译

**(1)使用 maven **

之前我就说过,Gradle 能够使用 Maven 的几乎所有特性,因此当我们需要使用依赖包的时候,而且该依赖包在 maven 中央库中存在的时候,我们不妨直接在配置文件中配置,配置方法也十分简单地说,以 appcompat_v7包为例,在 build.gradle 的最外层加入以下信息:

dependencies { compile 'com.android.support:appcompat-v7:21.0.3'}

compile 代表着你希望在编译的时候将某个 maven 包打入程序中,而后面的信息则是对应 maven 包的相关信息,方便从 maven 中央仓库中进行获取。

然后你再执行一下:

gradle check

(2)引入 jar 包

有时候我们在 libs 目录下有存放 jar 包类型或者 so 链接库类型的依赖资源,但是当你进行编译时,你会发现找不到这些资源,原因只有一个: Gradle 不知道你需要编译的资源对象在哪里,因此我们需要手动在 build.gradle 进行路径配置,大致方法与上面的类似,我就简单叙述一下就好了。

打开你的 build.gradle,在 dependencise 域,没错,就是刚才我们添加 appcompa_v7包的那个域,在域中我们加入一下代码:

compile fileTree(dir: 'libs', include: ['.jar'])

该代码就将所有在 libs 目录下的 jar 包引入了,如果要引入 so 库,再加一句

compile fileTree(dir: 'libs', include: ['/.so'])

(3)引入依赖项目

如果你实在找不到对应的 maven 项目或者不能单纯使用 jar 包进行引入,实在需要使用一个依赖工程,那我们就得考虑通过将依赖项目先转换为 Gradle 类型的 Android Library,然后再进行项目关联。

面对这种情况,我们可以像 Eclipse 一样将应用项目和依赖工程放在同一目录下,方便关联。

我们先将 TestGradle 中 build.gradle 中关于 appcompat 依赖包得引用去掉

在顶层目录中,我们建立一个 build.gradle 和 setting.gradle 文件分别存放项目依赖。

build.gradle 用于存放通用的配置信息,例如通用依赖:

// Top-level build file where you can add configuration options common to all sub-projects/modules.buildscript { repositories { jcenter() } dependencies { classpath 'com.android.tools.build:gradle:1.0.0' // NOTE: Do not place your application dependencies here; they belong // in the individual module build.gradle files }}allprojects { repositories { jcenter() }}

setting.gradle 用于存放项目信息,例如这里,我们可以像这样命名:

include ':TestGradle',':appcompat_v7'

TestGradle 和 appcompat_v7分别为应用项目和依赖工程的名称,如果你的工程是在某个子目录下,那么你可以使用类似于‘:libraries:lib1'这种形式标明在 libraries 文件夹下的 lib1文件夹也是一个 Gradle 项目*

之后我们进入 appcomp_v7目录,建立对应的 build.gradle 配置文件,由于我们在上层目录中已经创建了一个 build.gradle 并且配置了通用的依赖信息,因此在这个配置文件中我们可以不必写入 buildscript 的相关属性。

apply plugin: 'com.android.library'android { compileSdkVersion 21 buildToolsVersion "21.1.2"}

这里需要留意的是,这里的插件类型是' com.android.library' 标明他是一个依赖包。另外如果你的项目配置是 Eclipse 目录类型,请根据上文,配置对应的源码位置。

如此一来,你已经配置好了相关的依赖工程,接下来我们需要将这个依赖工程配置到主工程中。

方法为在主工程 build.gradle 中加入

dependencies { compile project(':appcompat_v7')}

之后你再使用 Gradle 命令行就能够针对本地的依赖库进行编译。

gradle check

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值