mirror of
https://github.com/material-components/material-components-android.git
synced 2026-02-05 12:07:44 +08:00
4.1 KiB
4.1 KiB
BottomNavigationView
Bottom navigation bars make it easy to explore and switch between top-level views with a single tap.
This pattern can be used when you have between 3 and 5 top-level destinations to navigate to.
Design & API Documentation
Usage
- Create a menu resource with up to 5 navigation targets (BottomNavigationView does not support more than 5 items).
- Lay out your
BottomNavigationViewbelow your content. - Set the
app:menuattribute on yourBottomNavigationViewto your menu resource. - Listen for selection events using
setOnNavigationItemSelectedListener(...).
A typical layout file would look like this:
<FrameLayout
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">
<!-- Main content -->
<android.support.design.widget.BottomNavigationView
android:id="@+id/bottom_navigation"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_gravity="bottom"
app:itemBackground="@color/colorPrimary"
app:itemIconTint="@color/white"
app:itemTextColor="@color/white"
app:menu="@menu/navigation_menu" />
</FrameLayout>
Handling Enabled/States
The app:itemIconTint and app:itemTextColor take a
ColorStateList
instead of a simple color, this means that you can write a selector for these
colors that accounts for enabled/disabled status.
For example, you could have a navigation_colors.xml that contains:
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item
android:state_enabled="true"
android:color="@color/white" />
<item
android:state_enabled="false"
android:color="@color/colorPrimaryDark" />
</selector>
And you would use it like this on your BottomNavigationView:
<android.support.design.widget.BottomNavigationView
android:id="@+id/bottom_navigation"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_alignParentBottom="true"
app:itemBackground="@color/colorPrimary"
app:itemIconTint="@drawable/navigation_colors"
app:itemTextColor="@drawable/navigation_colors"
app:menu="@menu/navigation_menu" />
Related Concepts
There are other navigation patterns you should be aware of
- Hierarchical navigation. See also Navigation with Back and Up.
- Swipeable tabs using TabLayout and ViewPager.
- Using NavigationView to display a longer list of navigation targets, usually in a navigation drawer.