升级到Studio Canary构建。我以前的Telegram Messenger项目是给以下错误。

错误:所有口味现在必须属于一个命名的口味维度。风味'armv7'没有分配到风味维度。更多信息请访问https://d.android.com/r/tools/flavorDimensions-missing-error-message.html

我该怎么办?我已经看到了这个链接,但不知道该怎么做。我现在有3个版本,发布版本,调试版本和自由/开源版本。


当前回答

如果您真的不需要这种机制,只需在构建中指定一个随机的风味维度。Gradle或build.gradle.kts:

android { 
    ...
    flavorDimensions("default")
    ...
}

有关更多信息,请查看迁移指南

其他回答

如果您真的不需要这种机制,只需在构建中指定一个随机的风味维度。Gradle或build.gradle.kts:

android { 
    ...
    flavorDimensions("default")
    ...
}

有关更多信息,请查看迁移指南

在KotlinDSL中,你可以这样使用:

flavorDimensions ("PlaceApp")
productFlavors {
    create("tapsi") {
        setDimension("PlaceApp")
        buildConfigField("String", "API_BASE_URL", "https://xxx/x/x/")
    }

}

经过尝试和仔细阅读,我自己解决了。 解决方案是在build.gradle中添加以下行。

flavorDimensions“versionCode”

android { 
       compileSdkVersion 24
       .....
       flavorDimensions "versionCode"
} 

如果您有简单的口味(免费/专业,演示/完整等),然后添加到构建。gradle文件:

android {
...
flavorDimensions "version"
productFlavors {
        free{
            dimension "version"
            ...
            }
        pro{
            dimension "version"
            ...
            }
}

通过维度,您可以创建“口味中的口味”。阅读更多。

如果你不想用尺寸,你应该用这条线

android { 
compileSdkVersion 24

...
flavorDimensions "default"
...
}

但是如果你想使用维度,你应该先声明你的维度名,然后再使用这个名称 这个例子来自文档:

android {
...
buildTypes {
debug {...}
release {...}
}

  // Specifies the flavor dimensions you want to use. The order in which you
  // list each dimension determines its priority, from highest to lowest,
  // when Gradle merges variant sources and configurations. You must assign
  // each product flavor you configure to one of the flavor dimensions.
  flavorDimensions "api", "mode"

  productFlavors {
    demo {
  // Assigns this product flavor to the "mode" flavor dimension.
  dimension "mode"
  ...
}

full {
  dimension "mode"
  ...
}

// Configurations in the "api" product flavors override those in "mode"
// flavors and the defaultConfig block. Gradle determines the priority
// between flavor dimensions based on the order in which they appear next
// to the flavorDimensions property above--the first dimension has a higher
// priority than the second, and so on.
minApi24 {
  dimension "api"
  minSdkVersion 24
  // To ensure the target device receives the version of the app with
  // the highest compatible API level, assign version codes in increasing
  // value with API level. To learn more about assigning version codes to
  // support app updates and uploading to Google Play, read Multiple APK Support
  versionCode 30000 + android.defaultConfig.versionCode
  versionNameSuffix "-minApi24"
  ...
}

minApi23 {
  dimension "api"
  minSdkVersion 23
  versionCode 20000  + android.defaultConfig.versionCode
  versionNameSuffix "-minApi23"
  ...
}

minApi21 {
  dimension "api"
  minSdkVersion 21
  versionCode 10000  + android.defaultConfig.versionCode
  versionNameSuffix "-minApi21"
  ...
    }
  }
}
...