Flutterにgoogle_mobile_adsを追加したところ、インタースティシャル広告をインスタンス化したタイミングでアプリがクラッシュするようになりました。
google_mobile_adsのバージョンを下げたり、gradleなどのバージョンを変えたりしましたが変化はありませんでした。
公式が出しているサンプルだと正常に動作しました。なのでFlutterのバージョンなど共有部分に問題はないと思います。
エラーは
E/AndroidRuntime(14135): FATAL EXCEPTION: main E/AndroidRuntime(14135): Process: sample.com.app, PID: 14135 E/AndroidRuntime(14135): java.lang.NoClassDefFoundError: Failed resolution of: Lcom/google/android/gms/ads/InterstitialAd; E/AndroidRuntime(14135): at io.flutter.plugins.googlemobileads.FlutterInterstitialAd.load(FlutterInterstitialAd.java:70) E/AndroidRuntime(14135): at io.flutter.plugins.googlemobileads.GoogleMobileAdsPlugin.onMethodCall(GoogleMobileAdsPlugin.java:299) E/AndroidRuntime(14135): at io.flutter.plugin.common.MethodChannel$IncomingMethodCallHandler.onMessage(MethodChannel.java:233) E/AndroidRuntime(14135): at io.flutter.embedding.engine.dart.DartMessenger.handleMessageFromDart(DartMessenger.java:85) E/AndroidRuntime(14135): at io.flutter.embedding.engine.FlutterJNI.handlePlatformMessage(FlutterJNI.java:819) E/AndroidRuntime(14135): at android.os.MessageQueue.nativePollOnce(Native Method) E/AndroidRuntime(14135): at android.os.MessageQueue.next(MessageQueue.java:336) E/AndroidRuntime(14135): at android.os.Looper.loop(Looper.java:197) E/AndroidRuntime(14135): at android.app.ActivityThread.main(ActivityThread.java:8125) E/AndroidRuntime(14135): at java.lang.reflect.Method.invoke(Native Method) E/AndroidRuntime(14135): at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:496) E/AndroidRuntime(14135): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1100) E/AndroidRuntime(14135): Caused by: java.lang.ClassNotFoundException: Didn't find class "com.google.android.gms.ads.InterstitialAd" on path: DexPathList[[zip file "/data/app/sample.app-D8qloDBoh2S95AXFem7KnA==/base.apk"],nativeLibraryDirectories=[/data/app/sample.com.app-D8qloDBoh2S95AXFem7KnA==/lib/arm64, /data/app/sample.com.app-D8qloDBoh2S95AXFem7KnA==/base.apk!/lib/arm64-v8a, /system/lib64, /system/product/lib64]] E/AndroidRuntime(14135): at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:196) E/AndroidRuntime(14135): at java.lang.ClassLoader.loadClass(ClassLoader.java:379) E/AndroidRuntime(14135): at java.lang.ClassLoader.loadClass(ClassLoader.java:312) E/AndroidRuntime(14135): ... 12 more
初期化やバナー広告は問題なく動作しますが、InterstitialAd及びPublisherInterstitialAdがインスタンス化する際にクラッシュします。
変数などの宣言は問題なくできます。
やったこと
google_mobile_adsのバージョン変更
gradleのバージョン変更
flutter clean
Pubのキャッシュを削除
realm-gradle-pluginの追加
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2021/04/20 15:27