Состав реактивного ранца. Как создать свертывающуюся компоновку?Android

Форум для тех, кто программирует под Android
Ответить
Anonymous
 Состав реактивного ранца. Как создать свертывающуюся компоновку?

Сообщение Anonymous »

Мне нужно реализовать частично свернутый макет в Jetpack Compose. Когда я прокручиваю список вниз, я хочу, чтобы верхний макет частично сворачивался, а когда я прокручиваю список вверху, я хочу, чтобы расширенный макет снова отображался. Поведение похоже на свертывание панели инструментов, но мне не нужна сворачивающаяся панель инструментов, мне нужен сворачивающийся пользовательский составной объект.
[img]https:// i.sstatic.net/fzmVJY56.png[/img]

За основу я взял следующее решение: https://github.com/germainkevinbusiness ... ree/master
Вот мой код:

Код: Выделить всё

@Composable
private fun CollapsingLayout(
modifier: Modifier,
collapsedContent: @Composable (Modifier) -> Unit,
expandedContent: @Composable (Modifier) -> Unit,
scrollBehavior: CollapsingTopBarScrollBehavior,
) = with(scrollBehavior) {

Surface(
modifier = modifier
.fillMaxWidth()
.height(currentTopBarHeight)
.verticalScroll(topBarVerticalScrollState.invoke()),
color = Color.Unspecified,
contentColor = Color.Unspecified,
elevation = 0.dp,
) {
Box {

// Display expanded content
expandedContent(Modifier
.alpha(expandedColumnAlpha.invoke().value)
.fillMaxWidth()
.height(currentTopBarHeight))

// Collapsed content with AnimatedVisibility for smooth transition
AnimatedVisibility(
visible = collapsedTitleAlpha.invoke().value in 0F..1F,
enter = fadeIn(initialAlpha = collapsedTitleAlpha.invoke().value),
exit = fadeOut()
) {
collapsedContent(
Modifier
.fillMaxWidth()
.height(scrollBehavior.collapsedTopBarHeight)
.align(Alignment.BottomStart),
)
}
}
}
}
Проблема в том, что этому коду необходимо заранее знать высоту развернутого и свернутого содержимого, но я не могу установить эту высоту заранее, поскольку высота развернутого блока может быть динамической. Так что я в замешательстве. Помогите пожалуйста решить эту проблему.
P.S. частично свернутый составной объект должен оставаться фиксированным вверху и не прокручиваться по списку.

Подробнее здесь: https://stackoverflow.com/questions/791 ... composable
Ответить

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

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

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

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

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