Jetpack Compose Navigation: как перейти от корневого графа к определенному экрану в нижней панели?Android

Форум для тех, кто программирует под Android
Ответить Пред. темаСлед. тема
Anonymous
 Jetpack Compose Navigation: как перейти от корневого графа к определенному экрану в нижней панели?

Сообщение Anonymous »

Я создал навигационные графики для навигации внутри своего приложения для Android. Графики работают правильно, на самом деле можно перемещаться внутри моего приложения, перемещаться между элементами нижней панели и переходить к экранам с подробными сведениями.
Но при попытке я обнаружил ошибку. перейти от NavigationRoute.DetailsGraph.OverviewScreen.route к NavigationRoute.MainScreenGraph.Profile.route, который является конкретным экраном нижней панели?
Ошибка: : java.lang.IllegalArgumentException: пункт назначения навигации не найден в графе навигации.
Вместо этого, если я попытаюсь перейти из NavigationRoute.DetailsGraph.OverviewScreen.route to NavigationRoute.MainScreenGraph.route работает корректно.
Я понял, что проблема в том, что нижняя панель использует другой NavHostController, но , как я могу решить эту проблему?
Если я использую свой корневой NavHostController для нижней панели, я получаю эту ошибку: java.lang.IllegalStateException: ViewModelStore должен быть установлен перед setGraph вызов.

Под кодом.
Корневой граф навигации
fun RootNavigationGraph(navController: NavHostController) {
NavHost(
navController = navController,
startDestination = NavigationRoute.AuthenticationGraph.route,
modifier = Modifier.fillMaxSize()
) {
authNavGraph(navController = navController)
mainScreenGraph(navController = navController)
detailsNavGraph(navController = navController)
}
}

Граф главного экрана
fun NavGraphBuilder.mainScreenGraph(
navController: NavHostController
) {

navigation(
route = NavigationRoute.MainScreenGraph.route,
startDestination = NavigationRoute.MainScreenGraph.MainScreen.route
) {
composable(route = NavigationRoute.MainScreenGraph.MainScreen.route) {
HomeScreen(rootNavController = navController)
}
}
}

Главный экран с нижней панелью
@Composable
fun HomeScreen(
rootNavController: NavHostController,
navController: NavHostController = rememberNavController(),
) {
Scaffold(
bottomBar = { BottomBar(navController = navController) }
) {
NavHost(
navController = navController,
startDestination = NavigationRoute.MainScreenGraph.Home.route
) {
homeScreen(
navController = rootNavController,
)
}
}
}

График главного экрана с тремя экранами находится на моей нижней панели.
fun NavGraphBuilder.homeScreen(
navController: NavHostController,
) {
composable(route = NavigationRoute.MainScreenGraph.Home.route) {
ScreenContent(
name = BottomBarScreen.Home.route,
onClick = {
navController.navigate(NavigationRoute.DetailsGraph.route)
}
)
}
composable(route = NavigationRoute.MainScreenGraph.Profile.route) {
ScreenContent(
name = NavigationRoute.MainScreenGraph.Profile.route,
onClick = { }
)
}
composable(route = NavigationRoute.MainScreenGraph.Settings.route) {
ScreenContent(
name = NavigationRoute.MainScreenGraph.Settings.route,
onClick = { }
)
}
}

График навигации с подробными сведениями
fun NavGraphBuilder.detailsNavGraph(
navController: NavHostController,
) {
navigation(
route = NavigationRoute.DetailsGraph.route,
startDestination = NavigationRoute.DetailsGraph.InfoScreen.route
) {
composable(route = NavigationRoute.DetailsGraph.InfoScreen.route) {
ScreenContent(name = NavigationRoute.DetailsGraph.InfoScreen.route) {
navController.navigate(NavigationRoute.DetailsGraph.OverviewScreen.route)
}
}
composable(route = NavigationRoute.DetailsGraph.OverviewScreen.route) {
ScreenContent(name = NavigationRoute.DetailsGraph.OverviewScreen.route) {
// THIS NOT WORK
navController.navigate(NavigationRoute.MainScreenGraph.Profile.route)

// THIS WORK
navController.navigate(NavigationRoute.MainScreenGraph.route)
}
}
}
}


Подробнее здесь: https://stackoverflow.com/questions/761 ... cific-scre
Реклама
Ответить Пред. темаСлед. тема

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение

Вернуться в «Android»