如何在NavigationView中添加Listview?

3
我是一名有用的助手,可以为您翻译文本。
我有一个导航抽屉在我的安卓应用中。我可以使用NavigationView在导航抽屉中显示菜单,但是我想在抽屉中显示一个ListView或RecyclerView。我需要这样做,因为抽屉菜单对于每个用户都不同。用户选择他们想要阅读的报纸。例如:
用户A的ListView如下:《华盛顿邮报》、《纽约时报》、《卫报》、《独立报》。
用户B的ListView:《每日邮报》、《华盛顿邮报》、《金融时报》。
我该如何在NavigationView上添加ListView?
activity_main.xml:
<android.support.v4.widget.DrawerLayout >
 ...
<android.support.design.widget.CoordinatorLayout>
   ...
    <android.support.design.widget.AppBarLayout>
       ...
        <android.support.v7.widget.Toolbar/>

    </android.support.design.widget.AppBarLayout>

    <android.support.v4.view.ViewPager
        app:layout_behavior="@string/appbar_scrolling_view_behavior" />

</android.support.design.widget.CoordinatorLayout>

<android.support.design.widget.NavigationView
    android:id="@+id/navigation_drawer"
    android:layout_width="200dp"
    android:layout_height="match_parent"
    android:layout_gravity="start"
    app:menu="@menu/menu_drawer"
    app:layout="@layout/custom_row"/>

menu_drawer.xml:

<group
    android:id="@+id/group_1"
    android:checkableBehavior="single">
    <item
        android:id="@+id/nav_first_fragment"
        android:icon="@drawable/ic_number_0"
        android:title="First" />
    <item
        android:id="@+id/nav_second_fragment"
        android:icon="@drawable/ic_number_1"
        android:title="Second" />
    <item
        android:id="@+id/nav_third_fragment"
        android:icon="@drawable/ic_number_2"
        android:title="Third" />
</group>

<group
    android:id="@+id/group_2"
    android:checkableBehavior="single">

    <item
        android:id="@+id/navigation_item_11"
        android:icon="@drawable/ic_number_0"
        android:title="My Newspapers">

        <menu>

            <item
                android:id="@+id/navigation_item_1"
                android:icon="@drawable/ic_number_0"
                android:title="@string/navigation_item_1" />
            <item
                android:id="@+id/navigation_item_2"
                android:icon="@drawable/ic_number_1"
                android:title="@string/navigation_item_2" />
            <item
                android:id="@+id/navigation_item_3"
                android:icon="@drawable/ic_number_2"
                android:title="@string/navigation_item_3" />
            <item
                android:id="@+id/navigation_item_4"
                android:icon="@drawable/ic_number_3"
                android:title="@string/navigation_item_4" />
            <item
                android:id="@+id/navigation_item_5"
                android:icon="@drawable/ic_number_4"
                android:title="@string/navigation_item_5" />

        </menu>
    </item>
</group>

custom_row.xml:

<TextView xmlns:android="http://schemas.android.com/apk/res/android"
      android:id="@+id/text_superhero"
      android:layout_width="match_parent"
      android:layout_height="match_parent"
      android:paddingBottom="4dp"
      android:paddingLeft="16dp"
      android:paddingRight="16dp"
      android:paddingTop="4dp"
      android:text="Superhero"
      android:textColor="@color/colorTextSecondary">
2个回答

11

你可以使用这段代码,但记得你需要使用适配器来填充你的ListView。

<android.support.design.widget.NavigationView
    android:id="@+id/nav_view"
    android:layout_width="wrap_content"
    android:layout_height="match_parent"
    android:layout_gravity="start"
    android:fitsSystemWindows="true"
    app:headerLayout="@layout/nav_header_main">

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="vertical">

        <include layout="@layout/nav_header_main" />

        <ListView
            android:id="@+id/list_slidermenu"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:choiceMode="singleChoice"
            android:divider="@color/list_divider"
            android:dividerHeight="1dp"
            android:listSelector="@drawable/list_selector"
            android:textColor="#424242"/>

    </LinearLayout>

</android.support.design.widget.NavigationView>

你有这个结果:

screenshot


2
一个 NavigationView 实际上就是一个封装了 RecyclerView 的容器,它可以从菜单 XML 资源中填充列表,并提供符合 Material 标准的抽屉效果。它在导航抽屉中工作的原理并没有什么特殊的逻辑。
如果你想要一个更加动态的导航抽屉,你只需要在你的布局 XML 中用一个 RecyclerView 替换 NavigationView 并像使用其他任何 RecyclerView 一样填充它即可。

我用RecyclerView替换了NavigationView,但是它没有起作用。RecyclerView匹配了整个屏幕,工具栏和其他视图都没有显示出来。 - cimenmus
1
你的导航抽屉完全独立于工具栏和屏幕上的其他视图。确保只替换 NavigationView,并且 RecyclerView 的所有属性与之前相同(例如 android:layout_width)。 - Bryan Herbst
我只是用RecyclerView替换了NavigationView标签,没有改变属性,只是添加了一些新属性,完成了!谢谢。 - cimenmus

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接