Android Studio 3.0体验维度问题

q3aa0525  于 2022-12-30  发布在  Android
关注(0)|答案(7)|浏览(157)

升级到工作室金丝雀建设。我以前的项目电报信使是给以下错误。
错误:所有风味现在必须属于一个命名的风味维度。风味“armv7”未分配给风味维度。有关详细信息,请访问https://d.android.com/r/tools/flavorDimensions-missing-error-message.html
我该怎么办?我已经看到了那个链接,但不知道该怎么办。我有3个版本的变种,现在,释放,调试和自由/开源软件。

eoxn13cs

eoxn13cs1#

如果你真的不需要这个机制,只需在build.gradlebuild.gradle.kts中指定一个随机的风味维度:

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

有关详细信息,请查看迁移指南

20jt8wwn

20jt8wwn2#

经过尝试和仔细阅读,我自己解决了这个问题。解决方法是在build.gradle中添加以下行。
flavor尺寸“版本代码”

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

7eumitmz3#

您可以在此处解决此问题,您需要使用productFlavors的名称添加flavorDimension,还需要定义维度,请参见以下示例,有关详细信息,请参见此处https://developer.android.com/studio/build/gradle-plugin-3-0-0-migration.html

flavorDimensions 'yourAppName' //here defined dimensions
productFlavors {
    production {
        dimension 'yourAppName' //you just need to add this line
        //here you no need to write applicationIdSuffix because by default it will point to your app package which is also available inside manifest.xml file.

    }

    staging {
        dimension 'yourAppName' //added here also
        applicationIdSuffix ".staging"//(.staging) will be added after your default package name.
        //or you can also use applicationId="your_package_name.staging" instead of applicationIdSuffix but remember if you are using applicationId then You have to mention full package name.
        //versionNameSuffix "-staging"

    }

    develop {
        dimension 'yourAppName' //add here too
        applicationIdSuffix ".develop"
        //versionNameSuffix "-develop"

    }
ehxuflar

ehxuflar4#

如果不想使用尺寸,则应使用此行

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"
  ...
    }
  }
}
...
eufgjt7s

eufgjt7s5#

我在build. gradle中为我的应用程序使用了flavorDimensions(模块:应用程序)

flavorDimensions "tier"

productFlavors {
    production {
        flavorDimensions "tier"
        //manifestPlaceholders = [appName: APP_NAME]
        //signingConfig signingConfigs.config
    }
    staging {
        flavorDimensions "tier"
        //manifestPlaceholders = [appName: APP_NAME_STAGING]
        //applicationIdSuffix ".staging"
        //versionNameSuffix "-staging"
        //signingConfig signingConfigs.config
    }
}

查看此链接了解更多信息

// Specifies two flavor dimensions.
flavorDimensions "tier", "minApi"

productFlavors {
     free {
            // Assigns this product flavor to the "tier" flavor dimension. Specifying
            // this property is optional if you are using only one dimension.
            dimension "tier"
            ...
     }

     paid {
            dimension "tier"
            ...
     }

     minApi23 {
            dimension "minApi"
            ...
     }

     minApi18 {
            dimension "minApi"
            ...
     }
}
5anewei6

5anewei66#

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

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

}
f45qwnt8

f45qwnt87#

如果您有简单的风格(免费/专业版、演示版/完整版等),请添加到build.gradle文件:

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

通过尺寸,您可以创建“口味中的口味”。

相关问题