我将com.google.android.material:material更新到了1.2.0版本,现在我的应用程序闪烁着白-黑。我在logcat中看到了这个例外:
E/Parcel: Class not found when unmarshalling: androidx.fragment.app.FragmentManagerState
java.lang.ClassNotFoundException: androidx.fragment.app.FragmentManagerState
at java.lang.Class.classForName(Native Method)
at java.lang.Class.forName(Class.java:454)
at android.os.Parcel.readParcelableCreator(Parcel.java:3014)
at android.os.Parcel.readParcelable(Parcel.java:2964)
at android.os.Parcel.readValue(Parcel.java:2866)
at android.os.Parcel.readArrayMapInternal(Parcel.java:3244)
at android.os.BaseBundle.initializeFromParcelLocked(BaseBundle.java:292)
at android.os.BaseBundle.unparcel(BaseBundle.java:236)
at android.os.Bundle.getBundle(Bundle.java:924)
at ky.a(:com.google.android.gms.dynamite_measurementdynamite@203315082@20.33.15 (120406-0):17)
at kk.onActivityCreated(:com.google.android.gms.dynamite_measurementdynamite@203315082@20.33.15 (120406-0):2)
at com.google.android.gms.measurement.internal.AppMeasurementDynamiteService.onActivityCreated(:com.google.android.gms.dynamite_measurementdynamite@203315082@20.33.15 (120406-0):3)
at cw.a(:com.google.android.gms.dynamite_measurementdynamite@203315082@20.33.15 (120406-0):64)
at ac.onTransact(:com.google.android.gms.dynamite_measurementdynamite@203315082@20.33.15 (120406-0):4)
at android.os.Binder.transact(Binder.java:914)
at com.google.android.gms.internal.measurement.zza.zzb(com.google.android.gms:play-services-measurement-base@@17.2.0:20)
at com.google.android.gms.internal.measurement.zzo.onActivityCreated(com.google.android.gms:play-services-measurement-base@@17.2.0:144)
at com.google.android.gms.internal.measurement.zzbc.zza(com.google.android.gms:play-services-measurement-sdk-api@@17.2.0:4)
at com.google.android.gms.internal.measurement.zzx$zza.run(com.google.android.gms:play-services-measurement-sdk-api@@17.2.0:11)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1167)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:641)
at java.lang.Thread.run(Thread.java:919)
Caused by: java.lang.ClassNotFoundException: androidx.fragment.app.FragmentManagerState
at java.lang.Class.classForName(Native Method)
at java.lang.BootClassLoader.findClass(ClassLoader.java:1358)
at java.lang.BootClassLoader.loadClass(ClassLoader.java:1418)
at java.lang.ClassLoader.loadClass(ClassLoader.java:312)
at java.lang.Class.classForName(Native Method)
at java.lang.Class.forName(Class.java:454)
at android.os.Parcel.readParcelableCreator(Parcel.java:3014)
at android.os.Parcel.readParcelable(Parcel.java:2964)
at android.os.Parcel.readValue(Parcel.java:2866)
at android.os.Parcel.readArrayMapInternal(Parcel.java:3244)
at android.os.BaseBundle.initializeFromParcelLocked(BaseBundle.java:292)
at android.os.BaseBundle.unparcel(BaseBundle.java:236)
at android.os.Bundle.getBundle(Bundle.java:924)
at ky.a(:com.google.android.gms.dynamite_measurementdynamite@203315082@20.33.15 (120406-0):17)
at kk.onActivityCreated(:com.google.android.gms.dynamite_measurementdynamite@203315082@20.33.15 (120406-0):2)
at com.google.android.gms.measurement.internal.AppMeasurementDynamiteService.onActivityCreated(:com.google.android.gms.dynamite_measurementdynamite@203315082@20.33.15 (120406-0):3)
at cw.a(:com.google.android.gms.dynamite_measurementdynamite@203315082@20.33.15 (120406-0):64)
at ac.onTransact(:com.google.android.gms.dynamite_measurementdynamite@203315082@20.33.15 (120406-0):4)
at android.os.Binder.transact(Binder.java:914)
at com.google.android.gms.internal.measurement.zza.zzb(com.google.android.gms:play-services-measurement-base@@17.2.0:20)
at com.google.android.gms.internal.measurement.zzo.onActivityCreated(com.google.android.gms:play-services-measurement-base@@17.2.0:144)
at com.google.android.gms.internal.measurement.zzbc.zza(com.google.android.gms:play-services-measurement-sdk-api@@17.2.0:4)
at com.google.android.gms.internal.measurement.zzx$zza.run(com.google.android.gms:play-services-measurement-sdk-api@@17.2.0:11)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1167)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:641)
at java.lang.Thread.run(Thread.java:919)
Caused by: java.lang.NoClassDefFoundError: Class not found using the boot class loader; no stack trace available经过很少的研究,我发现androidx.fragment.app.FragmentManagerState是用@SuppressLint("BanParcelableUsage")标记的。我猜这就是我的应用程序闪烁和不工作的原因,但我不知道如何解决这个问题?我试着在谷歌上搜索,但没有找到任何有用的东西。
我应该在哪里进一步搜索?我不记得曾经明确地使用过这个类。有人能帮帮忙吗?
发布于 2021-01-21 22:43:18
最后我找到了一个解决方案。一旦我更新了材质库,我就应该以一种更新的方式使用主题调整:
AppCompatDelegate.setDefaultNightMode(nightMode)而不是
val newConfig = Configuration(activity.resources.configuration)
newConfig.uiMode = newConfig.uiMode and Configuration.UI_MODE_NIGHT_MASK.inv()
newConfig.uiMode = newConfig.uiMode or uiNightMode
activity.resources.updateConfiguration(newConfig, null)
activity.setTheme(theme)我刚刚替换了这些代码,并从Theme.AppCompat.DayNight继承了应用程序主题,现在它就像一个护身符!
https://stackoverflow.com/questions/64091386
复制相似问题