Android-根据buildType和flavor的组合生成所有可能的.apk
我们有一个应用程序,它有3种不同的构建类型(alpha、beta、release)和不同的风格(英国、美国…),基于部署的国家/地区) 不是手动编译buildType和Flavor的每个组合,而是有一个Gradle任务来一次性生成它们(uk alpha、uk beta、uk release、usa alpha、usa beta、usa release等) 编辑:渐变文件(不带LIB)Android-根据buildType和flavor的组合生成所有可能的.apk,android,gradle,android-productflavors,android-build-type,Android,Gradle,Android Productflavors,Android Build Type,我们有一个应用程序,它有3种不同的构建类型(alpha、beta、release)和不同的风格(英国、美国…),基于部署的国家/地区) 不是手动编译buildType和Flavor的每个组合,而是有一个Gradle任务来一次性生成它们(uk alpha、uk beta、uk release、usa alpha、usa beta、usa release等) 编辑:渐变文件(不带LIB) 您可以使用命令行 /加德勒建筑 或者在android studio应用程序->任务->构建->构建中使用渐变菜单
您可以使用命令行 /加德勒建筑 或者在android studio应用程序->任务->构建->构建中使用渐变菜单
它将在app/build/outputs/apk中生成所有apk我认为
assembly
任务可以做到这一点。@JBirdVegas我尝试过Gradle构建,但这给了我一个错误:@Karakuri我尝试过在Android Studio的Gradle视图中运行“Gradle assemble”,但没有输出任何apk。我生成.apk的唯一方法是通过Build->generate signed apk,然后输出我想要的apk版本,将您的Build.gradle
文件与实际错误一起发布。执行完整生成任务时从命令行获取错误。听起来你们的口味不太好,伙计们,谢谢你们的帮助。我刚刚注意到,我在android studio中使用向导生成的文件是在模块根文件夹中生成的,但使用gradle build生成的apk位于app/build/output/apk中。我仍然没有找到密钥库的错误,但这不是本主题的重点。我得到以下信息:未找到id为'com.android.application'的插件。
repositories {
flatDir {
dirs 'libs'
}
}
final VERSION_MAJOR = 0
final VERSION_MINOR = 7
final VERSION_PATCH = 1
android {
defaultConfig {
applicationId "com.app"
multiDexEnabled true
versionName "${VERSION_MAJOR}.${VERSION_MINOR}.${VERSION_PATCH}"
versionCode VERSION_MAJOR * 10000000 + VERSION_MINOR * 100000 + VERSION_PATCH * 1000
}
signingConfigs {
release {
keyAlias 'xxx'
keyPassword 'xxx'
storeFile file('xxx')
storePassword 'xxx'
}
}
dexOptions {
preDexLibraries = true
javaMaxHeapSize "2g"
}
buildTypes {
release {
minifyEnabled true
debuggable false
versionNameSuffix ".0-release_location-on_live-server"
signingConfig signingConfigs.release
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
}
beta {
versionNameSuffix ".1-beta_location-off_live-server"
minifyEnabled true
debuggable true
signingConfig signingConfigs.release
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
}
alpha {
versionNameSuffix ".2-alpha_location_off_test-server"
minifyEnabled false
debuggable true
}
debug {
versionNameSuffix ".3-debug_location_off_test-server"
minifyEnabled false
debuggable true
}
}
productFlavors {
uk {
minSdkVersion 16
targetSdkVersion 24
}
usa {
minSdkVersion 16
targetSdkVersion 24
}
}
compileOptions {
sourceCompatibility JavaVersion.VERSION_1_7
targetCompatibility JavaVersion.VERSION_1_7
}
packagingOptions {
exclude 'META-INF/DEPENDENCIES'
exclude 'META-INF/DEPENDENCIES.txt'
exclude 'META-INF/LICENSE.txt'
exclude 'META-INF/NOTICE'
exclude 'META-INF/NOTICE.txt'
exclude 'META-INF/LICENSE'
exclude 'META-INF/LICENSE.txt'
exclude 'META-INF/notice.txt'
exclude 'META-INF/license.txt'
exclude 'META-INF/dependencies.txt'
exclude 'META-INF/LGPL2.1'
exclude 'META-INF/ASL2.0'
exclude 'META-INF/services/javax.annotation.processing.Processor'
exclude 'META-INF/rxjava.properties'
exclude 'META-INF/rxandroid.properties'
}
lintOptions {
checkReleaseBuilds false
abortOnError true
disable 'InvalidPackage'
}
applicationVariants.all { variant ->
// if(variant.buildType.name.equals("release"))
// variant.versionCode += 0
// if(variant.buildType.name.equals("beta"))
// variant.versionCode += 1
// if(variant.buildType.name.equals("debug"))
// variant.versionCode += 2
variant.outputs.each { output ->
output.outputFile = new File(
output.outputFile.parent,
output.outputFile.name.replace(".apk", "-${variant.versionName}.apk"))
}
}
}
afterEvaluate {
tasks.matching {
it.name.startsWith('dex')
}.each { dx ->
if (dx.additionalParameters == null) {
dx.additionalParameters = ['--multi-dex']
} else {
dx.additionalParameters += '--multi-dex'
}
}
}
dependencies {
... libs ...
}