Error inflating class com.google.android.material.navigation.NavigationView的解决方案

我的新书《Android App开发入门与实战》已于2020年8月由人民邮电出版社出版,欢迎购买。点击进入详情


欢迎加入Android开发交流QQ群:
Android开发技术交流

Logcat输出日志

2020-01-05 19:25:47.710 3713-3713/? E/AndroidRuntime: FATAL EXCEPTION: main
    Process: com.androidwind.github, PID: 3713
    java.lang.RuntimeException: Unable to start activity ComponentInfo{com.androidwind.github/com.androidwind.github.ui.main.MainActivity}: android.view.InflateException: Binary XML file line #17: Binary XML file line #17: Error inflating class com.google.android.material.navigation.NavigationView
        at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:3092)
        at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3235)
        at android.app.servertransaction.LaunchActivityItem.execute(LaunchActivityItem.java:78)
        at android.app.servertransaction.TransactionExecutor.executeCallbacks(TransactionExecutor.java:108)
        at android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:68)
        at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1926)
        at android.os.Handler.dispatchMessage(Handler.java:106)
        at android.os.Looper.loop(Looper.java:214)
        at android.app.ActivityThread.main(ActivityThread.java:6990)
        at java.lang.reflect.Method.invoke(Native Method)
        at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:494)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1445)
     Caused by: android.view.InflateException: Binary XML file line #17: Binary XML file line #17: Error inflating class com.google.android.material.navigation.NavigationView
     Caused by: android.view.InflateException: Binary XML file line #17: 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:343)
        at android.view.LayoutInflater.createView(LayoutInflater.java:647)
        at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:790)
        at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:730)
        at android.view.LayoutInflater.rInflate(LayoutInflater.java:863)
        at android.view.LayoutInflater.rInflateChildren(LayoutInflater.java:824)
        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.setContentView(AppCompatDelegateImpl.java:9)
        at androidx.appcompat.app.AppCompatActivity.setContentView(AppCompatActivity.java:1)
        at com.androidwind.base.ui.QuickActivity.setContentView(QuickActivity.java:15)
        at com.androidwind.base.ui.QuickActivity.onCreate(QuickActivity.java:8)
        at android.app.Activity.performCreate(Activity.java:7326)
        at android.app.Activity.performCreate(Activity.java:7317)
        at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1271)
        at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:3072)
        at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3235)
        at android.app.servertransaction.LaunchActivityItem.execute(LaunchActivityItem.java:78)
        at android.app.servertransaction.TransactionExecutor.executeCallbacks(TransactionExecutor.java:108)
        at android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:68)
        at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1926)
        at android.os.Handler.dispatchMessage(Handler.java:106)
        at android.os.Looper.loop(Looper.java:214)
        at android.app.ActivityThread.main(ActivityThread.java:6990)
        at java.lang.reflect.Method.invoke(Native Method)
        at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:494)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1445)
     Caused by: java.lang.NoSuchMethodError: No static method asAttributeSet(Lh/e/a/a;)Landroid/util/AttributeSet; in class Landroid/util/Xml; or its super classes (declaration of 'android.util.Xml' appears in /system/framework/framework.jar!classes2.dex)

场景还原

debug环境下没有问题,但是在release环境下就出错。
NavigationView是从com.google.android.material包下引入的。

解决过程

首先想到的是会不会因为开启了混淆导致的?
在proguard-rules.pro文件中看到已经对androidx版本进行了适配:

# androidx的混淆
-keep class com.google.android.material.** {*;}
-keep class androidx.** {*;}
-keep public class * extends androidx.**
-keep interface androidx.** {*;}
-dontwarn com.google.android.material.**
-dontnote com.google.android.material.**
-dontwarn androidx.**

接着想到是不是com.google.android.material包的版本较低?
当前版本是1.1.0-alpha09,看到最新版本是1.2.0-alpha03,于是改成最新版本,重新build后发现问题仍然存在,初步排除应该不是这个原因导致的。

最后在网上搜索的时候发现有人也遇到类似的问题,参考:
http://www.it1me.com/it-answers?id=30709419&ttl=Error+inflating+class+android.support.design.widget.NavigationView
其中有人提到:
在这里插入图片描述
于是将app:srcCompat改为android:src,这样问题解决了么?

然而并没有。。。
接着往下看:
在这里插入图片描述
其中说到了drawable文件夹中的内容要保持一致,
突然想起来前些时间顺手把drawable-v24文件夹给删了,理论上来说因该都会用到drawable文件夹内的东西吧?难道这两个文件夹内的东西还不一致?

看了一下,果然,drawable-v24文件夹中有一个ic_launcher_foreground.xml文件,但是在drawable文件夹中却没有,于是将ic_launcher_foreground.xml文件复制到drawable文件夹内。

你以为这样就结束了么?运行以后仍然崩溃。

回过头,我们看一下log日志,最开始的地方提示:

Caused by: java.lang.NoSuchMethodError: No static method asAttributeSet(Lh/e/a/a;)Landroid/util/AttributeSet; in class Landroid/util/Xml; or its super classes (declaration of ‘android.util.Xml’ appears in /system/framework/framework.jar!classes2.dex)
原来是混淆过后找不到文件了,都变成h/e/a/a之类的。

这类问题网上也比较多:
https://www.ojit.com/article/3511137
在混淆文件中加入如下代码即可:

-dontwarn org.xmlpull.v1.XmlPullParser
-dontwarn org.xmlpull.v1.XmlSerializer
-keep class org.xmlpull.v1.* {*;}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值