迁移到AndroidX后,解析com.google.android.material.navigation.NavigationView类时出错。

15

当我把项目更新为AndroidX且将targetSdkVersion设置为28后,我的项目在从beta测试商店安装时崩溃。

以下是我收到的错误日志:

2019-07-08 08:28:33.026 32011-32011/? E/AndroidRuntime: FATAL EXCEPTION: main Process: hu.itq.oakprotection, PID: 32011
        java.lang.RuntimeException: Unable to start activity ComponentInfo{hu.itq.oakprotection/hu.itq.oakprotection.MainActivity}: android.view.InflateException: Binary XML file line #15: Binary XML file line #15: Error inflating class com.google.android.material.navigation.NavigationView
            at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:3194)
            at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3302)
            at android.app.ActivityThread.-wrap12(Unknown Source:0)
            at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1891)
            at android.os.Handler.dispatchMessage(Handler.java:108)
            at android.os.Looper.loop(Looper.java:166)
            at android.app.ActivityThread.main(ActivityThread.java:7425)
            at java.lang.reflect.Method.invoke(Native Method)
            at com.android.internal.os.Zygote$MethodAndArgsCaller.run(Zygote.java:245)
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:921)
         Caused by: android.view.InflateException: Binary XML file line #15: Binary XML file line #15: Error inflating class com.google.android.material.navigation.NavigationView
         Caused by: android.view.InflateException: Binary XML file line #15: Error inflating class com.google.android.material.navigation.NavigationView
         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:658)
            at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:801)
            at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:741)
            at android.view.LayoutInflater.rInflate(LayoutInflater.java:874)
            at android.view.LayoutInflater.rInflateChildren(LayoutInflater.java:835)
            at android.view.LayoutInflater.inflate(LayoutInflater.java:515)
            at android.view.LayoutInflater.inflate(LayoutInflater.java:423)
            at android.view.LayoutInflater.inflate(LayoutInflater.java:374)
            at androidx.appcompat.app.AppCompatDelegateImpl.c(Unknown Source:23)
            at androidx.appcompat.app.AppCompatActivity.setContentView(Unknown Source:4)
            at hu.itq.oakprotection.MainActivity.onCreate(Unknown Source:6)
            at android.app.Activity.performCreate(Activity.java:7372)
            at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1218)
            at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:3147)
            at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3302)
            at android.app.ActivityThread.-wrap12(Unknown Source:0)
            at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1891)
            at android.os.Handler.dispatchMessage(Handler.java:108)
            at android.os.Looper.loop(Looper.java:166)
            at android.app.ActivityThread.main(ActivityThread.java:7425)
            at java.lang.reflect.Method.invoke(Native Method)
            at com.android.internal.os.Zygote$MethodAndArgsCaller.run(Zygote.java:245)
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:921)
         Caused by: java.lang.NoSuchMethodError: No interface method d()I in class Lorg/xmlpull/v1/XmlPullParser; or its super classes (declaration of 'org.xmlpull.v1.XmlPullParser' appears in /system/framework/core-libart.jar)
            at androidx.appcompat.view.SupportMenuInflater.a(Unknown Source:5)
            at androidx.appcompat.view.SupportMenuInflater.inflate(Unknown Source:25)
            at com.google.android.material.navigation.NavigationView.b(Unknown Source:12)
            at com.google.android.material.navigation.NavigationView.<init>(Unknown Source:255)
            at com.google.android.material.navigation.NavigationView.<init>(Unknown Source:2)
            at java.lang.reflect.Constructor.newInstance0(Native Method) 
            at java.lang.reflect.Constructor.newInstance(Constructor.java:334

以下是我在build.gradle文件中的依赖项:
android {
    compileSdkVersion 28
    def versionMajor = 1
    def versionMinor = 0
    def versionPatch = 1
    def versionBuild = 4 // ezt kell átírni új verzió kirakásakor

    defaultConfig {
        applicationId "hu.itq.oakprotection"
        minSdkVersion 23
        targetSdkVersion 28
        versionCode versionMajor * 10000 + versionMinor * 1000 + versionPatch * 100 + versionBuild
        versionName "${versionMajor}.${versionMinor}.${versionPatch}"
    }
    buildTypes {
        release {
            minifyEnabled true
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
        }
    }
    compileOptions {
        targetCompatibility 1.8
        sourceCompatibility 1.8
    }
}

dependencies {
    implementation fileTree(include: ['*.jar'], dir: 'libs')

    implementation 'androidx.core:core:1.0.2'
    implementation 'androidx.appcompat:appcompat:1.0.2'
    implementation 'androidx.legacy:legacy-support-v4:1.0.0'
    implementation 'androidx.constraintlayout:constraintlayout:1.1.3'
    implementation 'androidx.annotation:annotation:1.1.0'

    implementation 'com.payumoney.sdkui:plug-n-play:1.2.0'
    implementation 'androidx.cardview:cardview:1.0.0'
    implementation 'com.google.android.material:material:1.1.0-alpha07'
    implementation 'androidx.browser:browser:1.0.0'
    implementation 'com.google.android.gms:play-services-base:17.0.0'
    testImplementation 'junit:junit:4.12'
    androidTestImplementation 'androidx.test:runner:1.2.0'
    androidTestImplementation 'androidx.test.espresso:espresso-core:3.2.0'
    //Test error miatt kellett
    implementation 'androidx.annotation:annotation:1.1.0'

    //Aszinkron hálózatokhoz
    implementation 'com.android.volley:volley:1.1.1'

    //Facebook
    implementation 'com.facebook.android:facebook-android-sdk:4.34.0'
    //Osm Droid
    implementation 'org.osmdroid:osmdroid-android:6.1.0'
    implementation 'com.github.MKergall:osmbonuspack:6.4'

    implementation 'com.github.angads25:filepicker:1.1.1'
    //Tile provider igényli
    implementation 'mil.nga.geopackage:geopackage-android:3.0.2'
    implementation 'com.j256.ormlite:ormlite-android:5.1'
    implementation 'mil.nga.geopackage:geopackage-core:3.0.2'
    implementation 'ar.com.hjg:pngj:2.1.0'
    implementation 'mil.nga:tiff:2.0.0'
    implementation('mil.nga.geopackage:geopackage-android:3.0.2') {
        exclude group: 'com.google.android.gms', module: 'play-services'
        exclude group: 'com.google.maps.android', module: 'android-maps-utils'
        exclude group: 'com.android.support', module: 'support-v13'
    }
    //Glide
    implementation 'com.github.bumptech.glide:glide:4.8.0'
    annotationProcessor 'com.github.bumptech.glide:compiler:4.8.0'
    //Mapsforge rendering and database support, which is LGPL
    implementation 'org.mapsforge:mapsforge-map-android:0.8.0'
    implementation 'org.mapsforge:mapsforge-map:0.8.0'
    implementation 'org.mapsforge:mapsforge-themes:0.8.0'
    // ExoPlayer
    implementation 'com.google.android.exoplayer:exoplayer:2.7.3'
    //Youtube
    implementation 'com.github.HaarigerHarald:android-youtubeExtractor:v1.7.0'}

activity_main.xml:

<androidx.drawerlayout.widget.DrawerLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:id="@+id/drawer_layout"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:fitsSystemWindows="true"
    tools:openDrawer="start"
    tools:context=".MainActivity">

    <include
        layout="@layout/app_bar_main" />

    <com.google.android.material.navigation.NavigationView
        android:id="@+id/nav_view"
        android:layout_width="wrap_content"
        android:layout_height="match_parent"
        android:layout_gravity="start"
        android:fitsSystemWindows="true"
        app:headerLayout="@layout/nav_header_main"
        app:menu="@menu/activity_main_drawer"
        app:itemIconTint="@color/colorPrimary"
        app:itemTextColor="@color/colorPrimary"
        android:backgroundTint="@color/colorWhite"/>

</androidx.drawerlayout.widget.DrawerLayout>

为什么我在NavigationView中收到android.view.InflateException错误?


你是否使用了第三方库中的视图?(只是猜测) - Blundell
检查 layout/nav_header_main - Basi
在我的情况下是... android:fontFamily="@font/montserrat_bold"。 在之前的SDK版本中可以工作,但现在... - Jose Pose S
14个回答

18
这个错误可能有多种原因。请检查以下内容并确保它们是正确的:
  • 检查您在activity_main.xml中使用的默认导航抽屉模板代码中是否使用了com.google.android.material.navigation.NavigationView内部的drawablecolor资源。
  • 检查可绘制文件是否位于res/drawable文件夹中,而不是res/drawable-v21中。
  • 检查是否在NavigationView中使用了android:backgroundTint()android:src等类似内容。由于它们不适用于 Android API 级别低于 21 的版本,请改用 app:backgroundTintapp:srcCompat

1
问题是: android: backgroundTint = "@ color / colorWhite"。 解决方案: app: backgroundTint = "@ color / colorWhite" 谢谢,你救了我的一天 ;) - Tankos
我遇到了同样的问题 1)我没有使用backgrounTint或android:src 2)我没有在NavigationView中使用color或drawable 但我的应用程序在此行崩溃: setContentView(R.layout.layout_base_activity); - Muhammad Tufail
谢谢您的回复,我没有提出任何单独的问题。 我的错误和之前一样,报告如下: android.view.InflateException: Binary XML file line #15: Binary XML file line #15: Error inflating class com.google.android.material.navigation.NavigationView 我已经添加了所有的Androidx依赖项,并且已经检查了我的代码5-6次。 我还为了测试而删除了所有的drawable和颜色,但应用程序仍然崩溃了。。 - Muhammad Tufail
1
不客气,@MD.Riyaz。很高兴我的答案也解决了你的问题。考虑给一个赞,因为它有所帮助。 - SaadAAkash
1
很高兴能帮助@YashM.Hanj - SaadAAkash
显示剩余7条评论

5

对于那些选定的答案无法解决问题的人来说,我发现导航视图主题存在问题,应该使用appCompat主题(至少对我来说是这样的)。 创建一个新的样式如下:

<style name="NavView" parent="Theme.AppCompat.NoActionBar">
    <item name="android:windowNoTitle">true</item>
    ...
</style>

我在我的mainactivity.xml中的NavigationView中使用android:theme="@style/NavView"并成功运行了应用程序。


更改主题为“android:theme = "@style/Widget.Design.NavigationView"”,现在它可以正常工作 :) - KamDroid

4
在我的情况下,问题出在navigation.NavigationView的app:headerLayout布局上。我正在设置它。
<ImageView 
  app:srcCompat="@mipmap/ic_launcher_round"
/> 

问题出在ic_launcher_round上,因为它位于mipmap-anydpi-v26文件夹中,而我正在使用Android版本7.1.1,即API级别25。希望这能帮助任何人。

3
在我的情况下,问题出在 Manifest 文件中的主题值。
<activity
        android:name=".ui.BarcodeReaderDrawerActivity"
        android:label="@string/title_activity_barcode_reader_drawer">
        android:theme="@style/AppBaseTheme.NoActionBar"
    </activity>

更新于

<activity
        android:name=".ui.BarcodeReaderDrawerActivity"
        android:label="@string/title_activity_barcode_reader_drawer"
        android:theme="@style/Theme.MaterialComponents.Light.NoActionBar">
    </activity>

1

这个错误与主题有关。我通过注释主题中以下行来解决了我的问题。

  <style name="AppTheme.NavigationView"  >
    <!--<item name="android:textColorSecondary">#FFFFFF</item>-->
    <item name="android:scrollbarThumbVertical">@android:color/transparent</item>
    <item name="elevation">0dp</item>
</style>

通过删除或逐行注释主题代码,您可以快速确定问题所在。

1
在我的情况下,这很有帮助。希望这个答案能帮助到遇到问题的人。
 <style name="Theme.PLCDrive" parent="Theme.MaterialComponents.Light.NoActionBar">

在我的情况下,当主题样式为MaterialComponents时,它会不断崩溃,但当我改为AppCompat后,错误得到解决并正常运行。
<style name="Theme.PLCDrive" parent="Theme.AppCompat.Light.NoActionBar">

1
我在升级到Androidx的过程中遇到了一个错误,很难找到。问题出现在活动主题上。
在styles.xml中,一些地方我使用了错误的Android材质主题,导致导航栏未附加到操作栏。
from:

    <style name="AppTheme" parent="android:Theme.Material.Light.DarkActionBar">

to:

    <style name="AppTheme" parent="Theme.MaterialComponents.Light.DarkActionBar">

1
你可以检查你的XML文件。XML中可能存在诸如菜单、导航标题等问题。在我的案例中,错误出现在res/menu/menu.xml文件中。

1
我尝试更改模块设置、gradle设置、更改依赖项等等,发现问题出在导航视图中。但问题是另一种类型,即抽屉布局选择的图像溢出,所以只需更改图像或编辑它并调整大小,然后再尝试即可。因此,由于这个原因,在某些设备上导航视图会报错。

0

我的问题不是因为android:src

而是因为我在导航头布局中使用了矢量渐变作为背景(android:background="@drawable/bg"

这只发生在Android 6中

我将矢量图从这个改成了:

<vector xmlns:android="http://schemas.android.com/apk/res/android" xmlns:aapt="http://schemas.android.com/aapt" android:width="200dp" android:height="133dp" android:viewportWidth="375" android:viewportHeight="280">
    <path android:pathData="M0 0h375v280H0V0z">
        <aapt:attr name="android:fillColor">
            <gradient android:endX="497.417" android:endY="263.205" android:startX="150.5" android:startY="-33.5" android:type="linear">
                <item android:color="#FFFFFFFF" android:offset="0"/>
                <item android:color="#00000000" android:offset="1"/>
            </gradient>
        </aapt:attr>
    </path>
</vector>

转换成这个

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle">

    <gradient
        android:angle="315"
        android:endColor="#ffffff"
        android:startColor="#000000"
        android:type="linear" />
</shape>

然后崩溃消失了


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接