Android 导航组件-从自定义工具栏隐藏导航向上图标和片段标签

Android 导航组件-从自定义工具栏隐藏导航向上图标和片段标签,android,navigation,android-actionbar,android-toolbar,android-architecture-components,Android,Navigation,Android Actionbar,Android Toolbar,Android Architecture Components,我正在尝试为我的应用程序使用自定义操作栏(带有自定义徽标和导航向上按钮) <androidx.appcompat.widget.Toolbar xmlns:android="http://schemas.android.com/apk/res/android" android:id="@+id/toolbar" android:layout_width="match_parent" android:layout_height="?attr/actionBarSize" android:ba

我正在尝试为我的应用程序使用自定义操作栏(带有自定义徽标和导航向上按钮)

<androidx.appcompat.widget.Toolbar xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:layout_height="?attr/actionBarSize"
android:background="@android:color/white"/>

toolbar.setupWithNavController()
方法调用和的
toolbar
方法。这些方法对自定义图标或标题一无所知-它们只更新内置导航图标和标题

这意味着
toolbar.setupWithNavController()
不应该被调用

相反,如果您希望自定义工具栏布局对导航更改作出反应,则需要遵循指南并使用来执行任何自定义逻辑,而不是调用
工具栏。setupWithNavController()


如果您使用的是
工具栏。setupWithNavController
,如果您不使用默认的导航向上按钮和片段标签,是否有特殊原因?@ianhanniballake只想使用导航处理操作栏操作。这就是我用这个的原因
val navController = findNavController(R.id.nav_host_fragment_auth)
val appBarConfiguration = AppBarConfiguration(navController.graph)
val toolbar = findViewById<Toolbar>(R.id.toolbarAuth)
toolbar.setupWithNavController(navController, appBarConfiguration)

val mCustomView: View = layoutInflater.inflate(R.layout.custom_actionbar_auth, null)
val mButtonBack= mCustomView.findViewById<ImageView>(R.id.imageBack)
toolbar.addView(mCustomView)
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/custom_actionbar"
android:layout_width="match_parent"
android:layout_height="?attr/actionBarSize"
android:background="@color/colorPrimary"
android:paddingStart="20dp"
android:paddingEnd="20dp">

<ImageView
    android:id="@+id/imageBack"
    android:layout_width="10dp"
    android:layout_height="15dp"
    android:layout_alignParentStart="true"
    android:layout_centerVertical="true"
    android:background="@drawable/ic_arrow_back_white" />

<ImageView
    android:id="@+id/imageTitle"
    android:layout_width="115dp"
    android:layout_height="20dp"
    android:layout_centerHorizontal="true"
    android:layout_centerVertical="true"
    android:background="@drawable/ic_actionbar_logo" />
supportActionBar?.setDisplayHomeAsUpEnabled(false)
supportActionBar?.setHomeButtonEnabled(false)
supportActionBar?.setDisplayShowTitleEnabled(false)

toolbar.setNavigationIcon(null)
val navController = findNavController(R.id.nav_host_fragment_auth)
val toolbar = findViewById<Toolbar>(R.id.toolbarAuth)
val mCustomView: View = layoutInflater.inflate(R.layout.custom_actionbar_auth, null)
val mButtonBack = mCustomView.findViewById<ImageView>(R.id.imageBack)
toolbar.addView(mCustomView)
navController.addOnDestinationChangedListener { _, destination, arguments ->
    // Update the icon for your mButtonBack, etc.
}
mButtonBack.setOnClickListener {
    navController.navigateUp()
}