0

我在我的布局中这样做:

<android.support.v4.widget.DrawerLayout
        xmlns:android="http://schemas.android.com/apk/res/android"
        xmlns:app="http://schemas.android.com/apk/res-auto"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:fitsSystemWindows="true">

    <!-- your content layout -->

    <android.support.design.widget.NavigationView
            android:layout_width="wrap_content"
            android:layout_height="match_parent"
            android:layout_gravity="start"
            app:headerLayout="@layout/drawer_header"
            app:menu="@menu/drawer"/>
</android.support.v4.widget.DrawerLayout>

这在我的菜单中:

<item
    android:id="@+id/navigation_subheader"
    android:title="@string/navigation_subheader">
    <menu>
        <item
            android:id="@+id/navigation_sub_item_1"
            android:icon="@drawable/ic_android"
            android:title="@string/navigation_sub_item_1"/>
        <item
            android:id="@+id/navigation_sub_item_2"
            android:icon="@drawable/ic_android"
            android:title="@string/navigation_sub_item_2"/>
    </menu>
</item>

第一个问题,如果我这样做,我看不到导航抽屉的所有元素。第二个问题,如果我想添加一个标题,我可以看到它。对于标题,我只放置一个具有红色背景的相对 alyout。

4

2 回答 2

1

问题 #1

您的菜单需要<menu>作为根元素,如下所示:

<menu>
    <item
        android:id="@+id/navigation_item_1"
        android:icon="@drawable/ic_android"
        android:title="@string/navigation_item_1"/>
    <item
        android:id="@+id/navigation_item_2"
        android:icon="@drawable/ic_android"
        android:title="@string/navigation_item_2"/>
</menu>

如果您真的想使用子菜单,请<menu>在顶级<item>. 有关如何嵌套这些元素的更多信息,请参阅菜单资源。

问题 #2

检查你的layout_widthlayout_height。此外,请确保它首先在您的 IDE 布局编辑器中正确显示。

更新:

如果您的导航抽屉在您的操作栏下方绘制(就像您在评论中提到的那样),它与您的布局有关,而不是您的菜单项。请发布您如何创建操作栏(在代码或 xml 中)。

于 2015-05-31T07:25:03.640 回答
1

第一个问题,如果我这样做,我看不到导航抽屉的所有元素。

如果我理解正确,您至少可以看到一项,对吗?您可以尝试改用它吗:

<group android:checkableBehavior="single">
    <item
        android:id="@+id/navigation_item_1"
        android:checked="true"
        android:icon="@drawable/ic_android"
        android:title="@string/navigation_item_1"/>
    <item
        android:id="@+id/navigation_item_2"
        android:icon="@drawable/ic_android"
        android:title="@string/navigation_item_2"/>
</group>

看看这是否有效。大多数导航抽屉以导航项(如上所示的组)开头,下面使用分组项的子标题。

第二个问题,如果我想添加一个标题,我可以看到它。对于标题,我只放置一个具有红色背景的相对 alyout。

您需要为此标题布局设置高度(或 minHeight)。现在它不知道它需要多大。

如果您想要一个示例项目,您可以查看 Chris Banes 提供的示例项目:https ://github.com/chrisbanes/cheesesquare

于 2015-06-02T15:18:41.740 回答