Как правильно обрабатывать глубокие ссылки с несколькими NavHosts?
В моем приложении есть два NavHosts. Первый — рут, а второй — для HomeScreen. Глубокие ссылки работают правильно, когда я добавляю их на экран в корневом каталоге NavHost. Однако они не работают, когда я добавляю их на экран, содержащийся в HomeScreen NavHost. Причина, по которой у меня два NavHost, конечно же, связана с нижней панелью на главном экране. Стоит отметить, что оба экрана, которые должны обрабатывать глубокие ссылки, имеют один и тот же базовый путь, но модели маршрутов разные. Ниже я привел пример кода, иллюстрирующий проблему.
@AndroidEntryPoint
class MainActivity : ComponentActivity() {
@Inject
lateinit var mainViewModel: MainViewModel
@ExperimentalAnimationApi
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
installSplashScreen().apply {
setKeepOnScreenCondition {
mainViewModel.state.isLoading
}
}
enableEdgeToEdge()
setContent {
MyTheme {
val navController = rememberNavController()
Surface(
modifier = Modifier.fillMaxSize()
) {
if (mainViewModel.state.startDestination != null) {
RootNavGraph(
navController = navController,
startDestination = mainViewModel.state.startDestination!!
)
}
}
}
}
}
}
@ExperimentalAnimationApi
@Composable
fun RootNavGraph(
navController: NavHostController,
startDestination: Any
) {
NavHost(
navController = navController,
startDestination = startDestination
) {
authNavGraph(navController = navController)
composable {
HomeScreen(rootNavController = navController)
}
composable(
deepLinks = listOf(
navDeepLink(
basePath = "${BuildConfig.BASE_URL}something"
)
)
) {
ScreenX(onNavigateUp = navController::navigateUp)
}
}
}
@Serializable
data class ScreenXRoute(val id: Long)
@Composable
fun HomeScreen(
rootNavController: NavHostController,
navController: NavHostController = rememberNavController(),
viewModel: HomeViewModel = hiltViewModel()
) {
val navBackStackEntry by navController.currentBackStackEntryAsState()
val currentDestination = navBackStackEntry?.destination
HomeScreenUi(
currentDestination = currentDestination,
onNavigate = { route ->
navController.navigate(route) {
popUpTo(navController.graph.findStartDestination().id) {
saveState = true
}
launchSingleTop = true
restoreState = true
}
}) { paddingValues ->
MainNavGraph(
navController = navController,
rootNavController = rootNavController,
homeScreenBottomPadding = paddingValues
)
}
}
@Composable
fun MainNavGraph(
navController: NavHostController,
rootNavController: NavHostController,
homeScreenBottomPadding: PaddingValues
) {
NavHost(
navController = navController,
startDestination = VeryCoolGraph
) {
profileNavGraph(navController = navController, homeScreenBottomPadding = homeScreenBottomPadding)
veryCoolGraph(rootNavHostController = rootNavController, navController = navController, homeScreenBottomPadding = homeScreenBottomPadding)
}
}
fun NavGraphBuilder.veryCoolGraph(
rootNavHostController: NavHostController,
navController: NavHostController,
homeScreenBottomPadding: PaddingValues
) {
navigation(
startDestination = Screen1Route()
) {
composable(
enterTransition = { EnterTransition.None },
exitTransition = { ExitTransition.None },
deepLinks = listOf(
navDeepLink(
basePath = "${BuildConfig.BASE_URL}something"
)
)) {
val screen1ViewModel = it.sharedViewModel(navController = navController)
Screen1(
viewModel = screen1ViewModel,
homeScreenBottomPadding = homeScreenBottomPadding
)
}
composable {
val viewModel =
it.sharedViewModel(navController = navController)
Screen2(
viewModel = viewModel,
onNavigateUp = navController::navigateUp
)
}
}
}
@Serializable
data class Screen1Route(
val page: Int? = null,
val additionalInformation: String? = null,
val price: String? = null
)
Подробнее здесь: https://stackoverflow.com/questions/791 ... e-navhosts
Jetpack Compose — обработка глубоких ссылок с несколькими NavHosts ⇐ Android
Форум для тех, кто программирует под Android
-
Anonymous
1730135528
Anonymous
Как правильно обрабатывать глубокие ссылки с несколькими NavHosts?
В моем приложении есть два NavHosts. Первый — рут, а второй — для HomeScreen. Глубокие ссылки работают правильно, когда я добавляю их на экран в корневом каталоге NavHost. Однако они не работают, когда я добавляю их на экран, содержащийся в HomeScreen NavHost. Причина, по которой у меня два NavHost, конечно же, связана с нижней панелью на главном экране. Стоит отметить, что оба экрана, которые должны обрабатывать глубокие ссылки, имеют один и тот же базовый путь, но модели маршрутов разные. Ниже я привел пример кода, иллюстрирующий проблему.
@AndroidEntryPoint
class MainActivity : ComponentActivity() {
@Inject
lateinit var mainViewModel: MainViewModel
@ExperimentalAnimationApi
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
installSplashScreen().apply {
setKeepOnScreenCondition {
mainViewModel.state.isLoading
}
}
enableEdgeToEdge()
setContent {
MyTheme {
val navController = rememberNavController()
Surface(
modifier = Modifier.fillMaxSize()
) {
if (mainViewModel.state.startDestination != null) {
RootNavGraph(
navController = navController,
startDestination = mainViewModel.state.startDestination!!
)
}
}
}
}
}
}
@ExperimentalAnimationApi
@Composable
fun RootNavGraph(
navController: NavHostController,
startDestination: Any
) {
NavHost(
navController = navController,
startDestination = startDestination
) {
authNavGraph(navController = navController)
composable {
HomeScreen(rootNavController = navController)
}
composable(
deepLinks = listOf(
navDeepLink(
basePath = "${BuildConfig.BASE_URL}something"
)
)
) {
ScreenX(onNavigateUp = navController::navigateUp)
}
}
}
@Serializable
data class ScreenXRoute(val id: Long)
@Composable
fun HomeScreen(
rootNavController: NavHostController,
navController: NavHostController = rememberNavController(),
viewModel: HomeViewModel = hiltViewModel()
) {
val navBackStackEntry by navController.currentBackStackEntryAsState()
val currentDestination = navBackStackEntry?.destination
HomeScreenUi(
currentDestination = currentDestination,
onNavigate = { route ->
navController.navigate(route) {
popUpTo(navController.graph.findStartDestination().id) {
saveState = true
}
launchSingleTop = true
restoreState = true
}
}) { paddingValues ->
MainNavGraph(
navController = navController,
rootNavController = rootNavController,
homeScreenBottomPadding = paddingValues
)
}
}
@Composable
fun MainNavGraph(
navController: NavHostController,
rootNavController: NavHostController,
homeScreenBottomPadding: PaddingValues
) {
NavHost(
navController = navController,
startDestination = VeryCoolGraph
) {
profileNavGraph(navController = navController, homeScreenBottomPadding = homeScreenBottomPadding)
veryCoolGraph(rootNavHostController = rootNavController, navController = navController, homeScreenBottomPadding = homeScreenBottomPadding)
}
}
fun NavGraphBuilder.veryCoolGraph(
rootNavHostController: NavHostController,
navController: NavHostController,
homeScreenBottomPadding: PaddingValues
) {
navigation(
startDestination = Screen1Route()
) {
composable(
enterTransition = { EnterTransition.None },
exitTransition = { ExitTransition.None },
deepLinks = listOf(
navDeepLink(
basePath = "${BuildConfig.BASE_URL}something"
)
)) {
val screen1ViewModel = it.sharedViewModel(navController = navController)
Screen1(
viewModel = screen1ViewModel,
homeScreenBottomPadding = homeScreenBottomPadding
)
}
composable {
val viewModel =
it.sharedViewModel(navController = navController)
Screen2(
viewModel = viewModel,
onNavigateUp = navController::navigateUp
)
}
}
}
@Serializable
data class Screen1Route(
val page: Int? = null,
val additionalInformation: String? = null,
val price: String? = null
)
Подробнее здесь: [url]https://stackoverflow.com/questions/79134445/jetpack-compose-handling-deep-links-with-multiple-navhosts[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия