Android, Jetpack Compose Изменить ориентацию контентаAndroid

Форум для тех, кто программирует под Android
Ответить Пред. темаСлед. тема
Anonymous
 Android, Jetpack Compose Изменить ориентацию контента

Сообщение Anonymous »

Ссылка для предварительного просмотра: «Для отображения изображения в публикации необходимо 10 репутаций»
https://i.sstatic.net/p0vA4Mfg.jpg
Привет!
Я работаю над макетом из трех столбцов и хочу повернуть содержимое одного из столбцов на 90 градусов.
Я пробовал поменять местами ширину и высоту и настроить размещение содержимое, но безуспешно.
Вот проблема: когда поле, которое я хочу повернуть, занимает 50% ширины экрана, оно работает как положено. Однако, если размер поля больше или меньше 50 %, я сталкиваюсь с пробелом внизу.
Может ли кто-нибудь предложить решение, позволяющее гарантировать, что повернутый контент заполнит доступное пространство, не создавая пробела? ?
Спасибо!
Вот мой полный файл:
fun Layout() {
Row(
modifier = Modifier
.fillMaxSize()
.background(Color.Red)
) {
Row(
modifier = Modifier
.fillMaxSize()
) {
Box(
modifier = Modifier
.weight(1f)
.fillMaxSize()
.rotate(90f)
.swapDimensions()
.background(Color.Blue)
.background(Color.LightGray)
) {

Column(
modifier = Modifier
) {
Column(modifier = Modifier.background(Color.Magenta).fillMaxWidth()) {
Text(text = "All content in this box has to be rotated 90deg")
}
Column(modifier = Modifier.background(Color.LightGray)) {
Text(text = "Text 2")
}
}
}
Column(
modifier = Modifier
.weight(1f)
.fillMaxSize()
) {
Box(
modifier = Modifier
.weight(1f)
.fillMaxSize()
.background(Color.Green)
) {
Text(text = "This content is normal")
}
Box(
modifier = Modifier
.weight(1f)
.fillMaxSize()
.background(Color.Yellow)
) {
Text(text = "This content is normal")
}
}
Column(
modifier = Modifier
.weight(1f)
.fillMaxSize()
) {
Box(
modifier = Modifier
.weight(1f)
.fillMaxSize()
.background(Color.Magenta)
) {
Text(text = "This content is normal")
}
Box(
modifier = Modifier
.weight(1f)
.fillMaxSize()
.background(Color.Blue)
) {
Text(text = "This content is normal")
}
}
}
}
}
fun Modifier.swapDimensions() = layout { measurable, constraints ->
val placeable = measurable.measure(constraints)

val originalWidth = placeable.width
val originalHeight = placeable.height

val swappedWidth = originalHeight
val swappedHeight = originalWidth

layout(
swappedWidth,
swappedHeight
) {
placeable.place(
x = (swappedWidth - originalHeight) / 2,
y = (swappedHeight - originalWidth) / 2
)
}
}
@Preview(
name = "Landscape Preview",
device = "spec:width=800dp, height=400dp",
showBackground = true
)
@Composable
fun PreviewLayout() {
Layout()
} ```



Подробнее здесь: https://stackoverflow.com/questions/793 ... of-content
Реклама
Ответить Пред. темаСлед. тема

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

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

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

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

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение

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