android - 当我导航到不在该菜单中的片段时如何更改 BottomNavigationView 图标的颜色
问题描述
所以,我有一个Menu
膨胀到 aBottomNavigationView
来显示在应用程序中导航的选项。但我也有另一个Menu
膨胀的Toolbar
导航到应用程序的另一部分。这工作正常,但是当我单击 中的图标时toolbar
,最后选择的图标bottomNav
仍然具有突出显示,就好像它被选中一样。
底部导航视图
<androidx.coordinatorlayout.widget.CoordinatorLayout
android:id="@+id/bottomBarContainer"
android:layout_width="match_parent"
android:layout_height="100dp"
android:layout_gravity="bottom" >
<com.google.android.material.floatingactionbutton.FloatingActionButton
android:id="@+id/fabNewIssue"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:backgroundTint="@color/strong_blue"
android:contentDescription="@string/add_issue"
app:srcCompat="@drawable/ic_outline_add_24"
app:tint="@color/white"
app:fabCustomSize="60dp"
app:layout_anchor="@+id/bottomBar"
app:layout_anchorGravity="top|center"/>
<com.google.android.material.bottomappbar.BottomAppBar
android:id="@+id/bottomBar"
android:layout_width="match_parent"
android:layout_height="60dp"
android:layout_gravity="bottom"
app:fabAlignmentMode="center"
app:fabCradleMargin="10dp"
app:fabCradleRoundedCornerRadius="10dp">
<com.google.android.material.bottomnavigation.BottomNavigationView
android:id="@+id/bottomNavigationView"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_marginEnd="16dp"
android:background="@android:color/transparent"
app:menu="@menu/bottom_nav_menu"/>
</com.google.android.material.bottomappbar.BottomAppBar>
</androidx.coordinatorlayout.widget.CoordinatorLayout>
我如何管理点击的代码
override fun onCreateOptionsMenu(menu: Menu?): Boolean {
menuInflater.inflate(R.menu.toolbar_menu, menu)
return true
}
override fun onNavigationItemSelected(item: MenuItem): Boolean {
when(item.itemId) {
R.id.home -> {
changeFragment(HomeFragment(), getString(R.string.tag_home))
}
R.id.settings -> {
changeFragment(SettingsFragment(), getString(R.string.tag_settings))
}
}
return true
}
override fun onMenuItemClick(item: MenuItem?): Boolean {
when(item?.itemId) {
R.id.app_bar_notification -> {
changeFragment(NotificationsFragment(), getString(R.string.tag_notifications))
}
}
return true
}
你可以看到,主页按钮仍然突出显示。
如何以编程方式更改此行为?
解决方案
您可以使用此方法从 BottomNavigationView 中删除所有最后选择的图标
findViewById<BottomNavigationView>(R.id. bottomNavigationView).getMenu().setGroupCheckable(0, false, true);
完整的解决方案
替换这个:
override fun onMenuItemClick(item: MenuItem?): Boolean {
when(item?.itemId) {
R.id.app_bar_notification -> {
changeFragment(NotificationsFragment(), getString(R.string.tag_notifications))
}
}
return true
}
有了这个:
override fun onMenuItemClick(item: MenuItem?): Boolean {
when(item?.itemId) {
R.id.app_bar_notification -> {
changeFragment(NotificationsFragment(), getString(R.string.tag_notifications))
findViewById<BottomNavigationView>(R.id. bottomNavigationView).getMenu().setGroupCheckable(0, false, true);
}
}
return true
}
推荐阅读
- android - 使用 Espresso 时在 SearchView 上测试文本提交
- python - Python DateTime 减去 TimeDelta 与 TimeDelta 减去 DateTime
- reactjs - React Router v4:无法在 GitHub 页面上加载页面
- jquery - jQuery - 请求 JSON 数据时出现 AJAX 意外令牌错误
- c# - Unity2D:敌人在其半径内时不会跟随玩家
- c# - 套接字:阻塞操作被 WSACancelBlockingCall 调用中断
- python - 只有for循环中列表的最后一次迭代在用于pacman游戏的while循环[Python,Pygame]中生效,我该如何解决这个问题?
- swift - 在 reloadData func 之后以 nil 值加载 CollectionViewCell
- css - Bootstrap 4 卡相同的高度和底部对齐
- pandas - Plotting certain bars in a series and groupnig the rest in one bar