Исключение предварительного просмотра Android AppBarLayout

Ошибка при использовании 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)

Исключение предварительного просмотра Android AppBarLayoutИсключение предварительного просмотра Android AppBarLayout

Описания недостаточно для публикации?Описания недостаточно для публикации?

Удалить com.google.android.material и синхронизировать. Теперь снова добавьте его обратно и синхронизируйте, это решит проблему.

sanjeev 14.05.2019 14:01

Все решается после перезагрузки компа......

CrazyZhang 15.05.2019 02:46

Да, @CrazyZhang, иногда это случается из-за кеша .. ты тоже мог бы это сделать .. В любом случае рад узнать, что проблема решена. Ваше здоровье!

sanjeev 15.05.2019 06:01
2
3
954
4
Перейти к ответу Данный вопрос помечен как решенный

Ответы 4

Вам нужно использовать вот так

<?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?

Nick Bapu 14.05.2019 12:17

@NickBapu, ПОЖАЛУЙСТА, посмотри на его класс, у него уже есть материальные зависимости

Ankit Tale 14.05.2019 12:22

Я не знаю, как это привело к этому.

Все решается после перезагрузки компьютера.

Ответ принят как подходящий

Я пробовал несколько проектов с точно таким же кодом для AppBarLayout в Linux (AS3.4 и AS3.5 - Canary), а в Windows я пробовал его в AS3.3. Кажется, что-то с AppBarLayout в библиотеке поддержки не так. Я использовал андроидкс. Кажется, что-то пошло не так после нескольких успешных сборок.

Это не решение само по себе, а возможный обходной путь — вы можете избежать AppBarLayout, пока библиотека не будет обновлена ​​и AppBarLayout не будет вести себя хорошо.

Сообщается о проблеме: issuetracker.google.com/issues/133100463.

dimsuz 23.05.2019 11:34

У меня была такая же проблема, потому что я обновил свою библиотеку материалов до 1.1.0-alpha10 после перехода на androidX.

В качестве обходного пути мне пришлось перейти на 'com.google.android.material:material:1.0.0', а затем перезапустить студию Android. Надеюсь, поможет.

Другие вопросы по теме