0

0

如何在运行时动态修改 BottomNavigationView 的图标

碧海醫心

碧海醫心

发布时间:2026-03-10 14:51:17

|

650人浏览过

|

来源于php中文网

原创

如何在运行时动态修改 BottomNavigationView 的图标

本文详解如何通过 java 代码在运行时动态更新 bottomnavigationview 中指定菜单项的图标(如未读通知红点图标),并推荐使用 material 3 官方支持的 badge 机制替代手动换图,兼顾规范性与可维护性。

本文详解如何通过 java 代码在运行时动态更新 bottomnavigationview 中指定菜单项的图标(如未读通知红点图标),并推荐使用 material 3 官方支持的 badge 机制替代手动换图,兼顾规范性与可维护性。

在 Android 开发中,BottomNavigationView 是实现底部导航栏的标准组件。当需要根据业务状态(例如存在未读通知)动态改变某一项的视觉表现时,常见需求是高亮或替换图标。虽然可通过 setIcon() 手动切换图标资源,但 Material Design 3 更推荐使用 Badge(徽章) 进行未读提示——它语义清晰、适配深色模式、支持动画且无需额外图标资源。

✅ 推荐方案:使用 Badge(Material 3+)

自 Material Components 1.8.0 起,BottomNavigationView 原生支持 Badge API。只需调用 getOrCreateBadge() 即可为指定菜单项添加/更新徽章:

BottomNavigationView bottomNav = findViewById(R.id.bottomNavigationView);

// 假设 notification 菜单项的 ID 为 R.id.menu_notification
BadgeDrawable badge = bottomNav.getOrCreateBadge(R.id.menu_notification);
badge.setVisible(true);     // 显示徽章
badge.setNumber(3);         // 可选:显示数字(如“3”条未读)
badge.setBackgroundColor(ContextCompat.getColor(this, R.color.red_500));
badge.setTextColor(ContextCompat.getColor(this, R.color.white));

? 注意:R.id.menu_notification 必须与 @menu/bottom_nav.xml 中对应 的 android:id 一致。若仅需红点(无数字),调用 badge.setNumber(0) 并保持 setVisible(true) 即可渲染纯色圆点。

JS超酷图片翻动展示效果
JS超酷图片翻动展示效果

JS超酷图片翻动展示效果,根据鼠标进出图片的方向来控制图片进出的方式,效果超炫,兼容主流浏览器。 使用方法: 1、head区域引用文件 lrtk.css,animation.css 2、在文件中加入!-- 代码 开始 --!-- 代码 结束 --区域代码 3、js代码需要在html代码之后载入public.js,main.js 4、如需修改图片尺寸,直接在lrtk.css第10行修改即可

下载

⚠️ 备用方案:手动更换图标(兼容旧版或特殊场景)

若因兼容性或设计需求必须更换图标(如使用带红点的静态 drawable),可通过 Menu API 操作:

Menu menu = bottomNav.getMenu();
MenuItem notificationItem = menu.findItem(R.id.menu_notification);
notificationItem.setIcon(R.drawable.ic_notification_red); // 替换为自定义图标

⚠️ 重要限制与注意事项

  • setIcon() 会完全替换原始图标,丢失 app:itemIconTint 的颜色控制;
  • 图标尺寸需严格匹配(建议使用 vector drawable 并统一设置 android:width/height);
  • 若启用 app:labelVisibilityMode="labeled",图标更换后文字颜色不受影响,但需确保新图标与文字的可读性对比度达标;
  • 不推荐在 onCreate() 中直接调用 setIcon() —— 应确保 BottomNavigationView 已完成菜单 inflate(通常在 setOnItemSelectedListener 设置后操作更稳妥)。

✅ 最佳实践总结

场景 推荐方式 优势
未读消息提示(含数字/红点) getOrCreateBadge() 符合 Material 规范、自动适配、支持动画、无需额外资源
自定义图标样式(如品牌化图标) MenuItem.setIcon() 灵活可控,适合非标准提示
需要动态切换多状态图标(如已读/未读/错误) 结合 setIcon() 与状态管理 适用于复杂 UI 状态机

最后提醒:无论采用哪种方式,请始终在主线程操作 UI,并在 Activity/Fragment 生命周期安全时调用(例如避免在 onDestroy() 后更新 Badge)。对于通知状态,建议将 Badge 更新逻辑封装进统一的通知管理器,便于后续扩展(如清除徽章、联动 Push 服务等)。

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
pdf怎么转换成xml格式
pdf怎么转换成xml格式

将 pdf 转换为 xml 的方法:1. 使用在线转换器;2. 使用桌面软件(如 adobe acrobat、itext);3. 使用命令行工具(如 pdftoxml)。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1945

2024.04.01

xml怎么变成word
xml怎么变成word

步骤:1. 导入 xml 文件;2. 选择 xml 结构;3. 映射 xml 元素到 word 元素;4. 生成 word 文档。提示:确保 xml 文件结构良好,并预览 word 文档以验证转换是否成功。想了解更多xml的相关内容,可以阅读本专题下面的文章。

2119

2024.08.01

xml是什么格式的文件
xml是什么格式的文件

xml是一种纯文本格式的文件。xml指的是可扩展标记语言,标准通用标记语言的子集,是一种用于标记电子文件使其具有结构性的标记语言。想了解更多相关的内容,可阅读本专题下面的相关文章。

1167

2024.11.28

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

764

2023.08.10

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

764

2023.08.10

android开发三大框架
android开发三大框架

android开发三大框架是XUtil框架、volley框架、ImageLoader框架。本专题为大家提供android开发三大框架相关的各种文章、以及下载和课程。

338

2023.08.14

android是什么系统
android是什么系统

Android是一种功能强大、灵活可定制、应用丰富、多任务处理能力强、兼容性好、网络连接能力强的操作系统。本专题为大家提供android相关的文章、下载、课程内容,供大家免费下载体验。

1819

2023.08.22

android权限限制怎么解开
android权限限制怎么解开

android权限限制可以使用Root权限、第三方权限管理应用程序、ADB命令和Xposed框架解开。详细介绍:1、Root权限,通过获取Root权限,用户可以解锁所有权限,并对系统进行自定义和修改;2、第三方权限管理应用程序,用户可以轻松地控制和管理应用程序的权限;3、ADB命令,用户可以在设备上执行各种操作,包括解锁权限;4、Xposed框架,用户可以在不修改系统文件的情况下修改应用程序的行为和权限。

2132

2023.09.19

Go高并发任务调度与Goroutine池化实践
Go高并发任务调度与Goroutine池化实践

本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。

22

2026.03.10

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号