Ошибка раздувания BottomNavigationView.Ресурсы $ NotFoundException: идентификатор ресурса # 0x0 - PullRequest
0 голосов
/ 20 октября 2018

У меня возникла проблема с BottomNavigationView из библиотеки поддержки проектирования.Я использую его в своем файле activity_main.xml:

<android.support.design.widget.BottomNavigationView
        android:id="@+id/navigation"
        app:itemIconSize="16dp"
        app:labelVisibilityMode="labeled"
        app:itemTextColor="@color/white"
        app:itemIconTint="@color/white"
        app:itemBackground="@color/medium_purple"
        app:menu="@menu/main"
        android:layout_alignParentBottom="true"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"/>

Приложение вызывает сбой при накачке этого xml.Полная трассировка стека исключения приведена ниже:

java.lang.RuntimeException: Unable to start activity ComponentInfo{com.frolo.musp.dev/com.alexfrolov.mp.main.MainActivity}: android.view.InflateException: Binary XML file line #16: Binary XML file line #16: Error inflating class android.support.design.widget.BottomNavigationView
                                                                        at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2814)
                                                                        at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2892)
                                                                        at android.app.ActivityThread.-wrap11(Unknown Source:0)
                                                                        at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1613)
                                                                        at android.os.Handler.dispatchMessage(Handler.java:106)
                                                                        at android.os.Looper.loop(Looper.java:164)
                                                                        at android.app.ActivityThread.main(ActivityThread.java:6651)
                                                                        at java.lang.reflect.Method.invoke(Native Method)
                                                                        at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:547)
                                                                        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:822)
                                                                     Caused by: android.view.InflateException: Binary XML file line #16: Binary XML file line #16: Error inflating class android.support.design.widget.BottomNavigationView
                                                                     Caused by: android.view.InflateException: Binary XML file line #16: Error inflating class android.support.design.widget.BottomNavigationView
                                                                     Caused by: java.lang.reflect.InvocationTargetException
                                                                        at java.lang.reflect.Constructor.newInstance0(Native Method)
                                                                        at java.lang.reflect.Constructor.newInstance(Constructor.java:334)
                                                                        at android.view.LayoutInflater.createView(LayoutInflater.java:651)
                                                                        at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:794)
                                                                        at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:734)
                                                                        at android.view.LayoutInflater.rInflate(LayoutInflater.java:867)
                                                                        at android.view.LayoutInflater.rInflateChildren(LayoutInflater.java:828)
                                                                        at android.view.LayoutInflater.inflate(LayoutInflater.java:519)
                                                                        at android.view.LayoutInflater.inflate(LayoutInflater.java:427)
                                                                        at android.view.LayoutInflater.inflate(LayoutInflater.java:374)
                                                                        at android.support.v7.app.AppCompatDelegateImpl.setContentView(AppCompatDelegateImpl.java:469)
                                                                        at android.support.v7.app.AppCompatActivity.setContentView(AppCompatActivity.java:140)
                                                                        at com.alexfrolov.mp.main.MainActivity.onCreate(MainActivity.java:165)
                                                                        at android.app.Activity.performCreate(Activity.java:7074)
                                                                        at android.app.Activity.performCreate(Activity.java:7065)
                                                                        at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1215)
                                                                        at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2767)
                                                                        at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2892)
                                                                        at android.app.ActivityThread.-wrap11(Unknown Source:0)
                                                                        at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1613)
                                                                        at android.os.Handler.dispatchMessage(Handler.java:106)
                                                                        at android.os.Looper.loop(Looper.java:164)
                                                                        at android.app.ActivityThread.main(ActivityThread.java:6651)
                                                                        at java.lang.reflect.Method.invoke(Native Method)
                                                                        at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:547)
                                                                        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:822)
                                                                     Caused by: android.content.res.Resources$NotFoundException: Resource ID #0x0
                                                                        at android.content.res.ResourcesImpl.getValue(ResourcesImpl.java:220)
                                                                        at android.content.res.MiuiResourcesImpl.getValue(MiuiResourcesImpl.java:93)
                                                                        at android.content.res.Resources.getColorStateList(Resources.java:1034)
                                                                        at android.content.Context.getColorStateList(Context.java:631)
                                                                        at android.support.v7.content.res.AppCompatResources.getColorStateList(AppCompatResources.java:67)
                                                                        at android.support.design.internal.BottomNavigationMenuView.createDefaultColorStateList(BottomNavigationMenuView.java:467)
                                                                        at android.support.design.internal.BottomNavigationMenuView.<init>(BottomNavigationMenuView.java:101)
                                                                        at android.support.design.internal.BottomNavigationMenuView.<init>(BottomNavigationMenuView.java:86)

Версии всех библиотек поддержки и версия compileSdk одинаковы.Я действительно не понимаю, что это за чертовщина.Кто-нибудь может объяснить мне, пожалуйста?

Спасибо

Ответы [ 2 ]

0 голосов
/ 13 ноября 2018

У меня была эта проблема, и она озадачила меня на день или около того.По сути, BottomNav хочет, чтобы список цветов, определенный для textColorSecondary в вашей теме, отличался от простого цвета.Итак, я перешел от:

<style name="MTheme" parent="Theme.MaterialComponents.Light.Bridge">
    ...   
    <item name="android:textColorSecondary">#295055</item>

к

<style name="MTheme" parent="Theme.MaterialComponents.Light.Bridge">
    ...
    <item name="android:textColorSecondary">@color/secondary_textcolor</item>

, где Secondary_textcolor равен

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_enabled="true" android:color="#295055"/>
    <item android:state_enabled="false"  android:color="@color/disabled"/> 
</selector>

Я потратил много времени на добавление и удаление зависимостей, пытаясь найти эторешение.

0 голосов
/ 20 октября 2018

Проблема в названии вашего вопроса

Caused by: android.content.res.Resources$NotFoundException: Resource ID #0x0

Это означает, что вы используете ресурс, который не существует.Я не могу знать, что это, но это, как вы исправите.Перейдите в файл @menu/main и удалите все атрибуты для иконок.Вы можете оставить текст.Добавьте один за другим, чтобы проверить, какая проблема.Скорее всего, ваши значки были ошибочно помещены в папку drawable-24 вместо drawable или в папку с более высоким API Android, чем та, на которой вы тестируете.Иногда мы совершаем эти ошибки.

Также обратите внимание, что некоторые атрибуты применяются только при запуске определенного Android-API.Попробуйте проверить атрибуты, начинающиеся с app.

    app:itemTextColor="@color/white"
    app:itemIconTint="@color/white"
    app:itemBackground="@color/medium_purple"
...