Android 运行时异常Caused by: android.view.InflateException

最近在使用了一个自定义view时出现了inflateException ,下面是抛出的异常的日志:

2020-06-03 17:34:21.270 2970-2970/com.maxwell.camerademo E/AndroidRuntime: FATAL EXCEPTION: main
Process: com.maxwell.camerademo, PID: 2970
java.lang.RuntimeException: Unable to start activity ComponentInfo{com.maxwell.camerademo/com.maxwell.camerademo.LightScannerActivity}: android.view.InflateException: Binary XML file line #17: Binary XML file line #17: Error inflating class com.pax.pay.utils.lightscanner.view.ViewfinderView
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2865)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2955)
at android.app.ActivityThread.-wrap12(Unknown Source:0)
at android.app.ActivityThreadH.handleMessage(ActivityThread.java:1650)atandroid.os.Handler.dispatchMessage(Handler.java:106)atandroid.os.Looper.loop(Looper.java:164)atandroid.app.ActivityThread.main(ActivityThread.java:6747)atjava.lang.reflect.Method.invoke(NativeMethod)atcom.android.internal.os.RuntimeInitH.handleMessage(ActivityThread.java:1650) at android.os.Handler.dispatchMessage(Handler.java:106) at android.os.Looper.loop(Looper.java:164) at android.app.ActivityThread.main(ActivityThread.java:6747) at java.lang.reflect.Method.invoke(Native Method) at com.android.internal.os.RuntimeInitMethodAndArgsCaller.run(RuntimeInit.java:449)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:807)
Caused by: android.view.InflateException: Binary XML file line #17: Binary XML file line #17: Error inflating class com.pax.pay.utils.lightscanner.view.ViewfinderView

在使用第三方的自定义view时,layout里面的使用View要带上View的完整的路径,为了确保引用的View的路径是正确的,可以使用下面的方法来确认:

选中自定义View,然后选择Copy Reference。
Android 运行时异常Caused by: android.view.InflateException

为了确保layout中的使用的自定义View的标签中,是正确的,可以打开自定义View所在的layout ,然后点击自定 view的标签,确保可以跳转到自定义所在的类;如果无法跳转,则说明该layout 中自定义View的路径是错误的,需要把第一步骤中复制得到的自定义View的路径粘贴到自定义View的标签处

工欲善其事,必先利其器。我们最有效的武器就是我们的大脑。增加大脑的知识储备,提高思维能力是在将来立于不败之地的法宝。