Я хочу, чтобы при пролистывании вправо первый элемент исчезал, а нижняя карточка (дочерняя) появлялась сверху, по существу используя анимацию затухания и увеличения
Мой код . Похоже, код моей анимации работает неправильно
val pagerState = rememberPagerState(initialPage = 0) {
pagerCount
}
Box(modifier = modifier) {
for (i in 0 until pagerCount - 1) {
Column(
modifier = Modifier
.padding(
top = Spaces.xs2 * (pagerCount - i),
start = Spaces.xs2 * (pagerCount - i),
end = Spaces.xs2 * (pagerCount - i),
)
) {
item(i.toFloat())
if (i == 1) {
button(Spaces.xs2 * (pagerCount - i))
}
}
HorizontalPager(
modifier = modifier,
state = pagerState,
) { page ->
Box(
modifier = Modifier
.graphicsLayer {
val pageOffset = pagerState.offsetForPage(page)
val scale = 1f - abs(pageOffset) * 0.2f
scaleX = scale
scaleY = scale
alpha = 1f - abs(pageOffset)
}
) {
item(page.toFloat())
}
}
}
}
}
private fun PagerState.offsetForPage(page: Int): Float {
return this.currentPageOffsetFraction + (page - this.currentPage)
}
Подробнее здесь: https://stackoverflow.com/questions/790 ... n-horizont
У меня есть стопка карт. Как реализовать анимацию для сложенных элементов в горизонтальном пейджере? ⇐ Android
-
- Похожие темы
- Ответы
- Просмотры
- Последнее сообщение
-
-
Иметь единую серию из сложенных столбцов, которая охватывает всю ширину диаграммы
Anonymous » » в форуме Javascript - 0 Ответы
- 5 Просмотры
-
Последнее сообщение Anonymous
-