在 Jetpack compose 中定义视图权重时出现问题

Bha*_*mar 7 android android-layout-weight android-jetpack-compose

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

Row() {
Column(
    Modifier.weight(1f).background(Blue)){
    Text(text = "Weight = 1", color = Color.White)
}
Column(
    Modifier.weight(2f).background(Yellow)
) {
    Text(text = "Weight = 2")
}
}
Run Code Online (Sandbox Code Playgroud)

这将导致这样的布局 使用权重的简单行列布局。

但是如果我的内部视图来自其他一些可组合函数,而该函数不知道它将成为列或行的子级,该怎么办?

Row() {
  // Calling Some composable function here
}
Run Code Online (Sandbox Code Playgroud)

在这种情况下,我无法访问 Modifier.weight(..) 函数,因为它认为它不在行或列范围内,因为它是一个独立的函数。

Jar*_*ich 8

您可以在函数声明前添加RowScope.or前缀ColumnScope.

@Composable
fun RowScope.SomeComposable() {
    // weights should work in here
    Column(Modifier.weight(1f)){ /**/ }

}
Run Code Online (Sandbox Code Playgroud)


Gab*_*tti 6

您可以将修饰符添加为可组合项中的参数。

就像是:

@Composable
fun myCard(modifier: Modifier = Modifier, name:String){
    Box(modifier){
            Text(name,textAlign = TextAlign.Center,)
    }
}
Run Code Online (Sandbox Code Playgroud)

通过这种方式,它myCard不知道它将成为一个Column或一个的孩子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")
}
Run Code Online (Sandbox Code Playgroud)

在此输入图像描述