在使用 Android Gradle 插件 3.3.0 合并资源期间构建失败

Posted

技术标签:

【中文标题】在使用 Android Gradle 插件 3.3.0 合并资源期间构建失败【英文标题】:build failing during merge resources with Android Gradle plugin 3.3.0 【发布时间】:2019-03-13 16:52:09 【问题描述】:

我的构建有很多不同的风格,它们都有特定的资源,我不想让我的项目中的 src 目录与一堆特定于风格的目录杂乱无章,所以我从另一个文件夹中添加源集我在 mergeResources 任务(mergeResources.doFirst)之前的项目。这对于过去几个版本的 android Gradle 插件(3.1.0-3.2.0 和一些 3.3.0-alpha 版本)一直有效,但在某个时候,3.3.0-alpha AGP 启动了在此 mergeResources 任务期间导致构建失败。

现在我不断得到:

在 35 秒内构建失败 16 个可操作的任务:15 个已执行,1 个是最新的 线程“ForkJoinPool.commonPool-worker-6”中的异常 java.lang.IllegalStateException:AAPT 进程管理器在使用守护进程时无法关闭 在 com.android.builder.internal.aapt.v2.Aapt2DaemonManager.shutdown(Aapt2DaemonManager.kt:96) 在 com.android.build.gradle.internal.res.namespaced.RegisteredAaptService.shutdown(Aapt2DaemonManagerService.kt:61) 在 com.android.build.gradle.internal.workeractions.WorkerActionServiceRegistry$shutdownAllRegisteredServices$1$1.run(WorkerActionServiceRegistry.kt:96) 在 java.util.concurrent.ForkJoinTask$RunnableExecuteAction.exec(ForkJoinTask.java:1402) 在 java.util.concurrent.ForkJoinTask.doExec(ForkJoinTask.java:289) 在 java.util.concurrent.ForkJoinPool$WorkQueue.runTask(ForkJoinPool.java:1056) 在 java.util.concurrent.ForkJoinPool.runWorker(ForkJoinPool.java:1692) 在 java.util.concurrent.ForkJoinWorkerThread.run(ForkJoinWorkerThread.java:157)

我的堆栈跟踪是:

任务“:app:mergeMainReleaseResources”执行失败。 java.util.concurrent.ExecutionException: com.android.builder.internal.aapt.v2.Aapt2InternalException: AAPT2 aapt2-3.3.0-alpha13-5013011-windows Daemon #0: Unexpected error during compile 'C:\Users\Alex\ Documents\Work\Android\project\app\productio n_resources\categories\fitness\res\drawable-xxxhdpi\background_4.png',试图停止守护进程。 这在正常情况下不应该发生,如果发生请提出问题。

例外情况是: org.gradle.api.tasks.TaskExecutionException:任务':app:mergeMainReleaseResources'的执行失败。 在 org.gradle.api.internal.tasks.execution.ExecuteActionsTaskExecuter.executeActions(ExecuteActionsTaskExecuter.java:110) 在 org.gradle.api.internal.tasks.execution.ExecuteActionsTaskExecuter.execute(ExecuteActionsTaskExecuter.java:77) 在 org.gradle.api.internal.tasks.execution.OutputDirectoryCreatingTaskExecuter.execute(OutputDirectoryCreatingTaskExecuter.java:51) 在 org.gradle.api.internal.tasks.execution.SkipUpToDateTaskExecuter.execute(SkipUpToDateTaskExecuter.java:59) 在 org.gradle.api.internal.tasks.execution.ResolveTaskOutputCachingStateExecuter.execute(ResolveTaskOutputCachingStateExecuter.java:54) 在 org.gradle.api.internal.tasks.execution.ValidatingTaskExecuter.execute(ValidatingTaskExecuter.java:59) 在 org.gradle.api.internal.tasks.execution.SkipEmptySourceFilesTaskExecuter.execute(SkipEmptySourceFilesTaskExecuter.java:101) 在 org.gradle.api.internal.tasks.execution.FinalizeInputFilePropertiesTaskExecuter.execute(FinalizeInputFilePropertiesTaskExecuter.java:44) 在 org.gradle.api.internal.tasks.execution.CleanupStaleOutputsExecuter.execute(CleanupStaleOutputsExecuter.java:91) 在 org.gradle.api.internal.tasks.execution.ResolveTaskArtifactStateTaskExecuter.execute(ResolveTaskArtifactStateTaskExecuter.java:62) 在 org.gradle.api.internal.tasks.execution.SkipTaskWithNoActionsExecuter.execute(SkipTaskWithNoActionsExecuter.java:59) 在 org.gradle.api.internal.tasks.execution.SkipOnlyIfTaskExecuter.execute(SkipOnlyIfTaskExecuter.java:54) 在 org.gradle.api.internal.tasks.execution.ExecuteAtMostOnceTaskExecuter.execute(ExecuteAtMostOnceTaskExecuter.java:43) 在 org.gradle.api.internal.tasks.execution.CatchExceptionTaskExecuter.execute(CatchExceptionTaskExecuter.java:34) 在 org.gradle.api.internal.tasks.execution.EventFiringTaskExecuter$1.run(EventFiringTaskExecuter.java:51) 在 org.gradle.internal.operations.DefaultBuildOperationExecutor$RunnableBuildOperationWorker.execute(DefaultBuildOperationExecutor.java:300) 在 org.gradle.internal.operations.DefaultBuildOperationExecutor$RunnableBuildOperationWorker.execute(DefaultBuildOperationExecutor.java:292) 在 org.gradle.internal.operations.DefaultBuildOperationExecutor.execute(DefaultBuildOperationExecutor.java:174) 在 org.gradle.internal.operations.DefaultBuildOperationExecutor.run(DefaultBuildOperationExecutor.java:90) 在 org.gradle.internal.operations.DelegatingBuildOperationExecutor.run(DelegatingBuildOperationExecutor.java:31) 在 org.gradle.api.internal.tasks.execution.EventFiringTaskExecuter.execute(EventFiringTaskExecuter.java:46) 在 org.gradle.execution.taskgraph.LocalTask​​InfoExecutor.execute(LocalTask​​InfoExecutor.java:42) 在 org.gradle.execution.taskgraph.DefaultTaskExecutionGraph$BuildOperationAwareWorkItemExecutor.execute(DefaultTaskExecutionGraph.java:277) 在 org.gradle.execution.taskgraph.DefaultTaskExecutionGraph$BuildOperationAwareWorkItemExecutor.execute(DefaultTaskExecutionGraph.java:262) 在 org.gradle.execution.taskgraph.DefaultTaskPlanExecutor$ExecutorWorker$1.execute(DefaultTaskPlanExecutor.java:135) 在 org.gradle.execution.taskgraph.DefaultTaskPlanExecutor$ExecutorWorker$1.execute(DefaultTaskPlanExecutor.java:130) 在 org.gradle.execution.taskgraph.DefaultTaskPlanExecutor$ExecutorWorker.execute(DefaultTaskPlanExecutor.java:200) 在 org.gradle.execution.taskgraph.DefaultTaskPlanExecutor$ExecutorWorker.executeWithWork(DefaultTaskPlanExecutor.java:191) 在 org.gradle.execution.taskgraph.DefaultTaskPlanExecutor$ExecutorWorker.run(DefaultTaskPlanExecutor.java:130) 在 org.gradle.internal.concurrent.ExecutorPolicy$CatchAndRecordFailures.onExecute(ExecutorPolicy.java:63) 在 org.gradle.internal.concurrent.ManagedExecutorImpl$1.run(ManagedExecutorImpl.java:46) 在 org.gradle.internal.concurrent.ThreadFactoryImpl$ManagedThreadRunnable.run(ThreadFactoryImpl.java:55)

原因:org.gradle.internal.UncheckedException: java.util.concurrent.ExecutionException: com.android.builder.internal.aapt.v2.Aapt2InternalException: AAPT2 aapt2-3.3.0-alpha13-5013011-windows 守护进程# 0: 编译 'C:\Users\Alex 期间出现意外错误 \Documents\Work\Android\project\app\production_resources\categories\fitness\res\drawable-xxxhdpi\background_4.png',试图停止守护进程。 这在正常情况下不应该发生,如果发生,请提出问题。 在 org.gradle.internal.UncheckedException.throwAsUncheckedException(UncheckedException.java:63) 在 org.gradle.internal.UncheckedException.throwAsUncheckedException(UncheckedException.java:40) 在 org.gradle.internal.reflect.JavaMethod.invoke(JavaMethod.java:76) 在 org.gradle.api.internal.project.taskfactory.IncrementalTask​​Action.doExecute(IncrementalTask​​Action.java:50) 在 org.gradle.api.internal.project.taskfactory.StandardTaskAction.execute(StandardTaskAction.java:39) 在 org.gradle.api.internal.project.taskfactory.StandardTaskAction.execute(StandardTaskAction.java:26) 在 org.gradle.api.internal.tasks.execution.ExecuteActionsTaskExecuter$1.run(ExecuteActionsTaskExecuter.java:131) 在 org.gradle.internal.operations.DefaultBuildOperationExecutor$RunnableBuildOperationWorker.execute(DefaultBuildOperationExecutor.java:300) 在 org.gradle.internal.operations.DefaultBuildOperationExecutor$RunnableBuildOperationWorker.execute(DefaultBuildOperationExecutor.java:292) 在 org.gradle.internal.operations.DefaultBuildOperationExecutor.execute(DefaultBuildOperationExecutor.java:174) 在 org.gradle.internal.operations.DefaultBuildOperationExecutor.run(DefaultBuildOperationExecutor.java:90) 在 org.gradle.internal.operations.DelegatingBuildOperationExecutor.run(DelegatingBuildOperationExecutor.java:31) 在 org.gradle.api.internal.tasks.execution.ExecuteActionsTaskExecuter.executeAction(ExecuteActionsTaskExecuter.java:120) 在 org.gradle.api.internal.tasks.execution.ExecuteActionsTaskExecuter.executeActions(ExecuteActionsTaskExecuter.java:99) ... 31 更多 引起:java.util.concurrent.ExecutionException:com.android.builder.internal.aapt.v2.Aapt2InternalException:AAPT2 aapt2-3.3.0-alpha13-5013011-windows 守护进程#0:编译时出现意外错误'C:\Users \Alex\Documents\Work\Android\project\app\ production_resources\categories\fitness\res\drawable-xxxhdpi\background_4.png',试图停止守护进程。 这在正常情况下不应该发生,如果发生,请提出问题。 在 com.android.ide.common.workers.ExecutorServiceAdapter.close(ExecutorServiceAdapter.kt:56) 在 com.android.build.gradle.internal.aapt.WorkerExecutorResourceCompilationService.close(WorkerExecutorResourceCompilationService.kt:67) 在 com.android.build.gradle.tasks.MergeResources.doFullTask​​Action(MergeResources.java:268) 在 com.android.build.gradle.internal.tasks.IncrementalTask​​.taskAction(IncrementalTask​​.java:106) 在 org.gradle.internal.reflect.JavaMethod.invoke(JavaMethod.java:73) ... 42 更多

原因:com.android.builder.internal.aapt.v2.Aapt2InternalException: AAPT2 aapt2-3.3.0-alpha13-5013011-windows Daemon #0: Unexpected error during compile 'C:\Users\Alex\Documents\ Work\Android\project\app\production_resources\categories\fitness\res\drawable-xxxhdpi\background_4.png',试图停止守护进程。 这在正常情况下不应该发生,如果发生,请提出问题。 在 com.android.builder.internal.aapt.v2.Aapt2Daemon.handleError(Aapt2Daemon.kt:148) 在 com.android.builder.internal.aapt.v2.Aapt2Daemon.compile(Aapt2Daemon.kt:88) 在 com.android.builder.internal.aapt.v2.Aapt2DaemonManager$LeasedAaptDaemon.compile(Aapt2DaemonManager.kt:170) 在 com.android.build.gradle.internal.res.Aapt2CompileWithBlameRunnable$run$1.invoke(Aapt2CompileWithBlameRunnable.kt:37) 在 com.android.build.gradle.internal.res.Aapt2CompileWithBlameRunnable$run$1.invoke(Aapt2CompileWithBlameRunnable.kt:28) 在 com.android.build.gradle.internal.res.namespaced.Aapt2DaemonManagerService.useAaptDaemon(Aapt2DaemonManagerService.kt:71) 在 com.android.build.gradle.internal.res.namespaced.Aapt2DaemonManagerService.useAaptDaemon$default(Aapt2DaemonManagerService.kt:69) 在 com.android.build.gradle.internal.res.Aapt2CompileWithBlameRunnable.run(Aapt2CompileWithBlameRunnable.kt:34) 在 com.android.ide.common.workers.ExecutorServiceAdapter$submit$submission$1.run(ExecutorServiceAdapter.kt:39)

原因:java.io.IOException: AAPT2 进程意外退出。错误输出: 在 com.android.builder.internal.aapt.v2.Aapt2DaemonImpl$WaitForTaskCompletion.err(Aapt2DaemonImpl.kt:309) 在 com.android.builder.internal.aapt.v2.Aapt2DaemonImpl$processOutput$1.err(Aapt2DaemonImpl.kt:75) 在 com.android.utils.GrabProcessOutput$1.run(GrabProcessOutput.java:104)

我认为 PNG 文件可能已损坏或标记不正确,但我已经通过一大堆转换运行它,我得到了同样的错误。

在测试期间,它工作正常,但在发布构建期间,我收到此错误。我已经使用 AS 3.2 和 AGP 3.2.0 进行生产构建,效果很好。此外,这仅适用于 Windows。它在我的 Mac 上运行良好。

我的 build.gradle 是:

apply plugin: 'com.android.application'
apply plugin: 'io.fabric'

android 
    compileSdkVersion rootProject.ext.compileSdkVersion
    buildToolsVersion '28.0.3'
    defaultConfig 
        applicationId "com.project.test"
        minSdkVersion rootProject.ext.minSdkVersion
        targetSdkVersion rootProject.ext.targetSdkVersion
        versionCode 37
        versionName "1.0"
        testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
        multiDexEnabled true
    

    dexOptions 
        jumboMode true
        javaMaxHeapSize "4g"
        preDexLibraries = false
    

    sourceSets 

        debug.setRoot('build-types/debug')
        release.setRoot('build-types/release')

        androidTest.setRoot('tests')
    

    signingConfigs 

        key 
            storeFile file(RELEASE_STORE_FILE)
            storePassword RELEASE_STORE_PASSWORD
            keyAlias RELEASE_KEY_ALIAS
            keyPassword RELEASE_KEY_PASSWORD
        

    

    buildTypes 

        debug 
            minifyEnabled false
        

        release 
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.txt'
            signingConfig signingConfigs.key
        
    

    flavorDimensions "default"

    productFlavors 

        main 
            versionName "0"
            buildConfigField "String", "CATEGORY", "\"fitness\""
            buildConfigField "String", "BUILD_VERSION", "\"$config.buildVersion\""
            dimension "default"
        

        flavors.each  name, flavor ->
            "$name" 
                applicationId = config.applicationId + "." + "$name"
                versionName = config.versionName
                versionCode = flavor.versionCode
                buildConfigField "String", "CATEGORY", "\"$flavor.category\""
                buildConfigField "String", "BUILD_VERSION", "\"$config.buildVersion\""
                buildConfigField "String", "APP_ID", "\"$name\""
                resValue "string", "APP_NAME", flavor.appName
                dimension "default"
            
        

    

    packagingOptions 
        exclude 'META-INF/rxjava.properties'
    

    configurations.all 
        resolutionStrategy.force 'com.google.code.findbugs:jsr305:3.0.1'
    

    compileOptions 
        sourceCompatibility JavaVersion.VERSION_1_8
        targetCompatibility JavaVersion.VERSION_1_8
    


dependencies 
    implementation fileTree(include: ['*.jar'], dir: 'libs')
    androidTestImplementation('com.android.support.test.espresso:espresso-core:3.0.1', 
        exclude group: 'com.android.support', module: 'support-annotations'
    )
    androidTestImplementation('com.android.support.test:runner:1.0.1', 
        exclude group: 'com.android.support', module: 'support-annotations'
    )
    implementation 'com.google.code.findbugs:jsr305:3.0.2'
    implementation "com.android.support:appcompat-v7:$rootProject.supportLibraryVersion"
    implementation "com.android.support:support-v4:$rootProject.supportLibraryVersion"
    implementation "com.android.support:design:$rootProject.supportLibraryVersion"
    implementation "com.android.support:cardview-v7:$rootProject.supportLibraryVersion"
    implementation "com.android.support:customtabs:$rootProject.supportLibraryVersion"
    implementation 'com.android.support:multidex:1.0.3'
    implementation 'com.android.billingclient:billing:1.1'
    implementation "com.squareup.retrofit2:retrofit:$rootProject.retrofitVersion"
    implementation "com.squareup.retrofit2:converter-gson:$rootProject.retrofitVersion"
    implementation "com.squareup.retrofit2:adapter-rxjava2:$rootProject.retrofitVersion"
    implementation 'com.squareup.okhttp3:okhttp:3.11.0'
    implementation 'com.google.code.gson:gson:2.8.5'
    implementation "com.facebook.fresco:fresco:$rootProject.frescoVersion"
    implementation "com.facebook.fresco:animated-gif:$rootProject.frescoVersion"
    implementation "com.google.android.gms:play-services-auth:$rootProject.playServicesVersion"
    implementation "com.google.android.gms:play-services-gcm:$rootProject.playServicesVersion"
    implementation "com.google.android.gms:play-services-base:$rootProject.playServicesVersion"
    implementation "com.google.android.gms:play-services-ads:$rootProject.playServicesVersion"
    implementation('com.crashlytics.sdk.android:crashlytics:2.9.4@aar') 
        transitive = true
    
    implementation 'com.mixpanel.android:mixpanel-android:5.2.1'
    implementation "com.google.dagger:dagger:$rootProject.daggerVersion"
    implementation "com.google.dagger:dagger-android-support:$rootProject.daggerVersion"
    annotationProcessor "com.google.dagger:dagger-compiler:$rootProject.daggerVersion"
    implementation "com.jakewharton:butterknife:$rootProject.butterknifeVersion"
    annotationProcessor "com.jakewharton:butterknife-compiler:$rootProject.butterknifeVersion"
    implementation 'io.reactivex.rxjava2:rxandroid:2.0.2'
    implementation 'io.reactivex.rxjava2:rxjava:2.2.0'
    implementation 'com.github.JakeWharton:ViewPagerIndicator:2.4.1'
    implementation "com.google.android.exoplayer:exoplayer-core:$rootProject.exoPlayerVersion"
    implementation "com.google.android.exoplayer:exoplayer-hls:$rootProject.exoPlayerVersion"
    implementation "com.google.android.exoplayer:exoplayer-ui:$rootProject.exoPlayerVersion"
    testImplementation 'junit:junit:4.12'


android.applicationVariants.all  variant ->
    def category
    variant.productFlavors.each  flavor ->
        flavor.buildConfigFields.each  key, value ->
            if (key == "CATEGORY") 
                category = value.value.substring(1, value.value.length() - 1)
            
        
    
    variant.mergeResources.doFirst 
        android.sourceSets."$variant.productFlavors.get(0).name".res.srcDirs =
                ["production_resources/flavors/$variant.productFlavors.get(0).name/res",
                 "production_resources/categories/$category/res"]
    


afterEvaluate 
    tasks.matching 
        it.name.startsWith('dex')
    .each  dx ->
        if (dx.additionalParameters == null) 
            dx.additionalParameters = []
        
        dx.additionalParameters += '--multi-dex'
        dx.additionalParameters += "--main-dex-list=$projectDir/<filename>".toString()
    


apply plugin: 'com.google.gms.google-services'

【问题讨论】:

哦,这看起来超级有趣。您介意在问题跟踪器上提交问题,以便 Android Studio 团队可以查看吗? @IzabelaOrlowska 我已将问题发布到跟踪器。 issuetracker.google.com/issues/117900475 感谢您填写问题! 从 3.2.1 升级到 3.3.0 后也一样。清理了所有东西(缓存、Gradle 文件夹)——不走运。在 Mac 上工作,但在 Windows 上失败。这是非常可悲的,因为我一直在 Windows 上进行 Android 开发,它在那里工作得更快。失败的资源大小超过 2MB。 另外,它与Android Studio 3.3直接无关。我能够使用 AS 3.3,但必须使用 AGP 3.2.1 进行编译才能在 Windows 上工作。 【参考方案1】:

2019 年 4 月 19 日更新

此问题已在Android Gradle Plugin 3.4.0 中修复。

升级到 Android Studio 3.4.0 后,可以删除原始答案中建议的临时修复。万岁!

原创

这是 Android Gradle 插件 3.3.0 中的 AAPT2 中的一个错误,在构建具有较大 png(大约 2-3 mb 及以上)的项目时。

@akong9759 在 Google 的问题跟踪器上为此创建了一个问题,该问题已得到修复。

https://issuetracker.google.com/issues/117900475

该问题已在 Android Gradle Plugin 3.5.0-alpha03 中修复,修复计划在 3.4.0 版本中发布。

已针对该问题建议对 Android Gradle 插件 3.3.0 进行临时修复。将以下内容添加到项目build.gradle

allprojects 
    // Workaround for https://issuetracker.google.com/117900475
    // Remove when upgrading to AGP 3.4 or higher.
    configurations.matching  it.name == '_internal_aapt2_binary' .all  config ->
        config.resolutionStrategy.eachDependency  details ->
            details.useVersion("3.5.0-alpha03-5252756")
        
    

【讨论】:

直到 3.4.0 出来,这似乎是最好的答案,像魅力一样工作! 我尝试在我的项目 build.gradle 中添加它,但它没有解决任何问题。我很好奇..configures.matching 是否需要替换现有的configurations.all 部分? 如果您使用的是 nativescript,这仍然是目前唯一可行的解​​决方案。感谢分享! 今天我更新了 studio 到 3.4.0,gradle 插件到 3.4.0,分发 URL 中的 5.1.1。执行此更新后,我收到错误消息:“AAPT2 aapt2-3.5.0-alpha03-5252756-windows Daemon #7: Daemon startup failed”。请帮忙。 这似乎也是 Cordova 的唯一实际解决方案【参考方案2】:

我有同样的问题。该构建会破坏并提及不同的 png 文件,例如您的 background_4.png,但仅限于 Windows PC。在 Mac 上构建没有问题。

在我的情况下,图像大小是问题所在。只有大于 2MB 的图像才被缝合以破坏构建。在将每个图像缩小到小于 2MB 之后,构建又开始工作了。

【讨论】:

已确认,自从我从 GNU/Linux 切换到 Windows 后也遇到了这个问题。将大小减小到低于 2MB 确实解决了这个问题。我想知道为什么会这样,也许有办法以某种方式对其进行调整以正确处理此类图像 这是一个不错的发现,但考虑到在 2.2.1 上一切正常,并且在 Mac 上与 3.3.0 一起使用相同的项目,我当然不急于减小文件大小。它看起来像是“他们”方面的错误。 也为我工作。逆天。我刚刚将我所有的资产转换为 .webp 并且构建得很好。【参考方案3】:

仔细检查您的布局 xml 文件,我的问题是重复 xml

<?xml version="1.0" encoding="utf-8"?>

【讨论】:

这不是 XML 的问题,而是尝试换出 png 文件。我所有的 XML 资源都很好,否则它无法在我的 Mac 或旧版本的 AS 上运行。【参考方案4】:

您需要验证您的 layout.xml 文件。可能有问题。 我在布局文件上遇到了同样的错误并修复了问题。它对我有用。

【讨论】:

【参考方案5】:

我在使用 android 3.5.3 时遇到了同样的问题,上述解决方案不适用于我,但我发现 android studio 无法在颜色和矢量图像之间建立链接 我在向量中的代码看起来像这样

<vector android: android:tint="@color/colorPrimary"
    android:viewportHeight="24.0" android:viewportWidth="24.0"
    android: xmlns:android="http://schemas.android.com/apk/res/android">
    <path android:fillColor="@color/colorPrimary" android:pathData="M8,5v14l11,-7z"/>
</vector>

当我将@color/colorPrimary 更改为颜色代码#F44336 时效果很好

<vector android: android:tint="#F44336"
    android:viewportHeight="24.0" android:viewportWidth="24.0"
    android: xmlns:android="http://schemas.android.com/apk/res/android">
    <path android:fillColor="#F44336" android:pathData="M8,5v14l11,-7z"/>
</vector>

希望对你有帮助

【讨论】:

【参考方案6】:

您需要清理旧的 gradle 和 maven 依赖项缓存。例如,尝试删除.m2.gradle 下的文件,然后Invalidate Caches / Restart ...

另外,可以尝试通过在gradle.properties 中将enableAapt2 设置为false 来禁用gradle.properties

android.enableAapt2=false

【讨论】:

不,在从项目中清除 .gradle 以及从我的用户目录中清除 .gradle 和 .m2 并使缓存 /restart 无效后,同样的问题 /restart 可以发布您的build.gradle 吗?可能 buildToolsVersion 很重要。 就因为这个而清除整个.m2 (1GB+)?互联网对某些人来说并不便宜。【参考方案7】:

从日志看来,您的一个 png 图像可能已损坏,请尝试替换或删除它并尝试构建。

\res\drawable-xxxhdpi\background_4.png

【讨论】:

有什么方法可以确认它已损坏或修复文件本身?我尝试在图像编辑器中打开它并导出为 png,但这并没有解决它。【参考方案8】:

如果您要更改变体,它会自动配置自己... 意味着如果您要免费运行(从内置变体中选择),则付费风味将是红色的,反之亦然。

【讨论】:

不是这样的。我知道构建变体是如何工作的,但它不能满足我的需要。【参考方案9】:

在这个问题上花了一整天的时间后,我通过简单地获取GIMP并将PNG文件转换为JPG、as suggested by someone in google issue tracking来解决它。

它创造了奇迹,我不需要更改任何其他文件、包版本或设置。

【讨论】:

【参考方案10】:

对我来说,删除所有构建文件夹并重新启动系统并重新打开 Android Studio 在调试模式下工作。

更新:

我的一个 png 出现错误 : error: failed to read PNG signature: file does not start with PNG signature 我在 png 中再次打开并导出。现在它适用于每个构建变体。并删除一个零字节png。如果有效,任何人都会让它变得美丽/谢谢

【讨论】:

【参考方案11】:

我在缩小图像尺寸后解决了这个问题。

注意导致问题的图像与其他图像之间的尺寸差异,您会发现它的尺寸很大。

【讨论】:

【参考方案12】:

解决方案:-

刚刚删除了drawable-xxxhdpi\background_4.png并通过运行ionic cordova resources android --force重新生成了android资源

【讨论】:

以上是关于在使用 Android Gradle 插件 3.3.0 合并资源期间构建失败的主要内容,如果未能解决你的问题,请参考以下文章

在Android Studio中将Gradle从3.3升级到4.1后出错

AndroidStudio gradle插件和Gradle版本对应表

Android开发:《Gradle Recipes for Android》阅读笔记(翻译)3.3——整合resource文件

如何在android studio中查看当前使用的gradle版本和gradle插件版本

如何在android studio中查看当前使用的gradle版本和gradle插件版本

如何在android studio中查看当前使用的gradle版本和gradle插件版本