Ошибка при использовании AppBarLayout, я попробовал Clean Project и Rebuild Project, но они не сработали.
Проблем с запуском программы нет. Почему это?
XML-файл:
<?xml version = "1.0" encoding = "utf-8"?>
<LinearLayout xmlns:android = "http://schemas.android.com/apk/res/android"
android:orientation = "vertical"
android:layout_width = "match_parent"
android:layout_height = "match_parent">
<com.google.android.material.appbar.AppBarLayout
android:layout_width = "match_parent"
android:layout_height = "match_parent">
</com.google.android.material.appbar.AppBarLayout>
</LinearLayout>
Грейдл:
dependencies {
implementation fileTree(dir: 'libs', include: ['*.jar'])
implementation "org.jetbrains.kotlin:kotlin-stdlib-jdk7:${kotlin_version}"
implementation 'androidx.appcompat:appcompat:1.0.2'
implementation 'androidx.legacy:legacy-support-v4:1.0.0'
testImplementation 'junit:junit:4.12'
androidTestImplementation 'androidx.test:runner:1.1.1'
androidTestImplementation 'androidx.test.espresso:espresso-core:3.1.1'
implementation 'androidx.constraintlayout:constraintlayout:1.1.3'
implementation 'android.arch.navigation:navigation-fragment:1.0.0'
implementation 'androidx.cardview:cardview:1.0.0'
def nav_version = '1.0.0'
implementation "android.arch.navigation:navigation-ui:$nav_version"
implementation 'com.google.android.material:material:1.0.0'
}
Трассировки стека:
java.lang.IllegalArgumentException: java.lang.ClassCastException@73c26ae
at sun.reflect.GeneratedMethodAccessor274.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:498)
at android.animation.PropertyValuesHolder_Delegate.callMethod(PropertyValuesHolder_Delegate.java:108)
at android.animation.PropertyValuesHolder_Delegate.nCallFloatMethod(PropertyValuesHolder_Delegate.java:143)
at android.animation.PropertyValuesHolder.nCallFloatMethod(PropertyValuesHolder.java)
at android.animation.PropertyValuesHolder.access$400(PropertyValuesHolder.java:38)
at android.animation.PropertyValuesHolder$FloatPropertyValuesHolder.setAnimatedValue(PropertyValuesHolder.java:1387)
at android.animation.ObjectAnimator.animateValue(ObjectAnimator.java:990)
at android.animation.ValueAnimator.setCurrentFraction(ValueAnimator.java:674)
at android.animation.ValueAnimator.setCurrentPlayTime(ValueAnimator.java:637)
at android.animation.ValueAnimator.start(ValueAnimator.java:1069)
at android.animation.ValueAnimator.start(ValueAnimator.java:1088)
at android.animation.ObjectAnimator.start(ObjectAnimator.java:852)
at android.animation.StateListAnimator.start(StateListAnimator.java:188)
at android.animation.StateListAnimator.setState(StateListAnimator.java:181)
at android.view.View.drawableStateChanged(View.java:21105)
at android.view.ViewGroup.drawableStateChanged(ViewGroup.java:7101)
at android.view.View.refreshDrawableState(View.java:21160)
at android.view.View.dispatchAttachedToWindow(View.java:18379)
at android.view.ViewGroup.dispatchAttachedToWindow(ViewGroup.java:3397)
at android.view.ViewGroup.dispatchAttachedToWindow(ViewGroup.java:3404)
at android.view.ViewGroup.dispatchAttachedToWindow(ViewGroup.java:3404)
at android.view.ViewGroup.dispatchAttachedToWindow(ViewGroup.java:3404)
at android.view.AttachInfo_Accessor.setAttachInfo(AttachInfo_Accessor.java:42)
at com.android.layoutlib.bridge.impl.RenderSessionImpl.inflate(RenderSessionImpl.java:335)
at com.android.layoutlib.bridge.Bridge.createSession(Bridge.java:391)
at com.android.tools.idea.layoutlib.LayoutLibrary.createSession(LayoutLibrary.java:195)
at com.android.tools.idea.rendering.RenderTask.createRenderSession(RenderTask.java:540)
at com.android.tools.idea.rendering.RenderTask.lambda$inflate$5(RenderTask.java:666)
at java.util.concurrent.CompletableFuture$AsyncSupply.run(CompletableFuture.java:1590)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
at java.lang.Thread.run(Thread.java:745)
Описания недостаточно для публикации?Описания недостаточно для публикации?
Все решается после перезагрузки компа......
Да, @CrazyZhang, иногда это случается из-за кеша .. ты тоже мог бы это сделать .. В любом случае рад узнать, что проблема решена. Ваше здоровье!
Вам нужно использовать вот так
<?xml version = "1.0" encoding = "utf-8"?>
<LinearLayout xmlns:android = "http://schemas.android.com/apk/res/android"
android:orientation = "vertical"
android:layout_width = "match_parent"
android:layout_height = "match_parent">
<com.google.android.material.appbar.AppBarLayout
android:layout_width = "match_parent"
android:layout_height = "wrap_content">
</com.google.android.material.appbar.AppBarLayout>
</LinearLayout>
Поскольку вы добавили Материальные зависимости в gradle как com.google.android.material
Как он может использовать com.google.android.material.appbar.AppBarLayout, если он уже использует AndroidX?
@NickBapu, ПОЖАЛУЙСТА, посмотри на его класс, у него уже есть материальные зависимости
Я не знаю, как это привело к этому.
Все решается после перезагрузки компьютера.
Я пробовал несколько проектов с точно таким же кодом для AppBarLayout в Linux (AS3.4 и AS3.5 - Canary), а в Windows я пробовал его в AS3.3. Кажется, что-то с AppBarLayout в библиотеке поддержки не так. Я использовал андроидкс. Кажется, что-то пошло не так после нескольких успешных сборок.
Это не решение само по себе, а возможный обходной путь — вы можете избежать AppBarLayout, пока библиотека не будет обновлена и AppBarLayout не будет вести себя хорошо.
Сообщается о проблеме: issuetracker.google.com/issues/133100463.
У меня была такая же проблема, потому что я обновил свою библиотеку материалов до 1.1.0-alpha10 после перехода на androidX.
В качестве обходного пути мне пришлось перейти на 'com.google.android.material:material:1.0.0', а затем перезапустить студию Android.
Надеюсь, поможет.
Удалить
com.google.android.materialи синхронизировать. Теперь снова добавьте его обратно и синхронизируйте, это решит проблему.