Androidx底部导航栏使可隐藏导航项保持突出显示

时间:2020-03-06 15:58:34

标签: android android-fragments androidx android-architecture-navigation android-bottomnav

当用户未通过身份验证时,我将隐藏一个底部的导航项目(该项目将在用户通过身份验证后显示,在本例中为“消息片段”)。效果很好,但是当显示并选择了该片段时,即使我在该片段上,我以前所在的导航菜单仍会突出显示。另外,一旦我选择了另一个导航项目,“消息”仍会在底部导航栏上突出显示。请参阅下面的屏幕截图:

  1. 尚未选择消息时 Home Fragment, Message Fragment not yet selected

  2. 当我选择Message Fragment之前(我之前来自Home Fragment) Message Fragment Selected (Previously, Home Fragment)

  3. 当我返回到除消息以外的任何其他片段时(在本例中为“家庭片段”) Home Fragment Selected (Previously, Message Fragment)

这是我的MainActivity(请注意,navView.menu.findItem(R.id.navigation_messages).isVisible是底部导航栏中导致此行为的主要原因)

class MainActivity : AppCompatActivity() {

    private var authState : Int = 1

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)
        val navView: BottomNavigationView = findViewById(R.id.nav_view)
        val navController = findNavController(R.id.nav_host_fragment)

        val appBarConfiguration = AppBarConfiguration(
            setOf(
                R.id.navigation_home, R.id.navigation_explore, R.id.navigation_messages,  R.id.navigation_account
            )
        )

        // Passing each menu ID as a set of Ids because each
        // menu should be considered as top level destinations.

        setupActionBarWithNavController(navController, appBarConfiguration)
        navView.setupWithNavController(navController)

        when(authState) {
            0 -> navView.menu.findItem(R.id.navigation_messages).isVisible = false
            1 -> navView.menu.findItem(R.id.navigation_messages).isVisible = true
        }
    }

    override fun onSupportNavigateUp(): Boolean {
        return navigateUp(Navigation.findNavController(this, R.id.nav_host_fragment), AppBarConfiguration(setOf(
            R.id.navigation_home, R.id.navigation_explore, R.id.navigation_messages, R.id.navigation_account
        )))
    }
}

另外,这是我的activity_main.xml文件:

<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:id="@+id/container"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <com.google.android.material.bottomnavigation.BottomNavigationView
        android:id="@+id/nav_view"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_marginStart="0dp"
        android:layout_marginEnd="0dp"
        android:background="?android:attr/windowBackground"
        app:itemHorizontalTranslationEnabled="false"
        app:labelVisibilityMode="labeled"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintLeft_toLeftOf="parent"
        app:layout_constraintRight_toRightOf="parent"
        app:menu="@menu/bottom_nav_menu" />

    <fragment
        android:id="@+id/nav_host_fragment"
        android:name="androidx.navigation.fragment.NavHostFragment"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        app:defaultNavHost="true"
        android:layout_marginBottom="56dp"
        app:layout_constraintBottom_toTopOf="@+id/nav_view"
        app:layout_constraintHorizontal_bias="0.0"
        app:layout_constraintLeft_toLeftOf="parent"
        app:layout_constraintRight_toRightOf="parent"
        app:layout_constraintTop_toTopOf="parent"
        app:layout_constraintVertical_bias="0.0"
        app:navGraph="@navigation/mobile_navigation" />

</androidx.constraintlayout.widget.ConstraintLayout>

请注意,我使用的是Android Jetpack导航架构组件,该组件使其他类似的解决方案like thisthisthis在这种情况下不可行。

0 个答案:

没有答案