Android:BottomNavigationView自定义选中颜色和文字


前言

我们常常遇到这样的任务场景,需要动手制作一个导航栏,要求在点击时图标颜色和文字发生改变,那么这样的场景应该如何实现呢?

一、图标的动态更改

图标的动态更改我们通过自定义Layout和BottomNavigationView中的属性进行更改

新建Menu等步骤就不进行赘述了,这一部分还不了解的朋友可以先看一下BottomNavigationView的使用

这里直接放出代码供大家进行阅读

<com.google.android.material.bottomnavigation.BottomNavigationView
        android:id="@+id/mainBottomNavigation"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_alignParentBottom="true"
        android:background="#161817"
        app:itemIconTint="@drawable/bottom_btn_selected_color"
        app:labelVisibilityMode="labeled"
        android:elevation="1dp"
        app:menu="@menu/menu"/>

重点关注itemIconTint属性,它是实现BottomNavigationView的实现按钮动态颜色转变的关键

bottom_btn_selected_color.xml属性如下

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:color="@color/bottom_btn_selected" android:state_checked="true" />
    <item android:color="@color/bottom_btn_unselected" android:state_checked="false"/>
</selector>

最终实现效果

在这里插入图片描述

在这里插入图片描述
曾经笔者尝试过在menu中设置对每个Item设置drawable的形式进行区分点击和未点击的状态,但是事实上点击的事件是在BottomNavigationView这一层就进行了消费,并不会向下传递,所以该种做法并不行得通,有相同想法的uu可以看看

二、文字的动态更改

文字的动态更改需要通过Java代码进行实现,具体的代码如下

//获取底部导航图标颜色,根据图标颜色设置文字颜色
        Resources resource = getResources();
        @SuppressLint("ResourceType")
        ColorStateList csl = resource.getColorStateList(R.drawable.bottom_btn_selected_color);

        bottomNav.setItemTextColor(csl);

这里的drawable文件主要是用于实现颜色切换,上面第一个问题中的drawable文件类似

最终实现效果如上图所示

  • 7
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
BottomNavigationViewAndroid官方提供的一个用于底部导航栏的控件,我们可以通过自定义样式来改变其外观。 首先,在res目录下的values文件夹中创建一个新的styles.xml文件。这个文件将用于定义BottomNavigationView的样式。 然后,在styles.xml文件中添加一个新的style,如下所示: ``` <style name="BottomNavigationViewStyle" parent="Widget.Design.BottomNavigationView"> <item name="android:background">@color/colorPrimary</item> <item name="android:itemIconTint">@color/selector_bottom_navigation_icon</item> <item name="android:itemTextColor">@color/selector_bottom_navigation_text</item> <item name="itemTextAppearanceActive">@style/BottomNavigationTextAppearanceActive</item> <item name="itemTextAppearanceInactive">@style/BottomNavigationTextAppearanceInactive</item> </style> ``` 上述代码中,我们定义BottomNavigationView的背景颜色为colorPrimary,图标和文字颜色使用了selector_bottom_navigation_icon和selector_bottom_navigation_text文件中的颜色选择器。同时,我们还定义了活动状态和非活动状态下的文字样式为BottomNavigationTextAppearanceActive和BottomNavigationTextAppearanceInactive。 最后,在布局文件中使用我们自定义BottomNavigationView样式,如下所示: ``` <android.support.design.widget.BottomNavigationView android:id="@+id/bottomNavigationView" android:layout_width="match_parent" android:layout_height="wrap_content" style="@style/BottomNavigationViewStyle" app:menu="@menu/bottom_navigation_menu" /> ``` 以上就是对BottomNavigationView自定义样式的简单介绍。通过自定义样式,我们可以轻松地改变BottomNavigationView的外观,从而适应我们的项目需求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值