内容简介:一、 在项目多渠道开发时,除了对不同的渠道除了做统计外,还可以对不同的渠道加载不同的代码及资源,具体的部署可以参考二、思路:一般单独拆分出的library基本都是将代码及资源打包成aar包并上传,为了使用方便,最好是在uploadArchives时就上传到不同的artifact下。当然也可以传到不 的group下,但若在一个项目中有多个library时,只需要对其中的某个子库(如core-ui分离下的ui库)进行上传时最好上传不同的artifact下,一般只需要在手动选择Build Variants后就动
一、 在项目多渠道开发时,除了对不同的渠道除了做统计外,还可以对不同的渠道加载不同的代码及资源,具体的部署可以参考 Android studio gradle中分渠道加载res、libraries及Class ;在模块化拆分后,若恰好在模块内部的代码及资源也要根据不同的渠道发布不同的aar包到nexus仓库,该怎么配置呢?
二、思路:一般单独拆分出的library基本都是将代码及资源打包成aar包并上传,为了使用方便,最好是在uploadArchives时就上传到不同的artifact下。当然也可以传到不 的group下,但若在一个项目中有多个library时,只需要对其中的某个子库(如core-ui分离下的ui库)进行上传时最好上传不同的artifact下,一般只需要在手动选择Build Variants后就动态修改要上传的POM_ARTIFACT_ID即可。
- 将POM_ARTIFACT_ID定义在library项目下的gradle.properties文件中,如:
POM_ARTIFACT_ID=account 复制代码
2.若library开发的项目有用于测试的demo app,需要在app gradle下配置:
// 在dependencies下正常引入
implementation project(':account')
//需要与library库创建对应的productFlavors
android{
…
flavorDimensions "mode"
publishNonDefault true
productFlavors {
official {}
mi {}
}
}
//需要指定编译配置
configurations {
officialDebug
miDebug
officialRelease
miRelease
}
复制代码
3.在library的build.gradle文件中创建不同的变体,并在选择不同的Build Variants后更新发布时使用的POM_ARTIFACT_ID:
// 在dependencies下正常引入
android{
flavorDimensions "mode"
productFlavors {
official {}
mi {}
}
// 取出当前选择的渠道名
def currentFlavor = getCurrentFlavor()
println "---> currentFlavor = $currentFlavor"
if ("mi".equalsIgnoreCase(currentFlavor)) {
// 取要指定默认发布要使用的configuration
defaultPublishConfig “miRelease”
// 在取出渠道名判断后更新POM_ARTIFACT_ID
replacePropertiesValue('POM_ARTIFACT_ID', 'account-mi')
} else {
defaultPublishConfig "officialRelease"
replacePropertiesValue('POM_ARTIFACT_ID', 'account')
}
}
// 取出当前选择的渠道名
def getCurrentFlavor() {
Gradle gradle = getGradle()
String taskStr = gradle.getStartParameter().getTaskRequests().toString()
println("taskStr:" + taskStr)
Pattern pattern
if (taskStr.contains("assemble")) {
pattern = Pattern.compile("assemble(\\w+)(Release|Debug)")
} else {
pattern = Pattern.compile("generate(\\w+)(Release|Debug)")
}
Matcher matcher = pattern.matcher(taskStr)
if (matcher.find()) {
return matcher.group(1)
}
return ""
}
// 替换library项目下的gradle.properties中的key-value值,key下value不同时才替换
def replacePropertiesValue(key, replaceValue) {
if (project.hasProperty(key)) {
def value = project.properties.get(key)
if (!replaceValue.equalsIgnoreCase(value)) {
ant.replace(file: "gradle.properties", token: "$key=$value", value: "$key=$replaceValue")
}
}
}
复制代码
至此就能成功的将aar包发布到远程nuxus仓库,若在demo工程里跑起来了。但在主项目里一样需要判断配置。
三、主项目工程配置
- 在主工程中配置的渠道需要包含library中包含的渠道:
productFlavors {
official {}
mi {}
Baidu{}
}
复制代码
- 需要使用上面的currentFlavor()函数获取当前编译的flavor再选择依赖的库:
dependencies{
def currentFlavor = getCurrentFlavor()
println "---> currentFlavor = $currentFlavor"
if ("mi".equalsIgnoreCase(currentFlavor)) {
// implementation mi版本库
} else {
// implementation official版本库
}
}
复制代码
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- 多渠道打包
- Android 多渠道打包配置
- Android官方多渠道方案详解
- Walle —— Android多渠道打包神器
- App 多渠道打包及重签名方案
- Android美团多渠道打包Walle集成
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
算法统治世界——智能经济的隐形秩序
徐恪、李沁 / 清华大学出版社有限公司 / 2017-11-15 / CNY 69.00
今天,互联网已经彻底改变了经济系统的运行方式,经济增长的决定性要素已经从物质资料的增加转变成为信息的增长。但是,只有信息的快速增长是不够的,这些增长的信息还必须是“有序”的。只有“有序”才能使信息具有价值,能够为人所用,能够指导我们实现商业的新路径。这种包含在信息里的隐形秩序才是今天信息世界的真正价值所在。经济系统的运行确实是纷繁复杂的,但因为算法的存在,这一切变得有律可循,算法也成为新经济系统里......一起来看看 《算法统治世界——智能经济的隐形秩序》 这本书的介绍吧!