Я пытаюсь сделать так, чтобы при нажатии кнопки элемент исчезал, а затем появлялся. Я искал разные способы реализации, но ни один из них не работал.
Я пытался реализовать такую анимацию, отслеживая переходное состояние, но безуспешно. По какой-то причине элемент оказывается на той же стороне, в которую он переместился во время анимации выхода. Ниже мой код:
@Composable
fun Greeting() {
Row(
modifier = Modifier.fillMaxWidth(),
horizontalArrangement = Arrangement.SpaceBetween,
verticalAlignment = Alignment.CenterVertically
) {
val visibleState = remember { MutableTransitionState(initialState = true).apply { targetState = true } }
AnimatedVisibility(
visibleState = visibleState,
enter = slideInHorizontally(
animationSpec = tween(100, easing = LinearEasing),
initialOffsetX = { it }
),
exit = slideOutHorizontally (
animationSpec = tween(100, easing = LinearEasing),
targetOffsetX = { -it }
)
) {
RedBox()
}
Button {
visibleState.targetState = false
}
DisposableEffect(visibleState.currentState) {
onDispose {
visibleState.targetState = true
}
}
}
}
Подробнее здесь: https://stackoverflow.com/questions/790 ... d-if-it-is
Можно ли в AnimatedVisibility отследить окончание анимации и, если она завершена, изменить видимость вложенных компонент ⇐ Android
Форум для тех, кто программирует под Android
1728836123
Anonymous
Я пытаюсь сделать так, чтобы при нажатии кнопки элемент исчезал, а затем появлялся. Я искал разные способы реализации, но ни один из них не работал.
Я пытался реализовать такую анимацию, отслеживая переходное состояние, но безуспешно. По какой-то причине элемент оказывается на той же стороне, в которую он переместился во время анимации выхода. Ниже мой код:
@Composable
fun Greeting() {
Row(
modifier = Modifier.fillMaxWidth(),
horizontalArrangement = Arrangement.SpaceBetween,
verticalAlignment = Alignment.CenterVertically
) {
val visibleState = remember { MutableTransitionState(initialState = true).apply { targetState = true } }
AnimatedVisibility(
visibleState = visibleState,
enter = slideInHorizontally(
animationSpec = tween(100, easing = LinearEasing),
initialOffsetX = { it }
),
exit = slideOutHorizontally (
animationSpec = tween(100, easing = LinearEasing),
targetOffsetX = { -it }
)
) {
RedBox()
}
Button {
visibleState.targetState = false
}
DisposableEffect(visibleState.currentState) {
onDispose {
visibleState.targetState = true
}
}
}
}
Подробнее здесь: [url]https://stackoverflow.com/questions/79077433/is-it-possible-to-track-the-end-of-animation-in-animatedvisibility-and-if-it-is[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия