热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Gradle之多版本打包不同依赖配置

2019独角兽企业重金招聘Python工程师标准一、构建变体1.BuildType1.1默认buildTypebuildTypes{release{minifyEnabled

2019独角兽企业重金招聘Python工程师标准>>> hot3.png

 

一、构建变体

1. BuildType

1.1默认buildType

buildTypes {release {minifyEnabled trueproguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'}
}
// release版本中设置了开启混淆,并且定义了混淆文件的位置

默认情况下还有一个debug版本,我们也可以添加对debug版本的一些设置

buildTypes {debug {minifyEnabled false}
}
// debug版本中关闭混淆

1.2自定义buildType

除了默认的构建版本,还可以创建自己的构建版本

buildTypes {custom.initWith(buildTypes.debug)custom {applicationIdSuffix ".custom"versionNameSuffix "-custom" }}
// custom使用initWith方法复制debug版本并创建了一个新的构建版本,相当于继承了debug版本
// custom版本中添加applicationId后缀,添加versionName后缀

其他属性的设置可以查看buildType的文档。

2. ProductFlavor

productFlavor用来为app创建不同的版本,如:免费版和付费版、不同应用市场的渠道包等。
创建方式:

android {productFlavors {free { // 免费版}paid { // 付费版}wandoujia { // 豌豆荚应用市场渠道包}myapp { // 应用宝应用市场渠道包}}
}

每一个生产版本都可以设置applicationId、versionCode、versionName等许多属性,具体可以查看productFlavors的文档。

3. BuildVariant

buildType和productFlavor相结合,组成了构建变体。每创建一个buildType或productFlavor,都会同时创建相应的变体。例如:创建一个myapp的productFlavor时,将会创建出两个相应的变体:myappDebug和myappRelease。

二、依赖管理

依赖管理的具体细节这里不多说明,想要详细了解的可以查看依赖管理的文档。

1. 添加依赖

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

2. 依赖配置

Gradle中的依赖会以配置(configurations)分组,一个配置就是一组依赖,称之为依赖配置
android插件定义了一些标准的配置,如:

  • compile:编译项目代码所需要的依赖。
  • debugCompile:debug版本编译项目代码所需要的依赖,对应buildTypes中的debug。默认情况下,包含了编译时产生的类文件,以及编译时期所需要的依赖。
  • releaseCompile:release版本编译项目代码所需要的依赖,对应buildType中的release。默认情况下,包含了编译时产生的类文件,以及编译时期所需要的依赖。
  • testCompile:编译测试代码时所需要的依赖。默认情况下,包含了编译时产生的类文件,以及编译时期所需要的依赖。

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

三、多版本不同依赖配置

1. 需求

接入广告是目前许多APP的盈利方式,但是随着不同平台的的广告SDK越来越多,各大应用市场也开始加强这方面的监管了,有的应用市场禁止接入广告SDK,有的应用市场则要求只能接入特定的广告SDK,所以就需要针对不同市场生成含有不同广告SDK的应用版本。

2. 实现

2.1 原理

  • 每创建一个BuildType就会自动创建一个基于它名字的编译依赖配置Compile
  • 每创建一个ProductFlavor就会自动创建一个基于它名字的编译依赖配置Compile
  • 所以利用这个特点,可以为不同的版本设置不同的依赖配置。

2.2 依赖配置语法说明

  • 依赖jar文件

dependencies{// 依赖某个jar文件complie files('libs/xxx.jar') // 依赖libs目录下所有以.jar结尾的文件complie fileTree(dir: 'libs', include: ['*.jar']) // 依赖libs目录下除了xxx.jar以外的所有以.jar结尾的文件complie fileTree(dir: 'libs', exclude: ['xxx.jar'], include: ['*.jar'])
}

  • 依赖module

dependencies{// 依赖本地项目工程下的某个modulecomplie project(:'moduleName')
}

  • 依赖aar文件

android {repositories {flatDir {dirs 'libs'}}
}
dependencies{// 依赖名字为xxx后缀为aar的文件compile (name: 'xxx', ext: 'aar')
}

  • 依赖远程库

dependencies{// 格式为:group:name:versioncompile 'com.android.support:appcompat-v7:23.3.0'// 排除某个传递依赖compile 'com.android.support:appcompat-v7:23.3.0'{exclude group: 'xxx', module: 'xxx'
}

2.3 依赖jar包实现不同依赖

默认不依赖任何广告sdk
在build.gradle中添加ProductFlavor,如下:

android {productFlavors {baidu { // 百度应用市场}lenovo { // 联想应用市场}common { // 其他不监管广告市场}}
}

将所有广告sdk的jar包统一添加前缀"ad_",在build.gradle中的dependencies下添加

dependencies{// 默认不添加广告sdkcompile fileTree(dir: 'libs', excludes: ['ad_*.jar'], include: ['*.jar'])// 百度市场添加百度广告sdkbaiduCompile files(libs/ad_baidu_sdk.jar)// 联想应用市场的包添加联想广告sdklenovoCompile files(libs/ad_lenovo_sdk.jar)// 其他不监管广告应用市场添加通用的广告sdkcommonCompile files(libs/ad_common_sdk.jar)
}

配置完成后运行gradle assembleRelease命令,就会生成各个市场的渠道包,并且含有不用的广告sdk。

2.4 依赖远程库实现不同依赖

  • 方法一:默认不依赖任何广告sdk
    在build.gradle中添加ProductFlavor,如下:

android {productFlavors {baidu { // 百度应用市场}lenovo { // 联想应用市场}common { // 其他不监管广告市场}}
}

在build.gradle中的dependencies下添加

dependencies{// 百度市场添加百度广告sdkbaiduCompile "com.baidu:ad:1.0.0"// 联想应用市场的包添加联想广告sdklenovoCompile "com.lenovo:ad:1.0.0"// 其他不监管广告应用市场添加通用的广告sdkcommonCompile "com.common:ad:1.0.0"
}

  • 方法二:默认依赖通用广告sdk
    在build.gradle中添加ProductFlavor,如下:

android {productFlavors {baidu { // 百度应用市场}lenovo { // 联想应用市场}huawei { // 华为应用市场}}
}

在build.gradle中的dependencies下添加

dependencies{// 默认添加通用广告sdkcompile "com.common:ad:1.0.0"// 百度市场在默认的compile中去掉通用广告sdkbaiduCompile configurations.compile {exclude(group: "com.common:ad:1.0.0", module: "ad")}// 百度市场添加百度广告sdkbaiduCompile "com.baidu:ad:1.0.0"// 联想市场在默认的compile中去掉通用广告sdkbaiduCompile configurations.compile {exclude(group: "com.common:ad:1.0.0", module: "ad")}// 联想应用市场的包添加联想广告sdklenovoCompile "com.lenovo:ad:1.0.0"// 华为市场在默认的compile中去掉通用广告sdkbaiduCompile configurations.compile {exclude(group: "com.common:ad:1.0.0", module: "ad")}
}



作者:zly394
链接:http://www.jianshu.com/p/9b50c4059d61
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。


转:https://my.oschina.net/jjyuangu/blog/1560107



推荐阅读
  • 树莓派语音控制的配置方法和步骤
    本文介绍了在树莓派上实现语音控制的配置方法和步骤。首先感谢博主Eoman的帮助,文章参考了他的内容。树莓派的配置需要通过sudo raspi-config进行,然后使用Eoman的控制方法,即安装wiringPi库并编写控制引脚的脚本。具体的安装步骤和脚本编写方法在文章中详细介绍。 ... [详细]
  • 本文介绍了在CentOS上安装Python2.7.2的详细步骤,包括下载、解压、编译和安装等操作。同时提供了一些注意事项,以及测试安装是否成功的方法。 ... [详细]
  • 本文介绍了设计师伊振华受邀参与沈阳市智慧城市运行管理中心项目的整体设计,并以数字赋能和创新驱动高质量发展的理念,建设了集成、智慧、高效的一体化城市综合管理平台,促进了城市的数字化转型。该中心被称为当代城市的智能心脏,为沈阳市的智慧城市建设做出了重要贡献。 ... [详细]
  • 向QTextEdit拖放文件的方法及实现步骤
    本文介绍了在使用QTextEdit时如何实现拖放文件的功能,包括相关的方法和实现步骤。通过重写dragEnterEvent和dropEvent函数,并结合QMimeData和QUrl等类,可以轻松实现向QTextEdit拖放文件的功能。详细的代码实现和说明可以参考本文提供的示例代码。 ... [详细]
  • 使用Ubuntu中的Python获取浏览器历史记录原文: ... [详细]
  • 计算机存储系统的层次结构及其优势
    本文介绍了计算机存储系统的层次结构,包括高速缓存、主存储器和辅助存储器三个层次。通过分层存储数据可以提高程序的执行效率。计算机存储系统的层次结构将各种不同存储容量、存取速度和价格的存储器有机组合成整体,形成可寻址存储空间比主存储器空间大得多的存储整体。由于辅助存储器容量大、价格低,使得整体存储系统的平均价格降低。同时,高速缓存的存取速度可以和CPU的工作速度相匹配,进一步提高程序执行效率。 ... [详细]
  • Python正则表达式学习记录及常用方法
    本文记录了学习Python正则表达式的过程,介绍了re模块的常用方法re.search,并解释了rawstring的作用。正则表达式是一种方便检查字符串匹配模式的工具,通过本文的学习可以掌握Python中使用正则表达式的基本方法。 ... [详细]
  • web.py开发web 第八章 Formalchemy 服务端验证方法
    本文介绍了在web.py开发中使用Formalchemy进行服务端表单数据验证的方法。以User表单为例,详细说明了对各字段的验证要求,包括必填、长度限制、唯一性等。同时介绍了如何自定义验证方法来实现验证唯一性和两个密码是否相等的功能。该文提供了相关代码示例。 ... [详细]
  • 欢乐的票圈重构之旅——RecyclerView的头尾布局增加
    项目重构的Git地址:https:github.comrazerdpFriendCircletreemain-dev项目同步更新的文集:http:www.jianshu.comno ... [详细]
  • 本文讨论了如何使用Web.Config进行自定义配置节的配置转换。作者提到,他将msbuild设置为详细模式,但转换却忽略了带有替换转换的自定义部分的存在。 ... [详细]
  • 本文介绍了使用哈夫曼树实现文件压缩和解压的方法。首先对数据结构课程设计中的代码进行了分析,包括使用时间调用、常量定义和统计文件中各个字符时相关的结构体。然后讨论了哈夫曼树的实现原理和算法。最后介绍了文件压缩和解压的具体步骤,包括字符统计、构建哈夫曼树、生成编码表、编码和解码过程。通过实例演示了文件压缩和解压的效果。本文的内容对于理解哈夫曼树的实现原理和应用具有一定的参考价值。 ... [详细]
  • 提升Python编程效率的十点建议
    本文介绍了提升Python编程效率的十点建议,包括不使用分号、选择合适的代码编辑器、遵循Python代码规范等。这些建议可以帮助开发者节省时间,提高编程效率。同时,还提供了相关参考链接供读者深入学习。 ... [详细]
  • Nginx使用AWStats日志分析的步骤及注意事项
    本文介绍了在Centos7操作系统上使用Nginx和AWStats进行日志分析的步骤和注意事项。通过AWStats可以统计网站的访问量、IP地址、操作系统、浏览器等信息,并提供精确到每月、每日、每小时的数据。在部署AWStats之前需要确认服务器上已经安装了Perl环境,并进行DNS解析。 ... [详细]
  • 深入理解Kafka服务端请求队列中请求的处理
    本文深入分析了Kafka服务端请求队列中请求的处理过程,详细介绍了请求的封装和放入请求队列的过程,以及处理请求的线程池的创建和容量设置。通过场景分析、图示说明和源码分析,帮助读者更好地理解Kafka服务端的工作原理。 ... [详细]
  • Imtryingtofigureoutawaytogeneratetorrentfilesfromabucket,usingtheAWSSDKforGo.我正 ... [详细]
author-avatar
xiaobin
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有