El tipo NavController
se basa en uno o más objetos Navigator
para realizar la operación de navegación. De manera predeterminada, NavController
te permite dejar el gráfico de navegación si navegas a otra actividad a través de la clase ActivityNavigator
y su clase ActivityNavigator.Destination
anidada.
Para navegar a cualquier otro tipo de destino, se deben agregar uno o más objetos Navigator
adicionales a NavController
. Por ejemplo, cuando usas fragmentos como destinos, el objeto NavHostFragment
agrega automáticamente la clase FragmentNavigator
a su NavController
.
Para agregar un objeto Navigator
nuevo a un NavController
, usa el método getNavigatorProvider()
y, luego, el método addNavigator()
.
En el siguiente código, se muestra un ejemplo de cómo agregar un objeto CustomNavigator
a un NavController
:
Kotlin
val customNavigator = CustomNavigator() navController.navigatorProvider += customNavigator
Java
CustomNavigator customNavigator = new CustomNavigator(); navController.getNavigatorProvider().addNavigator(customNavigator);
La mayoría de las clases Navigator
tiene una subclase de destino anidada. Esa subclase se puede utilizar para especificar atributos adicionales exclusivos de tu destino. Si deseas obtener más información sobre las subclases de destino, consulta la documentación de referencia de la clase Navigator
correspondiente.
Recursos adicionales
Si deseas obtener más información sobre la navegación, consulta los siguientes recursos adicionales.