如何使用菜单布局将自定义项添加到NavigationView?

Tim*_*Rae 51 android navigation-drawer

我一直在尝试通过使用NavigationViewAndroid设计支持库中的新类来简化一些导航抽屉代码.如果您只想要左侧的图标和右侧的文本(例如文档中的示例),那么它的效果很好,但是如果我想android.support.v7.widget.SwitchCompat在Google Play电影应用中添加一个自定义视图,那该怎么办?看下面的截图)?

Google Play电影

我已尝试使用该actionLayout属性指定自定义布局文件,如下面的示例代码中所示,但该属性似乎被忽略,因为它不起作用.

res/menu/navigation_drawer.xml

<menu xmlns:android="http://schemas.android.com/apk/res/android">
    <group android:id="@+id/group1"
            android:checkableBehavior="single">
        <item
            android:id="@+id/nav_screen1"
            android:icon="@drawable/ic_list_black_24dp"
            android:title="Screen 1" />
        <item
            android:id="@+id/nav_screen2"
            android:icon="@drawable/ic_search_black_24dp"
            android:title="Screen2"/>
    </group>
    <group  android:id="@+id/group2">
        <item
            android:id="@+id/nav_custom"
            android:icon="@drawable/custom_icon_24dp"
            app:actionLayout="@layout/nav_drawer_switch"
            android:title="Custom item with switch"/>
        <item
            android:id="@+id/nav_settings"
            android:icon="@drawable/ic_settings_black_24dp"
            android:title="Settings"/>
    </group>
</menu>
Run Code Online (Sandbox Code Playgroud)

res/layout/nav_drawer_switch.xml

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="horizontal" android:layout_width="match_parent"
    android:layout_height="match_parent">
    <android.support.v7.widget.SwitchCompat
        android:layout_width="fill_parent"
        android:layout_height="match_parent"
        android:text="Custom item with switch"/>
</LinearLayout>
Run Code Online (Sandbox Code Playgroud)

我怎样才能让它发挥作用?理想情况下,我想在仍然使用我的菜单布局的同时添加自定义视图,但如果不使用粗糙的黑客(如利用支持库生成的现有布局)那是不可能的,那么我想知道代码最少的解决方案,仍然值得转换NavigationView.

Tim*_*Rae 37

Android支持库23.1现在支持actionLayout属性:

NavigationView提供了一种构建导航抽屉的便捷方式,包括使用菜单XML文件创建菜单项的功能.我们通过app:actionLayout或使用MenuItemCompat.setActionView()为项目设置自定义视图,从而扩展了可能的功能.

所以问题中的代码现在应该正常工作.

  • 请求使用示例 (21认同)
  • 在导航视图中使用时,它仍然无法用于图标和标题,即使您没有指定它们. (7认同)
  • @TimRae:我尝试使用app:actionLayout但它没有用.还有什么我可能会失踪的? (3认同)
  • 如何让actionLayout在标题后面左对齐? (3认同)
  • 它应该只是将属性`app:actionLayout ="@ layout/my_switch_layout"添加到菜单项.我已经举例说明了问题中`my_switch_layout`的样子 (2认同)

Ver*_*tti 16

NavigationView是一个子类FrameLayout,可以有多个子节点:

但是,您可以使用android:layout_gravity属性将多个子项添加到FrameLayout并通过为每个子项分配重力来控制它们在FrameLayout中的位置.

这意味着您可以为您的自定义视图添加NavigationView:

<android.support.design.widget.NavigationView
    android:layout_height="match_parent"
    android:layout_width="wrap_content"
    android:layout_gravity="start"
    android:fitsSystemWindows="true"
    app:menu="@menu/side_menu">

    <LinearLayout 
        android:orientation="horizontal" 
        android:layout_width="match_parent"
        android:layout_height="200dp"
        android:layout_gravity="bottom">

        <android.support.v7.widget.SwitchCompat
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:text="night_mode"/>
    </LinearLayout>
</android.support.design.widget.NavigationView>
Run Code Online (Sandbox Code Playgroud)

  • NavigationView是一个FrameLayout,内部包含一个ListView.此解决方法不允许向ListView添加自定义菜单项,仅显示与ListView的滚动不同步的内容. (4认同)

Ram*_*thi 6

使用switchcompat创建一个布局,并在菜单项中提及它

<item android:id="@+id/notification"
        android:title="Notification"
        app:actionLayout="@layout/notify" />`
Run Code Online (Sandbox Code Playgroud)

然后通知布局添加这个

<android.support.v7.widget.SwitchCompat
    android:id="@+id/switch_compat"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_marginTop="10dp"
    android:checked="false"
    android:onClick="notify"/>
Run Code Online (Sandbox Code Playgroud)

onclick是您的Activity中的keyPoint,实现处理程序,然后它将工作.


rob*_*nst 6

我遇到了同样的问题,发现NavigationView行为不同,具体取决于:

  • 无论你设置android:titleandroid:icon属性上item或不
  • 你的动作布局包含什么样的视图(例如TextView或其他)

不设置用于完全自定义项目的属性:

<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    tools:showIn="navigation_view">

    <item
        android:id="@+id/nav_custom"
        android:title="@null"
        app:actionLayout="@layout/nav_drawer_switch" />
</menu>
Run Code Online (Sandbox Code Playgroud)

(请注意,您也可以不设置android:title,但这会导致 Android Studio 中出现警告。)

结果:

带有开关的导航视图作为自定义操作布局

(这是 27.1.1 的版本com.android.support:design,不确定其他版本。)