【问题标题】:Text layout priority in Jetpack ComposeJetpack Compose 中的文本布局优先级
【发布时间】:2021-07-09 16:51:42
【问题描述】:

我连续有两个文本:

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))
    )
}

第一个可能很长。发生这种情况时,第二个文本会被压缩并从视图中消失。

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

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

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

【问题讨论】:

  • 我需要第二个在左边是什么意思?
  • 我的意思是在右边,修正了错字。第一个文本应该对齐到开始,第二个文本应该对齐到结束

标签: android android-jetpack-compose android-jetpack-compose-text


【解决方案1】:

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

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))
    )
}

【讨论】:

  • 现在看起来是正确的,我仍然对没有权重修饰符无法使文本不贪婪这一事实感到困惑,这意味着我不能在行内多次使用它(不做大小相互依赖)是的,我可以在带有填充的文本之间设置最小间距,但我发现 Spacer 是这样做的首选方式,在这种情况下我不能为其分配权重修饰符..
【解决方案2】:

您可以尝试防止 Text 可组合填充整个宽度。

比如你可以说

Text(text = "Lorem...", modifier = Modifier.fillMaxWidth(0.75f))

这将使文本填满其最大宽度,但为第二个文本留出 25% 的剩余空间。当然,您可以将 0.75f 更改为您认为适合您的用例的任何值。

【讨论】:

  • 如果我确定第二个文本不会占用超过 25% 的空间,这可能会起作用,但我希望它占用它需要的所有空间,然后第一个标签布局开始计算
猜你喜欢
  • 2014-10-04
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2021-10-14
  • 2021-04-15
  • 2021-07-22
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多