上一篇 文章中详细介绍了module中build.gradle文件的属性和配置,今天详细讲解一下我在自己的应用中主要是实现多渠道打包功能。
1.首先定义一个打包时间
def releaseTime(){
return newDate().format("yyyyMMdd", TimeZone.getTimeZone("UTC"))
}
gradle语法我也不是很懂,但是基本是以java基础的。此处获得的时间格式是20170121这种格式,此处定义是为了自动生成包名。
2.定义开启databinding
android{
dataBinding{
enabled=true
}
}
databinding是新型的安卓mvvm架构,想深入了解的可以去搜各种教程,这里推荐的是慕课网上markzhai的视频,讲的很透彻
3.定义版本构建工具
compileSdkVersion rootProject.ext.compileSdkVersion
buildToolsVersion rootProject.ext.buildToolsVersion
此处compileversion和buildversion用的是自定义全局变量。假如一个工程中有多个module,那每个version都需要在模块中定义一次,此处定义在工程build.gradle中,修改一个即可修改全部方便各个模块统一管理。有兴趣的同学可以网上搜着方面教程
4.定义签名文件
Properties props =newProperties()
props.load(newFileInputStream(rootProject.file("example.properties")))
signingConfigs{
release{
storeFile rootProject.file(props['keyStore'])
keyAliasprops['keyAlias']
keyPasswordprops["keyStorePassword"]
storePasswordprops['keyStorePassword']
}
debug{
}
}
为了安全,正式版签名文件一般不要直接写在gradle文件中,而是自定义一个properties文件,这个文件可以自己藏起来,哈哈。
首先定义一个propertie变量prop,用来装载你的自己的签名文件,此处我把签名文件定义为example.properties,放在工程根目录下,我的签名文件敏感信息都在prop中可以以键值对的形式读取。这样就完成了保密工作。
5。默认构建方式
defaultConfig{
ndk{
abiFilters"armeabi","armeabi-v7a","x86","mips","arm64-v8a"
}
minSdkVersionrootProject.ext.minSdkVersion
targetSdkVersionrootProject.ext.targetSdkVersion
versionCode rootProject.ext.versionCode
versionName rootProject.ext.versionName
signingConfigsigningConfigs.release }
此处定义的signingConfigsigningConfigs.release即为release版的签名信息
5.这个地方是重点,各位同学要认真
buildTypes{
release{
buildConfigField"boolean","LOG_DEBUG","true"
buildConfigField"String","HOST_API","\"https://api.saka.com/\""
minifyEnabledtrue
shrinkResourcesfalse
proguardFiles getDefaultProguardFile('proguard-android.txt'),'proguard-rules.pro'
zipAlignEnabledtrue
signingConfigsigningConfigs.release
productFlavors{
'xiaomi'{}
'360'{}
'wandoujia'{}
'yingyongbao'{}
'anzhi'{}
'lenovo'{}
'huawei'{}
'baidu'{}
'oppo'{}
'sougou'{}
'pp'{}
'letv'{}
'vivo'{}
'jinli'{}
'mumayi'{}
'eoe'{}
'liqu'{}
'gooplay'{}
'amazon'{}
'meizu'{}
'smartisan'{}
'samsung'{}
'wo'{}
'mm'{}
'anzow'{}
'yesky'{}
'2345'{}
'kuan'{}
'yingyonghui'{}
'beta'{}
'hisense'{}
}
productFlavors.all{flavor -> flavor.manifestPlaceholders = [UMENG_CHANNEL_VALUE:name]
}
applicationVariants.all{variant ->
variant.outputs.each{output ->
defoutputFile = output.outputFile
if(outputFile !=null&& outputFile.name.endsWith('.apk')){
//输出apk名称为XXX20160328_v1.0.0_vc10_XXXX_test.apk
deffileName ="ShangChaoLa${releaseTime()}_v${defaultConfig.versionName}_vc${defaultConfig.
versionCode}_${variant.productFlavors[0].name}.apk"
//控制输出的APK的存放路径
if(project.hasProperty('OUT_PUT_DIR_PARA')){
File output_dir1 = file("${OUT_PUT_DIR_PARA}");
output.outputFile =newFile(output_dir1, fileName)
println"输出文件位置:"+ output.outputFile
}else{
output.outputFile =newFile(outputFile.parent, fileName)
println"输出文件位置:"+ output.outputFile
}
}
}
}
}
debug{
buildConfigField"boolean","LOG_DEBUG","true"
buildConfigField"String","HOST_API","\"http://192.168.1.105:5000/api/\""
versionNameSuffix"-debug"
minifyEnabledtrue
zipAlignEnabledtrue
shrinkResourcesfalse
proguardFiles getDefaultProguardFile('proguard-android.txt'),'proguard-rules.pro'
signingConfigsigningConfigs.debug
}
}
此处定义了一些列内容
buildtype就是构建种类
首先看release版本
buildConfigField允许你自定义一个字段,这个字段接受三个参数,都是必须的,而且必须是用引号包裹的,否则无效。
第一个参数表示你的变量类型,第二个参数表示你的变量名称,第三个参数表示初始化的值。
buildConfigField "boolean", "LOG_DEBUG", "true"
相当于java中的boolean LOG_DEBUG=true;
在编译后会在系统的BuildConfig文件中生成一段代码
public static final booleanLOG_DEBUG=true;
此处你是可以在工程中使用的,假如你拥有自己的log输出工具类,可以用这个来控制是否输出日志。判断LOG_DEBUG是否为真,为真时输出日志,为假时禁止输出日志。
下面的HOST_API同样的原理,假如公司的测试服务器和正式服务器的地址不同,可以自定义一个这样的变量来存储API地址,不过要注意的是定义string类型时时必须要有双引号的,此时应使用转义符来正确表示API地址,否则不会生成正确的地址。
下面就是productflavors,定义好渠道后用
productFlavors.all{flavor -> flavor.manifestPlaceholders = [UMENG_CHANNEL_VALUE:name]
来替换掉manifiest文件中的placeholder
后边一段代买是用来输出正确的文件名称的。
好了多渠道打包就是这样的简单。不过这种操作方式在现在的技术来看有一个弊端就是时间需要非常长,我这么多包基本半个小时才能完成。
gradle的强大就是这样来的
美团多渠道打包采用另一种方式生成新包,基本1分钟之内搞定,等下一期在介绍。