我在布局中这样做:
<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谁有红色背景。
答案 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_width
和layout_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