android - 在 Jetpack compose 中定义 View 权重的问题

标签 android android-jetpack-compose android-layout-weight

我想使用权重制作一个简单的喷气背包组合布局。下面是代码

Row() {
Column(
    Modifier.weight(1f).background(Blue)){
    Text(text = "Weight = 1", color = Color.White)
}
Column(
    Modifier.weight(2f).background(Yellow)
) {
    Text(text = "Weight = 2")
}
}
这将导致这样的布局
Simple row column lauout using weights.
但是,如果我的内部 View 来自其他一些可组合函数,而这些函数不知道它将成为列或行的子函数,该怎么办?
Row() {
  // Calling Some composable function here
}
在那种情况下,我无法访问 Modifier.weight(..) 函数,因为它认为它不在行或列范围内,因为它是一个独立的函数。

最佳答案

您可以在 Composable 中添加修饰符作为参数。
就像是:

@Composable
fun myCard(modifier: Modifier = Modifier, name:String){
    Box(modifier){
            Text(name,textAlign = TextAlign.Center,)
    }
}
这样myCard不知道它将成为 Column 的 child 或 Row .
然后在您的实现中,您可以使用:
Row(Modifier.padding(16.dp).height(50.dp)) {
    myCard(Modifier.weight(1f).background(Color.Yellow),"Weight = 1")
    myCard(Modifier.weight(2f).background(Color.Red),"Weight = 2")
}
enter image description here

关于android - 在 Jetpack compose 中定义 View 权重的问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/67158923/

相关文章:

android - 单击叠加层时显示 toast

android - java.lang.IllegalArgumentException : Navigation destination that matches request NavDeepLinkRequest 异常

Jetpack Compose 中的 Android 基本 TextField 对齐

android - layout_weight 与它应该做的相反

Android - ConstraintLayout 中的 ConstraintVertical 权重不起作用?

Jellybean 中的 Android SQLite 数据库事务/锁定更改

android - 我可以包含一个自动完成和跨平台(iOS/Android)的字符串文件吗?

android - 背景图像不适用于 Android、BB、Windows Phone

android - 如何在撰写中设置高度 WRAP_CONTENT?

Android weightsum 没有按预期工作