问题
这两天做功能需要修改一个布局文件,遇到了inflating class问题。
分析
查看错误信息:
Binary XML file line:XML文件问题。
inflating class顾名思义是不能“初始化”类对象。
也就可以通过错误信息得出,是由于加载布局文件时,无法解析导致程序异常。
示例分析
出错代码:布局结构为dialpad_button中引用dialpad布局。
dialpad_button.xml
<LinearLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/dialpadbutton"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
android:gravity="center_horizontal"
android:clipChildren="false">
<include layout="@layout/dialpad" />
</LinearLayout>
dialpad.xml
<LinearLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/dialpad"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
android:clipChildren="false">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="0dp"
android:layout_weight="1"
android:orientation="horizontal">
<Space style="@style/DialpadSpaceStyle" />
<include layout="@layout/dialpad_key_one" />
<include layout="@layout/dialpad_key"
android:id="@+id/two"
style="@style/DialpadKeyButtonStyle"/>
<include layout="@layout/dialpad_key"
android:id="@+id/three"
style="@style/DialpadKeyNumberStyle" />
<Space style="@style/DialpadSpaceStyle" />
</LinearLayout>
</LinearLayout>
style.xml:
<style name="DialpadKeyNumberStyle">
<item name="android:textColor">?attr/dialpad_text_color_primary</item>
<item name="android:textSize">@dimen/dialpad_key_numbers_size</item>
<item name="android:fontFamily">sans-serif-light</item>
<item name="android:layout_width">wrap_content</item>
<item name="android:layout_height">wrap_content</item>
<item name="android:layout_marginBottom">@dimen/dialpad_key_number_margin_bottom</item>
<item name="android:gravity">center</item>
</style>
结果运行时,就出现了如下错误:
*06-21 16:26:07.985 10789-10789/com.android.dialer E/AndroidRuntime: FATAL EXCEPTION: main
Process: com.android.dialer, PID: 10789
java.lang.RuntimeException: Unable to start activity ComponentInfo{com.android.dialer/com.android.incallui.InCallActivity}: android.view.InflateException: Binary XML file line #107: Binary XML file line #51: Binary XML file line #22: Error inflating class <unknown>
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2745)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2810)
at android.app.ActivityThread.-wrap12(ActivityThread.java)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1529)
at android.os.Handler.dispatchMessage(Handler.java:110)
at android.os.Looper.loop(Looper.java:203)
at android.app.ActivityThread.main(ActivityThread.java:6275)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1063)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:924)
Caused by: android.view.InflateException: Binary XML file line #107: Binary XML file line #51: Binary XML file line #22: Error inflating class <unknown>
Caused by: android.view.InflateException: Binary XML file line #51: Binary XML file line #22: Error inflating class <unknown>
Caused by: android.view.InflateException: Binary XML file line #22: Error inflating class <unknown>
Caused by: java.lang.reflect.InvocationTargetException
at java.lang.reflect.Constructor.newInstance0(Native Method)
at java.lang.reflect.Constructor.newInstance(Constructor.java:430)*
根据上面分析,一定是是dialpad解析初始化时出错了。那么哪里出错了呢?。对于这种问题,请仔细检查你的布局文件,错误一定是在你的布局文件当中,不要放过每个细节
经过仔细查看(这个过程无疑是比较痛苦的,请坚持下去),发现问题根源,在dialpad布局中使用的style=”@style/DialpadKeyNumberStyle”,我们回过头再看下DialpadKeyNumberStyle的定义中使用了<item name="android:textColor">?attr/dialpad_text_color_primary</item>
,问题就出现这个属性应用当中,dialpad_text_color_primary什么时候定义的?结果发现没有地方定义!!
修改后的代码:
dialpad_button.xml
<LinearLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/dialpadbutton"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
android:gravity="center_horizontal"
android:theme="@style/Dialpad_Light"
android:clipChildren="false">
<include layout="@layout/dialpad" />
</LinearLayout>
Dialpad_Light的定义
<style name="Dialpad_Light">
<item name="dialpad_text_color">@android:color/black</item>
<item name="dialpad_text_color_primary">@android:color/black</item>
<item name="dialpad_text_color_secondary">@color/dialpad_secondary_text_color</item>
<item name="dialpad_icon_tint">@color/dialpad_icon_tint</item>
<item name="dialpad_voicemail_tint">@color/dialpad_secondary_text_color</item>
<item name="dialpad_background">@color/background_dialpad</item>
</style>
可以看到这里为dialpad_button新增了theme,而theme中定义了我们后面使用到的资源(这个可以理解为,theme是我定义的成员变量块,后面DialpadKeyNumberStyle中的是对成员变量的使用,如果使用了未定义的成员变量,那么就会报错)
小结
总结为两点需注意:
- 对于该类型的错误,仔细审阅xml文件,问题就在这,不要让其他来分散你的注意力。
- android:theme=”@style/Dialpad_Light”;Theme的用法,可以定义相关item变量,供后续的布局进行使用(可以使用java代码的思维进行理解)。