<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) { } } }
原文地址:https://www.cnblogs.com/cnman/p/10289049.html
时间: 2024-09-30 02:25:37