在 Jetpack Compose 中定义视图权重的问题
Issue with defining weight to views in Jetpack compose
我想制作一个简单的 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")
}
}
这将导致这样的布局
但是,如果我的内部视图来自某个其他 Composable 函数,而该函数不知道它将成为列或行的子项怎么办?
Row() {
// Calling Some composable function here
}
在那种情况下,我无法访问 Modifier.weight(..) 函数,因为它认为它不在行或列范围内,因为它是一个独立的函数。
您可以将修饰符作为参数添加到您的可组合项中。
类似于:
@Composable
fun myCard(modifier: Modifier = Modifier, name:String){
Box(modifier){
Text(name,textAlign = TextAlign.Center,)
}
}
这样 myCard
就不知道它会成为 Column
或 Row
的 child。
那么在你的实现中你可以使用:
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")
}
您可以在函数声明前加上 RowScope.
或 ColumnScope.
前缀
@Composable
fun RowScope.SomeComposable() {
// weights should work in here
Column(Modifier.weight(1f)){ /**/ }
}
我想制作一个简单的 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")
}
}
这将导致这样的布局
但是,如果我的内部视图来自某个其他 Composable 函数,而该函数不知道它将成为列或行的子项怎么办?
Row() {
// Calling Some composable function here
}
在那种情况下,我无法访问 Modifier.weight(..) 函数,因为它认为它不在行或列范围内,因为它是一个独立的函数。
您可以将修饰符作为参数添加到您的可组合项中。
类似于:
@Composable
fun myCard(modifier: Modifier = Modifier, name:String){
Box(modifier){
Text(name,textAlign = TextAlign.Center,)
}
}
这样 myCard
就不知道它会成为 Column
或 Row
的 child。
那么在你的实现中你可以使用:
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")
}
您可以在函数声明前加上 RowScope.
或 ColumnScope.
前缀
@Composable
fun RowScope.SomeComposable() {
// weights should work in here
Column(Modifier.weight(1f)){ /**/ }
}