Gradle Plugin Samples 之 Gradle Hello World (二)

Gradle Hello World

一个 Android Studio 项目中,会存在多个  .gradle  文件。其中,  project  目录下存在一个  build.gradle  文件和一个  settings.gradle  文件;每一个  module  会存在一个  build.gradle  文件。

本文只是简略的讲解一下默认生成的  .gradle  文件的内容,更多  Gradle Plugin  的知识,请看 这里

{@projectName}/build.gradle


buildscript {
repositories {
    jcenter()
}
dependencies {
    classpath 'com.android.tools.build:gradle:1.0.0'
}
}

allprojects {
repositories {
    jcenter()
}
}


默认的  project  目录下的  build.gradle  文件内容如上。
  • buildscript :用于设置驱动构建过程的代码。
  • jcenter():声明使用 maven 仓库。在老版本中,此处为 mavenCentral()
    • mavenCentral() :表示依赖从 Central Maven 2 仓库中获取。
    • jcenter() :表示依赖从 Bintary’s JCenter Maven 仓库中获取。* **mavenLocal()** :表示依赖从本地的Maven仓库中获取。
  • dependencies :声明了使用 Android Studio gradle 插件版本。一般升级AS或者导入从Eclipse中生成的项目时需要修改下面gradle版本。具体的版本对应关系,请点击
  • allprojects:设置每一个 module 的构建过程。在此例中,设置了每一个 module 使用 maven 仓库依赖。

在景德镇,默认的maven源可能无法访问,可以通过以下的方式设置其他的maven源。当然,你也可以设置依赖本地库。

maven {
url "http://xx.xxx.xxx/xxx"
}


开源中国的源地址为:

http://maven.oschina.net/content/groups/public/


开源中国的thirdparty源地址为:

http://maven.oschina.net/content/repositories/thirdparty/


你可以为  repositories  设置多个库。  Gradle  会根据依赖定义的顺序在各个库里寻找它们。在第一个库里找到就不会再在第二个库里进行寻找。

{@projectName}/settings.gradle


include ':app'


默认的  project  目录下的  settings.gradle  文件内容如上。可有可能默认情况下,  project  目录下的 settings.gradle  文件不存在,你可以自己创建。
  • include ':app':表示当前 project 下有一个名称为 app 的 module 。

如果你的一个  module  并不是  project  根目录下,你可以这么设置。

include ':app2'
project(':app2').projectDir = new File('path/to/app2')


{@projectName}/gradle{@projectName}/gradlew{@projectName}/gradlew.bat

这3个文件及文件夹我们不需要进行处理。

有一处比较特别的就是:

{@projectName}/gradle/wrapper/gradle-wrapper.properties  这个配置文件中配置了  Gradle  构建当前项目时使用的  Gradle  版本。我们需要注意的就是 Android Studio 、Gradle 、 Gradle Plugin 这3个的版本需要对应起来,具体的对应关系请 点此

我们可以使用  {@projectName}/gradlew.bat  在命令行中进行  Gradle  任务。但是,建议使用 Android Studio 的 Gradle  功能面板进行  Gradle  任务。

{@moduleName}/build.gradle


apply plugin: 'com.android.application'

android {
compileSdkVersion 21
buildToolsVersion "21.1.2"

defaultConfig {
    applicationId "cc.bb.aa.myapplication"
    minSdkVersion 10
    targetSdkVersion 21
    versionCode 1
    versionName "1.0"
}
buildTypes {
    release {
        minifyEnabled false
        proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
    }
}
}

dependencies {
compile fileTree(dir: 'libs', include: ['*.jar'])
compile 'com.android.support:appcompat-v7:21.0.3'
}


默认的  module  目录下的  build.gradle  文件内容如上。
  • apply plugin: 'com.android.application'

    表示使用 com.android.application 插件。也就是表示,这是一个 android application module 。com.android.library 表示,这是一个 android library module 。
  • android

    配置所有 android 构建过程需要的参数。
  • compileSdkVersion

    用于编译的 SDK 版本。
  • buildToolsVersion

    用于 Gradle 编译项目的工具版本。在 SDK 中可以查看本机已安装的版本。
  • defaultConfig

    Android 项目默认设置。
    • applicationId:应用程序包名。
    • minSdkVersion:最低支持 Android 版本。
    • targetSdkVersion:目标版本。实际上应为测试环境下测试机的 Android 版本。
    • versionCode:版本号。* **versionName**:版本名称。
  • buildTypes:
    编译类型。默认有两个: release 和 debug 。我们可以在此处添加自己的 buildTypes ,可在 Build Variants 面板看到。
    • minifyEnabled

      是否使用混淆。在老版本中为 runProguard ,新版本之所换名称,是因为新版本支持去掉没使用到的资源文件,而 runProguard 这个名称已不合适了。* **proguardFiles**: 
      使用的混淆文件,可以使用多个混淆文件。此例中,使用了 **SDK** 中的 **proguard-android.txt** 文件以及当前 **module** 目录下的 **proguard-rules.pro** 文件。
  • dependencies

    用于配制引用的依赖。
    • compile fileTree(dir: 'libs', include: ['*.jar'])

      引用当前 module 目录下的 libs 文件夹中的所有 .jar 文件。* **compile 'com.android.support:appcompat-v7:21.0.3'**: 
      引用 **21.0.3**版本的 **appcompat-v7** (也就是常用的 **v7** library 项目)。
      > 在 **Eclipse** 中,使用 **android support** ,需要在 SDK 中下载 **Android Support Library** 。在 Android Studio中,使用 **android support** ,需要在 SDK 中下载 **Android Support Repository** ,且项目中使用的版本不能大于 SDK 中的版本。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值