build.gradle配置说明

module/build.gradle

apply plugin: 'com.android.application'
//说明module的类型,com.android.application为程序,com.android.library为库
android {
    compileSdkVersion 22  //编译的SDK版本
    buildToolsVersion "22.0.1"  //编译的Tools版本
    defaultConfig {  //默认配置
        applicationId "com.example.test"  //应用程序的包名
        minSdkVersion 15  //支持的最低版本
        targetSdkVersion 25  //支持的目标版本
        versionCode 3190  //版本号
        versionName "3.1.9"  //版本名
    }
    sourceSets {  //目录指向配置
        main {
            manifest.srcFile 'AndroidManifest.xml'  //指定AndroidManifest文件
            java.srcDirs = ['src']  //指定source目录
            resources.srcDirs = ['src']  //指定source目录
            aidl.srcDirs = ['src']  //指定source目录
            renderscript.srcDirs = ['src']  //指定source目录
            res.srcDirs = ['res']  //指定资源目录
            assets.srcDirs = ['assets']  //指定assets目录
            jniLibs.srcDirs = ['libs']  //指定lib库目录
        }
        debug.setRoot('build-types/debug')  //指定debug模式的路径
        release.setRoot('build-types/release')  //指定release模式的路径
    }
    signingConfigs {  //签名配置
        release {  //发布版签名配置
            storeFile file("fk.keystore")  //密钥文件路径
            storePassword "123"  //密钥文件密码
            keyAlias "fk"  //key别名
            keyPassword "123"//key密码
        }
        debug {  //debug版签名配置
            storeFile file("fk.keystore")
            storePassword "123"
            keyAlias "fk"
            keyPassword "123"
        }
    }
    buildTypes {  //build类型
        release {  //发布
            minifyEnabled true  //混淆开启
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-project.txt'  //指定混淆规则文件
            signingConfig signingConfigs.release  //设置签名信息
        }
        debug {  //调试
            signingConfig signingConfigs.release
        }
    }
    packagingOptions {
        exclude 'META-INF/ASL2.0'
        exclude 'META-INF/LICENSE'
        exclude 'META-INF/NOTICE'
        exclude 'META-INF/MANIFEST.MF'
    }
    lintOptions {
        abortOnError false  //lint时候终止错误上报,防止编译的时候莫名的失败
    }
}
dependencies {
    compile fileTree(dir: 'libs', exclude: ['android-support*.jar'], include: ['*.jar'])   
    //编译lib目录下的.jar文件
    compile project(':Easylink')  //编译附加的项目
    compile project(':ImageLibrary')
    compile project(':ImageResLibrary')
    compile project(':Ofdmtransport')
    compile project(':PullToRefreshLibrary')
    compile project(':RecorderLibrary')
    compile project(':WebSocket')
    compile project(':WidgetLibrary')
    compile 'com.nostra13.universalimageloader:universal-image-loader:1.9.3'  //编译来自Jcenter的第三方开源库
}

项目/build.gradle

// Top-level build file where you can add configuration options common to all sub-projects/modules.
//整个项目的gradle基础配置文件
//buildscript { ... }配置了驱动构建的代码。
// 声明了使用jcenter 中央库,并且对一个Maven 文件有一个类路径依赖。
// 这个文件是包含 Gradle Android 插件的 1.5.0版本的库
buildscript {
    repositories {
        jcenter()
    }

    dependencies {
        //声明了android gradle plugin的版本
        classpath 'com.android.tools.build:gradle:1.5.0'

        // NOTE: Do not place your application dependencies here; they belong
        // in the individual module build.gradle files
    }
}

allprojects {
    repositories {
        jcenter()
    }
}

task clean(type: Delete) {
    delete rootProject.buildDir
}

内容主要包含了两个方面:一个是声明仓库的源,这里可以看到是指明的jcenter(), 之前版本则是mavenCentral(), jcenter可以理解成是一个新的中央远程仓库,兼容maven中心仓库,而且性能更优。另一个是声明了android gradle plugin的版本,android studio 1.0正式版必须要求支持gradle plugin 1.0的版本。

android DSL

–领域特定语言(domain-specific languages,简称DSL

  • defaultConfig{} 默认配置,是ProductFlavor类型。它共享给其他ProductFlavor使用

  • sourceSets{ } 源文件目录设置,是AndroidSourceSet类型。

  • buildTypes{ } BuildType类型

  • signingConfigs{ } 签名配置,SigningConfig类型

  • productFlavors{ } 产品风格配置,ProductFlavor类型

  • testOptions{ } 测试配置,TestOptions类型

  • aaptOptions{ } aapt配置,AaptOptions类型

  • lintOptions{ } lint配置,LintOptions类型

  • dexOptions{ } dex配置,DexOptions类型

  • compileOptions{ } 编译配置,CompileOptions类型

  • packagingOptions{ } PackagingOptions类型

  • jacoco{ } JacocoExtension类型。 用于设定 jacoco版本

  • splits{ } Splits类型。
    android{ … }配置了用于 android 构建的所有参数。这是Android DSL的入口。

### Kotlin DSL 在 `build.gradle` 和 `settings.gradle` 中的配置方法 #### 1. `settings.gradle.kts` 配置 `settings.gradle.kts` 是 Gradle 构建系统的入口文件之一,主要用于定义多模块项目的结构以及初始化设置。通过 Kotlin DSL 编写此文件可以更高效地管理和维护复杂的项目。 以下是常见的配置项及其说明: - **启用特定插件** 使用 `pluginManagement { repositories {} }` 来指定插件仓库的位置。 ```kotlin pluginManagement { repositories { gradlePluginPortal() // 添加官方插件门户作为源 mavenCentral() // Maven Central Repository 支持 } } ``` - **包含子模块** 如果项目是一个多模块工程,则可以通过 `include()` 方法来注册各个模块。 ```kotlin include(":app", ":core", ":features:auth") // 注册多个模块 ``` 上述内容展示了如何利用 Kotlin DSL 对 `settings.gradle.kts` 文件进行基本配置[^1]。 --- #### 2. `build.gradle.kts` 配置 `build.gradle.kts` 负责具体项目的构建逻辑、依赖关系以及其他高级选项的设定。下面是一些典型的场景和对应的实现方式。 ##### a) 应用插件 在脚本顶部声明所需插件,并为其传递必要的参数。 ```kotlin plugins { id("org.jetbrains.kotlin.jvm") version "1.8.0" apply true // 启用 Kotlin JVM 插件 } ``` 此处指定了 JetBrains 提供的标准库支持版本号并激活它[^4]。 ##### b) 设置编译器属性 调整 Kotlin 编译过程中的行为以满足开发需求。 ```kotlin tasks.withType<org.jetbrains.kotlin.gradle.tasks.KotlinCompile> { kotlinOptions { jvmTarget = "17" // Java 版本兼容性目标设为 JDK 17 freeCompilerArgs += "-Xjsr305=strict" // 加入额外命令行标志优化警告处理机制 } } ``` 这段代码片段设置了 JVM 目标级别和其他自定义标记以便更好地控制生成字节码的质量[^2]。 ##### c) 管理外部依赖 引入第三方库到当前环境中非常简单直观。 ```kotlin dependencies { implementation("com.squareup.retrofit2:retrofit:2.9.0") // Retrofit HTTP 客户端框架实例化 testImplementation(kotlin("test")) // 测试环境下的单元测试工具包集成 } ``` 这里列举了一个网络请求组件的例子连同其配套资源一起加载进来[^3]。 --- ### 总结 以上分别介绍了基于 Kotlin DSL 的两种主要 Gradle 配置文件——即 `settings.gradle.kts` 和 `build.gradle.kts` ——各自的功能特点及实际操作示范。希望这些信息能够帮助您快速上手并熟练掌握它们的应用技巧!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值