отобразить на экране изменяющийся текст. Особенность в том, что когда текст становится пустым, он с анимацией должен исчезть, а когда снова станет не пустым, с анимацией появиться.
Пробую сделать просто через AnimatedVisibility (картинка 1), но в таком случае, анимации исчезания не видно, т.к. исчезает пустая строка.
Тогда я пытаюсь закешировать последний не пустой текст (картинка 2). Всё работает как надо, но MutableState тут избыточен
Заменяю на самописную обёртку - делегат, которая не вызывает рекомпозиии при изменении (картинка 3) Но начинает выглядеть весьма громоздко.
Как можно более изящно данную задачу решить?
1. .animateContentSize() 2. Сделать ширину через animateDpAsState, а просчитывать ширину через Paragraph() (в таком случае можно просчитывать ширину следующего текста, показать анимацию, и с задержкой показать новый текст)
Проблема не в анимации размера между текстами, проблема в том, что если я анимирую скрытие текста, когда он становится пустым, то отображается анимация не последнего непустого текста, а текст переключается на пустой, а потом запускается анимация, которую не видно, из-за того, что анимируется пустой текст
А если использовать задержку перед передачей нового текста
Уж лучше тогда моим способом, менее костыльно
AnimatedContent не пробовали?
Я задержку с длиной одинаковой длине анимации не назвал бы костылем, не знаю
Он идеально подошёл бы, если бы я хотел бы анимаровать и между текстами тоже. А так я хочу анимировать только появление и исчезание текста
В таком случае мне придётся заботится о том, что бы эти длительности были бы всегда одинаковыми, к тому же задержку нужно будет ставить только перед пустым значением. Да и вообще задержки, это асинхронность, работа с корутинами или Flow, чего бы я не хотел делать внутри композа
animatedContent попробуйте. а внутри контента условие if (needShow) { Text() } else { Box() }
Может попробовать что-нибудь в духе updateTransition(text).AnimatedVisibility({it.isNotEmpty()}) { Text(targetState) } ?
Спасибо, попробую, с этими штуками ещё не работал
Обсуждают сегодня