Android利用系统原生BottomNavigationView实现底部导航

Posted 菜鸟工程司

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Android利用系统原生BottomNavigationView实现底部导航相关的知识,希望对你有一定的参考价值。

   <android.support.design.widget.BottomNavigationView
        android:id="@+id/navigation"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_marginStart="0dp"
        android:layout_marginEnd="0dp"
        android:background="#2488e2"
  app:itemIconTint="@color/tab_icon" app:itemTextColor="@color/tab_icon" app:layout_constraintBottom_toBottomOf="parent" app:layout_constraintLeft_toLeftOf="parent" app:layout_constraintRight_toRightOf="parent" app:menu="@menu/navigation" />
itemIconTint,
itemTextColor:分别代表选中和非选中状态下按钮图标和文字的颜色

在color下新建tab_icon.xml,
<selector xmlns:android="http://schemas.android.com/apk/res/android">
 <item android:color="@color/colorNormal" android:state_checked="false" />
    <item android:color="@color/colorSelected" android:state_checked="true"/>
</selector>

menu:在menu下建一个xxmenu.xml ,每一个item代表一个底部标签

 <item
        android:id="@+id/navigation_1"
        android:icon="@drawable/icon"
        android:title="@string/tab_title" />

 

当底部item过多的时候点击会有一个偏移的现象????

解决方法:定义一个工具类
public class BottomNavigationViewHelper {
    @SuppressLint("RestrictedApi")
    public static void disableShiftMode(BottomNavigationView view) {
        BottomNavigationMenuView menuView = (BottomNavigationMenuView) view.getChildAt(0);
        try {
            Field shiftingMode = menuView.getClass().getDeclaredField("mShiftingMode");
            shiftingMode.setAccessible(true);
            shiftingMode.setBoolean(menuView, false);
            shiftingMode.setAccessible(false);
            for (int i = 0; i < menuView.getChildCount(); i++) {
                BottomNavigationItemView item = (BottomNavigationItemView) menuView.getChildAt(i);
                //noinspection RestrictedApi
                item.setShiftingMode(false);
                // set once again checked value, so view will be updated
                //noinspection RestrictedApi
                item.setChecked(item.getItemData().isChecked());
            }
        } catch (NoSuchFieldException e) {

        } catch (IllegalAccessException e) {

        }
    }

}

 










以上是关于Android利用系统原生BottomNavigationView实现底部导航的主要内容,如果未能解决你的问题,请参考以下文章

利用 Android 系统原生 API 实现分享功能(2)

web移动端和PC端利用chrome同步开发调试

如何使 Android BottomNavigationView 背景透明?

利用 Chrome 开发者工具远程调试 Android 中的原生 WebView

利用 Flutter 如何优雅的调用 Android 原生方法?

怎样下载原生android系统