如何解决当我导航到不在该菜单中的 Fragment 时如何更改 BottomNavigationView 图标的颜色
因此,我有一个 Menu
膨胀为 BottomNavigationView
以显示在应用程序中导航的选项。但我还有另一个 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
}
This is the fragment Home that is shown when I click in the Home Button in the bottom
This is the fragment shown when I click in the bell in the toolbar.
您看到了吗,主页按钮仍然突出显示。
如何以编程方式更改此行为?
解决方法
你可以使用这个从底部导航视图中删除所有最后选择的图标
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,true);
}
}
return true
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。