gpt4 book ai didi

android - Jetpack Compose 中的文本布局优先级

转载 作者:行者123 更新时间:2023-12-04 23:55:59 24 4
gpt4 key购买 nike

我有两条连续的文本:

Row {
Text(
"Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.",
maxLines = 1,
style = MaterialTheme.typography.h4,
modifier = Modifier
.background(Color.Cyan)
)
Spacer(
modifier = Modifier
.weight(1f)
.requiredWidthIn(min = 10.dp)
)
Text(
"Second",
style = MaterialTheme.typography.h5,
modifier = Modifier
.requiredWidth(IntrinsicSize.Min)
.background(Color.Yellow.copy(alpha = 0.5f))
)
}

第一个可能很长。当它发生时,第二个文本被压缩并从 View 中消失。

requiredWidth(IntrinsicSize.Min) 将其恢复,但第一个文本仍占用所有可用宽度并位于第二个文本下方。

enter image description here

当第一个文本很小时,我需要第二个文本在右边,这就是我在它们之间使用间隔符的原因。

如何添加一些布局优先级来修复它?

最佳答案

您可以在Row中添加Arrangement.SpaceBetween并将修饰符weight(1f, fill= false)添加到第一个文本:

Row(horizontalArrangement = Arrangement.SpaceBetween,
modifier = Modifier.fillMaxWidth()) {
Text(
"Lorem ....",
maxLines = 1,
style = MaterialTheme.typography.h4,
modifier = Modifier
.background(Color.Cyan)
.weight(1f, fill= false)
)
Text(
"Second",
style = MaterialTheme.typography.h5,
modifier = Modifier
.background(Color.Yellow.copy(alpha = 0.5f))
)
}

enter image description here enter image description here

关于android - Jetpack Compose 中的文本布局优先级,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/68320333/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com