Android:InflateException 问题(膨胀类 android.support.v7.widget.Toolbar 时出错)

标签 android exception runtimeexception android-toolbar inflate-exception

我在接收 RuntimeException 和 InflateException 时遇到问题,说明二进制 XML 文件:膨胀类 android.support.v7.widget.Toolbar 时出错。我创建了一个尝试使用抽屉导航的项目。我使用 Android 5.0 创建了一个 android-support-v7-appcompat 库(按照谷歌文档的说明)。在应用程序中,我正在扩展 NavigationDrawerActivity。我不确定是什么原因造成的。库似乎设置正确,但应用程序在启动时崩溃。

MainActivity.java

public class MainActivity extends NavigationDrawerActivity {

    private static final String LOGTAG = "MainActivity";

    @Override
    protected void onCreate(Bundle savedInstanceState) 
    {
        // Layout
        setContentView(R.layout.activity_main);

        super.onCreate(savedInstanceState);

NavigationDrawerActivity.java

public class NavigationDrawerActivity extends ActionBarActivity 
{
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

        // Use ToolBar and set it as ActionBar
        Toolbar toolbar = (Toolbar) findViewById(R.id.my_awesome_toolbar);
        setSupportActionBar(toolbar);

activity_main.xml

<android.support.v4.widget.DrawerLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/drawer_layout"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:fitsSystemWindows="true"     xmlns:app="http://schemas.android.com/apk/res/com.mobile_iab_ad_framework">

<!--     Added fitSystemWindows to allow NavDrawer overlay ActionBar -->

<!--     To display fragments -->
    <FrameLayout
        android:id="@+id/frame_container"
        android:layout_width="match_parent"
        android:layout_height="match_parent" >

<!--         Use a Toolbar so the drawer can be displayed over ActionBar -->
        <android.support.v7.widget.Toolbar
            android:id="@+id/my_awesome_toolbar"
            style="@style/HeaderBar"
            app:theme="@style/ActionBarThemeOverlay"
            app:popupTheme="@style/ActionBarPopupThemeOverlay"
            android:layout_width="match_parent"
            android:layout_height="wrap_content" />
    </FrameLayout>

<!--        Listview to display slider menu -->
        <ListView
            android:id="@+id/list_slidermenu"
            android:layout_width="240dp"
            android:layout_height="match_parent" 
            android:layout_gravity="start"
            android:background="@color/list_background"
            android:choiceMode="singleChoice"
            android:divider="@color/list_divider"
            android:dividerHeight="0dp"
            android:listSelector="@drawable/list_selector" />
</android.support.v4.widget.DrawerLayout>

LogCat 日志

12-06 03:06:56.487: E/AndroidRuntime(7105): FATAL EXCEPTION: main
12-06 03:06:56.487: E/AndroidRuntime(7105): Process: com.package, PID: 7105
12-06 03:06:56.487: E/AndroidRuntime(7105): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.mobile_iab_ad_framework/com.package.device_discovery.MainActivity}: android.view.InflateException: Binary XML file line #17: Error inflating class android.support.v7.widget.Toolbar
12-06 03:06:56.487: E/AndroidRuntime(7105):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2305)
12-06 03:06:56.487: E/AndroidRuntime(7105):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2363)
12-06 03:06:56.487: E/AndroidRuntime(7105):     at android.app.ActivityThread.access$900(ActivityThread.java:161)
12-06 03:06:56.487: E/AndroidRuntime(7105):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1265)
12-06 03:06:56.487: E/AndroidRuntime(7105):     at android.os.Handler.dispatchMessage(Handler.java:102)
12-06 03:06:56.487: E/AndroidRuntime(7105):     at android.os.Looper.loop(Looper.java:157)
12-06 03:06:56.487: E/AndroidRuntime(7105):     at android.app.ActivityThread.main(ActivityThread.java:5356)
12-06 03:06:56.487: E/AndroidRuntime(7105):     at java.lang.reflect.Method.invokeNative(Native Method)
12-06 03:06:56.487: E/AndroidRuntime(7105):     at java.lang.reflect.Method.invoke(Method.java:515)
12-06 03:06:56.487: E/AndroidRuntime(7105):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1265)
12-06 03:06:56.487: E/AndroidRuntime(7105):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1081)
12-06 03:06:56.487: E/AndroidRuntime(7105):     at dalvik.system.NativeStart.main(Native Method)
12-06 03:06:56.487: E/AndroidRuntime(7105): Caused by: android.view.InflateException: Binary XML file line #17: Error inflating class android.support.v7.widget.Toolbar
12-06 03:06:56.487: E/AndroidRuntime(7105):     at android.view.LayoutInflater.createView(LayoutInflater.java:626)
12-06 03:06:56.487: E/AndroidRuntime(7105):     at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:702)
12-06 03:06:56.487: E/AndroidRuntime(7105):     at android.view.LayoutInflater.rInflate(LayoutInflater.java:761)
12-06 03:06:56.487: E/AndroidRuntime(7105):     at android.view.LayoutInflater.rInflate(LayoutInflater.java:769)
12-06 03:06:56.487: E/AndroidRuntime(7105):     at android.view.LayoutInflater.inflate(LayoutInflater.java:498)
12-06 03:06:56.487: E/AndroidRuntime(7105):     at android.view.LayoutInflater.inflate(LayoutInflater.java:398)
12-06 03:06:56.487: E/AndroidRuntime(7105):     at android.view.LayoutInflater.inflate(LayoutInflater.java:354)
12-06 03:06:56.487: E/AndroidRuntime(7105):     at android.support.v7.app.ActionBarActivityDelegateBase.setContentView(ActionBarActivityDelegateBase.java:228)
12-06 03:06:56.487: E/AndroidRuntime(7105):     at android.support.v7.app.ActionBarActivity.setContentView(ActionBarActivity.java:102)
12-06 03:06:56.487: E/AndroidRuntime(7105):     at com.package.device_discovery.MainActivity.onCreate(MainActivity.java:51)
12-06 03:06:56.487: E/AndroidRuntime(7105):     at android.app.Activity.performCreate(Activity.java:5431)
12-06 03:06:56.487: E/AndroidRuntime(7105):     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1105)
12-06 03:06:56.487: E/AndroidRuntime(7105):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2269)
12-06 03:06:56.487: E/AndroidRuntime(7105):     ... 11 more
12-06 03:06:56.487: E/AndroidRuntime(7105): Caused by: java.lang.reflect.InvocationTargetException
12-06 03:06:56.487: E/AndroidRuntime(7105):     at java.lang.reflect.Constructor.constructNative(Native Method)
12-06 03:06:56.487: E/AndroidRuntime(7105):     at java.lang.reflect.Constructor.newInstance(Constructor.java:423)
12-06 03:06:56.487: E/AndroidRuntime(7105):     at android.view.LayoutInflater.createView(LayoutInflater.java:600)
12-06 03:06:56.487: E/AndroidRuntime(7105):     ... 23 more
12-06 03:06:56.487: E/AndroidRuntime(7105): Caused by: java.lang.NoSuchMethodError: android.support.v4.content.ContextCompat.getDrawable
12-06 03:06:56.487: E/AndroidRuntime(7105):     at android.support.v7.internal.widget.TintManager.getDrawable(TintManager.java:133)
12-06 03:06:56.487: E/AndroidRuntime(7105):     at android.support.v7.internal.widget.TintTypedArray.getDrawable(TintTypedArray.java:62)
12-06 03:06:56.487: E/AndroidRuntime(7105):     at android.support.v7.widget.Toolbar.<init>(Toolbar.java:249)
12-06 03:06:56.487: E/AndroidRuntime(7105):     at android.support.v7.widget.Toolbar.<init>(Toolbar.java:191)
12-06 03:06:56.487: E/AndroidRuntime(7105):     ... 26 more

styles.xml

<resources xmlns:android="http://schemas.android.com/apk/res/android">

    <!--
        Base application theme, dependent on API level. This theme is replaced
        by AppBaseTheme from res/values-vXX/styles.xml on newer devices.
    -->
    <style name="AppBaseTheme" parent="android:Theme.Light">
        <!--
            Theme customizations available in newer API levels can go in
            res/values-vXX/styles.xml, while customizations related to
            backward-compatibility can go here.
        -->
        <item name="android:actionBarStyle">@style/MyActionBar</item>
        <item name="windowActionBar">false</item>
    </style>

    <!-- Application theme. -->
    <style name="AppTheme" parent="AppBaseTheme">
        <!-- All customizations that are NOT specific to a particular API-level can go here. -->
        <item name="android:actionBarStyle">@style/MyActionBar</item>
        <item name="windowActionBar">false</item>
    </style>

    <!--  Extends Theme.Holo.Light and removes the Action Bar -->
    <style name="ThemeWithoutActionBar" parent="android:Theme.Holo.Light">
        <item name="android:windowActionBar">false</item>
        <item name="android:windowNoTitle">true</item>
    </style>

    <!-- ************************************************************** -->
    <!-- Action Bar Style (Requires API 11) -->
    <style name="MyActionBar" parent="@android:style/Widget.Holo.Light.ActionBar">
        <item name="android:background">@color/action_bar_bg</item>
        <item name="android:height">60dp</item>
        <item name="android:titleTextStyle">@style/MyActionBar.TitleTextStyle</item>
    </style>
    <!-- ************************************************************** -->

    <!-- ************************************************************** -->
    <!-- Action Bar Text Style (Requires API 13) -->
    <style name="MyActionBar.TitleTextStyle" parent="@android:style/TextAppearance.Holo.Widget.ActionBar.Title">
        <item name="android:textColor">#FFFFFF</item>
        <item name="android:textSize">20sp</item>
    </style>
    <!-- ************************************************************** -->



    <!-- ************************************************************** -->
    <!-- Toolbar Style -->
    <style name="toolbarStyle" parent="Theme.AppCompat">

    </style>

    <style name="ActionBarThemeOverlay" parent="">
        <!-- Color of Toolbar Font Color -->
        <item name="android:textColorPrimary">@android:color/white</item>

        <!-- Color of Toolbar Action Buttons -->
        <item name="colorControlNormal">@android:color/black</item>
        <item name="colorControlHighlight">@android:color/black</item>
    </style>

    <style name="HeaderBar">
        <!-- Color of Toolbar Background Color -->
        <item name="android:background">@color/action_bar_bg</item>
        <item name="android:minHeight">80dp</item>
    </style>

    <style name="ActionBarPopupThemeOverlay" parent="ThemeOverlay.AppCompat.Light" >
        <!-- Color of Toolbar Popup from Action Overflow -->
        <!-- 
        <item name="android:background">@android:color/holo_green_light</item>
        <item name="android:textColor">@android:color/holo_green_dark</item>
        -->
    </style>
    <!-- ************************************************************** -->

</resources>

最佳答案

解决方案是使用最新版本的android-support-v4、android-support-v13、android-support-v7 库

关于Android:InflateException 问题(膨胀类 android.support.v7.widget.Toolbar 时出错),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27331017/

相关文章:

java - Spring Rest Controller 异常处理

java - RunTimeException 是什么原因?

java - 用捕获运行时异常来包装进程是否不好?

c# - 使用 Xamarin Vs Native android 开发 android 应用程序

java - 本地文件的 java.io.InputStream 何时会在关闭时抛出异常?

python - 如何在 Python 中一次捕获多个异常并处理单个异常?

java.lang.IllegalArgumentException : No view found for id 0x7f090047 ("project name":id/content) for fragment FmMenu 异常

android - 带有阴影的弯曲 android 工具栏

java - 非法状态异常 : finishBroadcast() called outside of a broadcast

android - 选项卡不显示