如何在NavigationView中添加Listview?

时间:2015-08-28 14:19:26

标签: android android-listview navigation-drawer android-recyclerview navigationview

我的Android应用程序中有一个导航抽屉。我可以使用navigationView在导航抽屉中显示一个菜单,但我想在抽屉中显示listview或recyclerview。我需要这样,因为抽屉菜单对每个用户来说都不一样。用户选择他们想要阅读的报纸。例如:

  • 用户A的列表视图将是这样的:华盛顿邮报,纽约 时代,卫报,独立。

  • 用户B的列表视图:每日邮报,华盛顿邮报,金融时报。

如何在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 个答案:

答案 0 :(得分:5)

您可以使用此代码,但请记住您需要使用适配器来填充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>

您有以下结果:enter image description here

答案 1 :(得分:1)

NavigationView只不过是RecyclerView的包装器,它从菜单XML资源填充列表,并提供开箱即用的符合材料的抽屉。实际上没有任何特殊逻辑可以在导航抽屉中使用。

如果您想要一个更具动态性的导航抽屉,则应该简单地将布局XML中的NavigationView替换为RecyclerView,并像填充任何其他RecyclerView一样填充它。