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()) }
)
}
}
}
}
}
}
< /code>
потоки реализованы в ViewModel таким образом: < /p>
    @OptIn(ExperimentalCoroutinesApi::class)
val row1Items: StateFlow = query
.flatMapLatest { queryParams ->
myDao.getItemsFlow(queryParams.query)
}
.map { list ->
sortedItems(list)
}
.stateIn(
scope = viewModelScope,
started = SharingStarted.WhileSubscribed(5.seconds),
initialValue = emptyList(),
)
По сути, есть класс данных запроса, который при изменении вызывает метод запроса DAO и сортирует результаты этого запроса DAO, прежде чем излучать сортированный список в поток.

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

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

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

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

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

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