Lazycolumn Потеряя позиция свитка после перемещения вперед и отброситься назадAndroid

Форум для тех, кто программирует под Android
Ответить
Anonymous
 Lazycolumn Потеряя позиция свитка после перемещения вперед и отброситься назад

Сообщение Anonymous »

У меня есть композитный композит myview , который состоит из столбца , в котором находится Lazycolumn , который содержит некоторые строки заголовков, контент -строки и некоторые лазироузы, которые также прокручивают горизонтально. Когда я перемещаюсь вперед с этого с помощью NavController.navigate (route) , а затем возвращаюсь, используя NavController.popbackStack () Состояние прокрутки лазиколона не сохраняется, и это всегда расположено вверх. ViewModel не воссоздается, потоки, которые заполняют Lazyrows, не излучают новые значения, а лазироузы сохраняют свое горизонтальное положение прокрутки. Я использую ту же навигацию в другом месте в приложении, и все остальные лазиколомы сохраняют свои позиции прокрутки через навигацию без проблем.@Composable
fun MyView(
viewModel: MyViewModel,
onNavigateToNext: (String) -> Unit,
) {
val introItems by viewModel.introItems.collectAsStateWithLifecycle(emptyList())
val row1items by viewModel.row1items.collectAsStateWithLifecycle(emptyList())
val row2items by viewModel.row2items.collectAsStateWithLifecycle(emptyList())
val row3items by viewModel.row3items.collectAsStateWithLifecycle(emptyList())
val row4items by viewModel.row4items.collectAsStateWithLifecycle(emptyList())
val listState = rememberLazyListState()

Column(
modifier = Modifier.fillMaxSize()
) {
LazyColumn(
state = listState,
contentPadding = PaddingValues(bottom = 8.dp),
verticalArrangement = Arrangement.spacedBy(8.dp),
modifier = Modifier
.padding(horizontal = 8.dp)
.windowInsetsPadding(WindowInsets.ime)
) {
item(key = "header1") {
Text("header1", modifier = Modifier.height(80.dp))
}
items(introItems, key = {it.itemID}) { listItem ->
Text(listItem.name, modifier = Modifier.height(80.dp))
}
item(key = "header2") {
Text("header2", modifier = Modifier.height(80.dp))
}
item(key = "lazyrow1") {
LazyRow {
items(row1items) { listItem ->
Text(listItem.name, modifier = Modifier.height(150.dp))
}
}
}
item(key = "header3") {
Text("header3", modifier = Modifier.height(80.dp))

}
item(key = "lazyrow2") {
LazyRow {
items(row2items) { listItem ->
Text(listItem.name, modifier = Modifier.height(150.dp))
}
}
}
item(key = "header4") {
Text("header4", modifier = Modifier.height(80.dp))
}
item(key = "lazyrow3") {
LazyRow {
items(row3items) { listItem ->
Text(listItem.name, modifier = Modifier.height(150.dp))
}
}
}
item(key = "header5") {
Text("header5", modifier = Modifier.height(80.dp))
}
item(key = "lazyrow4") {
LazyRow {
items(row4items) { listItem ->
Text(
listItem.name,
modifier = Modifier
.height(150.dp)
.clickable { onNavigateToNext(listItem.itemID.toString()) }
)
}
}
}
}
}
}


Подробнее здесь: https://stackoverflow.com/questions/797 ... pping-back
Ответить

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

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

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

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

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