【问题标题】:How to add dividers in Bottom Navigation View如何在底部导航视图中添加分隔线
【发布时间】:2017-03-29 05:57:41
【问题描述】:

我正在尝试在 BottomNavigationView

的菜单项中添加分隔符

所有项目都在底部水平显示,但我无法在其中添加分隔线。

底部导航视图 xml:

<android.support.design.widget.BottomNavigationView
        android:id="@+id/navigation"
        android:layout_width="match_parent"
        android:layout_height="?attr/actionBarSize"
        android:focusable="false"
        app:itemBackground="@color/colorPrimaryDark"
        app:itemIconTint="@color/bottom_navigation_selector"
        app:itemTextColor="@color/bottom_navigation_selector"
        app:layout_anchor="@id/container"
        app:layout_anchorGravity="bottom"
        app:menu="@menu/bottom_nav_items" />

还有bottom_nav_items.xml:

<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android">
<item
    android:id="@+id/menu_family"
    android:checked="false"
    android:icon="@drawable/family"
    android:title="@string/family" />
<item
    android:id="@+id/menu_me"
    android:checked="false"
    android:icon="@drawable/me"
    android:title="@string/me" />

<item
    android:id="@+id/menu_blank"
    android:checkable="false"
    android:enabled="false"
    android:title="" />
<item
    android:id="@+id/menu_event"
    android:checked="false"
    android:icon="@drawable/event"
    android:title="@string/event" />
<item
    android:id="@+id/menu_more"
    android:checked="false"
    android:icon="@drawable/more"
    android:title="@string/more" />

感谢您的支持。

【问题讨论】:

  • 尝试将每个菜单项放在单独的组中
  • 试过了,但它给了我 xml 膨胀错误

标签: android menuitem bottomnavigationview


【解决方案1】:

像这样创建一个可绘制的item_bg.xml

<layer-list xmlns:android="http://schemas.android.com/apk/res/android">

    <item>
        <shape android:shape="rectangle" >
            <solid android:color="#F4F4F4" />
        </shape>
    </item>

    <item android:top="-2dp" android:right="-2dp" android:left="-2dp">
        <shape>
            <solid android:color="@android:color/transparent" />
            <stroke
                android:width="1dp"
                android:color="#EAEAEA" />
        </shape>

    </item>

</layer-list>

然后将其添加到 NavigationView 为 app:itemBackground="@drawable/item_bg"

 <android.support.design.widget.BottomNavigationView
    android:id="@+id/navigation"
    android:layout_width="match_parent"
    android:layout_height="?attr/actionBarSize"
    android:focusable="false"
    app:itemBackground="@drawable/item_bg"
    app:itemIconTint="@color/bottom_navigation_selector"
    app:itemTextColor="@color/bottom_navigation_selector"
    app:layout_anchor="@id/container"
    app:layout_anchorGravity="bottom"
    app:menu="@menu/bottom_nav_items" />

【讨论】:

  • 感谢您的解决方案。但我有一个问题,每当我使用分隔线时,我都会得到至少一个带有屏幕末端边框的项目。我想缩小这个差距。你能告诉我我该怎么做吗? @ShutterSoul
【解决方案2】:

如果有人仍然有兴趣这样做,尽管不建议这样做。 您可以通过编程方式实现这一点,以避免像公认的解决方案那样在屏幕末尾设置分隔符。

 val bottomNavigationMenuView = (binding.navView[0] as BottomNavigationMenuView)
    if (bottomNavigationMenuView.isNotEmpty()) {
                  bottomNavigationMenuView[1].setBackgroundResource(R.drawable.bottom_view_divider)
        bottomNavigationMenuView[2].setBackgroundResource(R.drawable.bottom_view_divider)
        bottomNavigationMenuView[3].setBackgroundResource(R.drawable.bottom_view_divider)

    }

注意:点击项目时,您将失去底部视图导航中的涟漪效果。

【讨论】:

    【解决方案3】:

    试试这个方法……

    BottomNavigationView mBottomNavigationView = (BottomNavigationView) findViewById(R.id.navigation);
    NavigationMenuView navMenuView = (NavigationMenuView) mBottomNavigationView.getChildAt(0);
    navMenuView.addItemDecoration(new DividerItemDecoration(MainActivity.this,DividerItemDecoration.VERTICAL));
    

    【讨论】:

    • 另一个选项是你需要在菜单中设置选择和取消选择drawable和绑定drawable
    • 您的回答无效。 @AnshulTyagi 正在使用 BottomNavigationView,它没有添加项目装饰的方法。
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2021-01-25
    • 2017-09-29
    • 2017-08-30
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多