Navegació

El component de navegació fa servir un graf de navegació per gestionar la navegació de la teva aplicació.

Introducció

El Navigation component utilitza un graf de navegació per gestionar la navegació de la teva aplicació.

El graf de navegació és l’estructura de dades que conté cada destinació dins la teva aplicació i la connexió entre elles.

Note

El graf de navegació és diferent de la back stack, que és una pila dins del NavController que conté les destinacions que l’usuari ha visitat recentment.

Hi ha tres tipus de destinacions: hosted, dialog, i activity.

Les destinacions “hosted” són les que s’utilitzen amb més freqüència, i ocupen tota la pantalla del’amfitrió.

Entorn de treball

Crea un nou projecte compose-navigation amb Amper

Habilita la serialització i afegeix una dependència amb la biblioteca navigation-compose: module.yaml

A continuació tens una aplicació d’exemple amb dues pantalles (“screens”).

Modifica el fitxer src/main.kt:

src/main.kt
import androidx.compose.foundation.layout.Column
import androidx.compose.material.Button
import androidx.compose.material.MaterialTheme
import androidx.compose.material.Text
import androidx.compose.runtime.*
import androidx.navigation.NavController
import androidx.navigation.compose.NavHost
import androidx.navigation.compose.composable
import androidx.navigation.compose.rememberNavController
import kotlinx.serialization.Serializable
@Composable
fun App() {
MaterialTheme {
val controller = rememberNavController()
NavHost(controller, startDestination = HomeRoute) {
composable<HomeRoute> { HomeScreen(controller) }
composable<CityRoute> { CityScreen() }
}
}
}
@Serializable
object HomeRoute
@Composable
fun HomeScreen(controller: NavController) {
Column {
Text("Home")
Button(onClick = { controller.navigate(CityRoute) }) {
Text("City")
}
}
}
@Serializable
object CityRoute
@Composable
fun CityScreen() {
Text("Barcelona")
}

Amb la funció “composable” NavHost crees un graf de navegació.

En cridar la funció “composable” NavHost passem com a paràmetres un NavController i una ruta pel destí inicial (la ruta Home).

Amb la funció composable() defineixes quin “composable” es el destí d’una “ruta”.

HomeRoute

HomeScreen

CityRoute

CityScreen

Quan defineixes una ruta mai has de dir de quin “screen” ha de venir, sinó quin “screen” ha de gestionar la “ruta”.

Note

Amb la tecla Esc pots navegar cap enrere.

Activitat

Task

Afegeix un nova pàgina CountryScreen.

Afegeix un botó aHomeScreen que et porti aCountryScreen.

Afegeix un botó aCountryScreen que et porti aCiytScreen.

Afegeix una barra de navegació(TopAppBar):

Paràmetres

Si vols passar paràmetres a un “screen” has d’utlitzar un data class enlloc d’un object.

@Serializable
data class CityRoute(val name: String)

Ara el componentHomeScreen ja pot utilitzar la nova ruta:

@Composable
fun HomeScreen(controller: NavController) {
// ...
Button(onClick = { controller.navigate(CityRoute("Girona")) }) {
Text("City")
}
// ...
}
}

ElNavHost ha de configurar la ruta passantCityRoute a CityScreen:

@Composable
fun App() {
MaterialTheme {
val controller = rememberNavController()
NavHost(controller, startDestination = HomeRoute) {
composable<HomeRoute> { HomeScreen(controller) }
composable<CityRoute> { entry -> CityScreen(controller, entry.toRoute()) }
composable<CountryRoute> { CountryScreen(controller) }
}
}
}

El componentCityScreen ha d’acceptar com a paràmetre CityRoute:

@Composable
fun CityScreen(controller: NavController, route: CityRoute) {
Column {
Nav(controller)
Text(route.name)
}
}

Ara CityScreen mostra la ciutat que li passen com a paràmetre.

Task

Afegeix unTextField aHomeScreen on l’usuari pugui posar la ciutat que vulgui i al apretar el botó passi el contingut com a paràmetre:

Crea un “screen”Countries que mostri una llista de paisos:

Afegeix un enllaç del “screen” a la barra de navegació

Fes que la llista de països sigui clicable i navegui al “screen” Country:

Fes el mateix amb un “screen” Cities.

Activitat

Pendent