如何在新的android支持库中添加导航视图

时间:2015-05-31 06:16:35

标签: android android-design-library

我在布局中这样做:

<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谁有红色背景。

2 个答案:

答案 0 :(得分: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>内。有关如何嵌套这些元素的详细信息,请参阅Menu Resource

  

问题#2

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

<强>更新

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

答案 1 :(得分: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