web-dev-qa-db-ja.com

Android Gradleプラグイン3.3.0を使用したリソースのマージ中にビルドが失敗する

私のビルドには特定のリソースを持つさまざまなフレーバーがあり、プロジェクトの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が実行され、スレッド "ForkJoinPool.commonPool-worker-6" Java.lang.IllegalStateExceptionで1つの最新の例外:デーモンがcomで使用されている間、AAPTプロセスマネージャーをシャットダウンできません。 com.Android.build.gradle.internal.res.namespaced.RegisteredAaptService.shutdown(Aapt2DaemonManagerService.kt:61)のcom.Android。のAndroid.builder.internal.aapt.v2.Aapt2DaemonManager.shutdown(Aapt2DaemonManager.kt:96) build.gradle.internal.workeractions.WorkerActionServiceRegistry $ shutdownAllRegisteredServices $ 1 $ 1.run(WorkerActionServiceRegistry.kt:96)at Java.util.concurrent.ForkJoinTask $ RunnableExecuteAction.exec(ForkJoinTask.Java:1402)at Java.util.concurrent.ForkJoinTask doExec(ForkJoinTask.Java:289)at Java.util.concurrent.ForkJoinPool $ WorkQueue.runTask(ForkJoinPool.Java:1056)at Java.util.concurrent.ForkJoinPool.runWorker(ForkJoinPool.Java:1692)at 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:コンパイル中の予期しないエラー '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)at org.gradle.api.internal.tasks.execution.ExecuteActionsTaskExecuter.execute(ExecuteActionsTaskExecuter.Java:77)at org.gradle org.gradle.api.internal.tasks.execution.SkipUpToDateTaskExecuter.execute(SkipUpToDateTaskExecuter.Java:59)at org.gradle.api.internalの.api.internal.tasks.execution.OutputDirectoryCreatingTaskExecuter.execute(OutputDirectoryCreatingTaskExecuter.Java:51) org.gradle.api.internal.tasks.execution.ValidatingTaskExecuter.execute(ValidatingTaskExecuter.Java:59)at org.gradle.api.internal.tasks.executionの.tasks.execution.ResolveTaskOutputCachingStateExecuter.execute(ResolveTaskOutputCachingStateExecuter.Java:54) org.gradleのorg.gradle.api.internal.tasks.execution.FinalizeInputFilePropertiesTaskExecuter.execute(FinalizeInputFilePropertiesTaskExecuter.Java:44)の.SkipEmptySourceFilesTaskExecuter.execute(SkipEmptySourceFilesTaskExecuter.Java:101) org.gradle.api.internal.tasks.execution.ResolveTaskArtifactStateTaskExecuter.execute(ResolveTaskArtifactStateTaskExecuter.Java:62)at .api.internal.tasks.execution.CleanupStaleOutputsExecuter.execute(CleanupStaleOutputsExecuter.Java:91)at org.gradle.api.in org.gradle.api.internal.tasks.execution.SkipOnlyIfTaskExecuter.execute(SkipOnlyIfTaskExecuter.Java:54)at org.gradle.api.internal.cuts.exeの.tasks.execution.SkipTaskWithNoActionsExecuter.execute(SkipTaskWithNoActionsExecuter.Java:59) ExecuteAtMostOnceTaskExecuter.execute(ExecuteAtMostOnceTaskExecuter.Java:43)at org.gradle.api.internal.tasks.execution.CatchExceptionTaskExecuter.execute(CatchExceptionTaskExecuter.Java:34)at org.gradle.api.internal.tasks.execution.EventFiringTaskExecuter $ 1。 org.gradle.internal.operations.DefaultBuildOperationExecutor $ RunnableBuildOperationWorker.execute(DefaultBuildOperationExecutor.Java:300)at org.gradle.internal.operations.DefaultBuildOperationEのrun(EventFiringTaskExecuter.Java:51) xecutor $ RunnableBuildOperationWorker.execute(DefaultBuildOperationExecutor.Java:292)at org.gradle.internal.operations.DefaultBuildOperationExecutor.execute(DefaultBuildOperationExecutor.Java:174)at org.gradle.internal.operations.DefaultBuildOperationExecutor.run(DefaultBuildOperationExecutor.Java:Java) org.gradle.internal.operations.DelegatingBuildOperationExecutor.run(DelegatingBuildOperationExecutor.Java:31)at org.gradle.api.internal.tasks.execution.EventFiringTaskExecuter.execute(EventFiringTaskExecuter.Java:46)at org.gradle.execution.taskgraph org.gradle.execution.taskgraph.DefaultTaskExecutionGraph $ BuildOperationAwareWorkItemExecutor.execute(DefaultTaskExecutionGraph.Java:277)at。 :262)at org.gradle.execution.taskgraph.DefaultTaskPlanExecutor $ ExecutorWorker $ 1.execute(DefaultTaskPlanEx ecutor.Java:135)org.gradle.execution.taskgraph.DefaultTaskPlanExecutor $ ExecutorWorker $ 1.execute(DefaultTaskPlanExecutor.Java:130)at org.gradle.execution.taskgraph.DefaultTaskPlanExecutor $ ExecutorWorker.execute(DefaultTaskPlanExecutor.Java:200) org.gradle.execution.taskgraph.DefaultTaskPlanExecutor $ ExecutorWorker.executeWithWork(DefaultTaskPlanExecutor.Java:191)at org.gradle.execution.taskgraph.DefaultTaskPlanExecutor $ ExecutorWorker.run(DefaultTaskPlanExecutor.Java:130)at org.gradle.internal ExecutorPolicy $ CatchAndRecordFailures.onExecute(ExecutorPolicy.Java:63)at org.gradle.internal.concurrent.ManagedExecutorImpl $ 1.run(ManagedExecutorImpl.Java:46)at org.gradle.internal.concurrent.ThreadFactoryImpl $ ManagedThreadRunnable.Java(ThreadFactoryImpl.JavaFactory :55)

原因:org.gradle.internal.UncheckedException:Java.util.concurrent.ExecutionException:com.Android.builder.internal.aapt.v2.Aapt2InternalException:AAPT2 aapt2-3.3.0-alpha13-5013011-windows Daemon#0:Unexpectedコンパイル中のエラー '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)at org.gradle.internal.UncheckedException.throwAsUncheckedException(UncheckedException.Java:40)at org.gradle.internal.reflect.JavaMethod.invoke(JavaMethod.Java :76)org.gradle.api.internal.project.taskfactory.IncrementalTask​​Action.doExecute(IncrementalTask​​Action.Java:50)at org.gradle.api.internal.project.taskfactory.StandardTaskAction.execute(StandardTaskAction.Java:39)at org.gradleのorg.gradle.api.internal.project.taskfactory.StandardTaskAction.execute(StandardTaskAction.Java:26)at org.gradle.api.internal.tasks.execution.ExecuteActionsTaskExecuter $ 1.run(ExecuteActionsTaskExecuter.Java:131)at org.gradle org.gradle.internal.operations.DefaultBuildOperationExecutor $ RunnableBuildOperationWorker.execute(DefaultBuildOperationExecutor.Java:292)at .org.gradle.internal.operatiの.internal.operations.DefaultBuildOperationExecutor $ RunnableBuildOperationWorker.execute(DefaultBuildOperationExecutor.Java:300) ons.DefaultBuildOperationExecutor.execute(DefaultBuildOperationExecutor.Java:174)at org.gradle.internal.operations.DefaultBuildOperationExecutor.run(DefaultBuildOperationExecutor.Java:90)at org.gradle.internal.operations.DelegatingBuildOperationExecutor.run(DelegatingBuildOperationExecutor.Java:174) org.gradle.api.internal.tasks.execution.ExecuteActionsTaskExecuter.executeAction(ExecuteActionsTaskExecuter.Java:120)at 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 Daemon#0:コンパイル中の予期しないエラー 'C:\ Users\Alex\Documents\Work\Android\project\app\production_resources\categories\fitness\res\drawable-xxxhdpi\background_4.png '、デーモンを停止しようとしています。これは通常の状況では発生しません。発生した場合は問題を報告してください。 com.Android.build。at com.Android.ide.common.workers.ExecutorServiceAdapter.close(ExecutorServiceAdapter.kt:56)at com.Android.build.gradle.internal.aapt.WorkerExecutorResourceCompilationService.close(WorkerExecutorResourceCompilationService.kt:67)at com.Android.build .gradle.tasks.MergeResources.doFullTask​​Action(MergeResources.Java:268)at com.Android.build.gradle.internal.tasks.IncrementalTask​​.taskAction(IncrementalTask​​.Java:106)at 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:コンパイル中の予期しないエラー '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)at com.Android.builder.internal.aapt.v2.Aapt2Daemon.compile(Aapt2Daemon.kt:88)at com.Android .builder.internal.aapt.v2.Aapt2DaemonManager $ LeasedAaptDaemon.compile(Aapt2DaemonManager.kt:170)at com.Android.build.gradle.internal.res.Aapt2CompileWithBlameRunnable $ run $ 1.invoke(Aapt2CompileWithBlameRunnable.kt:37) Android.build.gradle.internal.res.Aapt2CompileWithBlameRunnable $ run $ 1.invoke(Aapt2CompileWithBlameRunnable.kt:28)at com.Android.build.gradle.internal.res.namespaced.Aapt2DaemonManagerService.useAaptDaemon(Aapt2DaemonManagerService.kt:71)at71 .Android.build.gradle.internal.res.namespaced.Aapt2DaemonManagerService.useAaptDaemon $ default(Aapt2DaemonManagerService.kt:69)at com.Android.build.gradle.internal.res.Aapt2CompileWithBlameRunnable.run(Aapt2CompileWithBlameRunnable.kt:34) .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)at com.Android.builder.internal.aapt.v2.Aapt2DaemonImpl $ processOutput $ 1.err(Aapt2DaemonImpl。 kt:75)at 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'
26
akong9759

2019年4月19日更新

この問題は、Android Gradle Plugin 3.4.0で修正されました。

Android St​​udio 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 Plugin 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")
        }
    }
}
38

同じ問題がありました。ビルドは壊れて、background_4.pngのような異なるpngファイルに言及しますが、これはWindows PCのみです。 Macでのビルドには問題がありませんでした。

私の場合、画像サイズが問題でした。ビルドを壊すために2MBを超えるイメージのみが継ぎ合わされます。すべてのイメージを2MB未満に縮小した後、ビルドは再び機能し始めました。

17
Stefan Lösing

私の場合の問題は、xmlが重複していたので、レイアウトxmlファイルを慎重に確認してください

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

Layout.xmlファイルを確認する必要があります。何か問題がある可能性があります。同じエラーが発生し、レイアウトファイルの問題を修正しました。それは私のために働いた。

1
Arti patel

解決:-

Drawable-xxxhdpi\background_4.pngを削除し、ionic cordova resources Android --forceを実行してAndroidリソースを再生成しました

0
Manoj Alwis

画像サイズを縮小した後、この問題を解決しました。

  • 問題の原因となった画像と他の画像のサイズの違いに注目すると、サイズが大きいことがわかります。
0
Anbara Ayoub

ログからpngイメージの1つが破損している可能性があるようです。交換または削除してビルドしてみてください。

\res\drawable-xxxhdpi\background_4.png
0
karan

問題に長い一日を費やした後、私は単に GIMP を取得し、PNGファイルをJPGに変換することで解決しました Googleの問題追跡の誰かが提案したように

それは奇跡を起こし、他のファイル、パッケージバージョン、または設定を変更する必要はありませんでした。

0
Umur Karagöz

バリアントを変更すると、自動的に設定されます...無料で実行する場合(ビルドされたバリアントから選択)、有料のフレーバーは赤になります。

0
maneeshsagar

Gradleおよびmaven依存関係の古いキャッシュをクリーンアップする必要があります。たとえば、.m2および.gradleの下のファイルを削除してから、キャッシュの無効化/再起動...

また、enableAapt2内でfalseに設定することで、gradle.propertiesを無効にしようとすることもできます。

Android.enableAapt2=false
0
shizhen

私にとっては、すべてのビルドフォルダーを削除してシステムを再起動し、Android St​​udioを再度開いてデバッグモードで動作します。

更新:

Pngの1つがエラー: error: failed to read PNG signature: file does not start with PNG signatureを示していました。pngでもう一度開いてエクスポートします。現在、すべてのビルドバリアントで動作しています。そして、ゼロバイトpngを1つ削除します。うまくいけば誰もが美しくします/ありがとう

0
Qamar