转自: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