JJ1*_*123 5 android android-jetpack-compose
androidx.compose.ui.layout.SubcomposeLayout.kt我在 的源代码中看到了这个函数androidx.compose.ui:ui:1.0.0-beta02。
private fun createMeasurePolicy(
block: SubcomposeMeasureScope.(Constraints) -> MeasureResult
): MeasurePolicy = object : LayoutNode.NoIntrinsicsMeasurePolicy(
error = "Intrinsic measurements are not currently supported by SubcomposeLayout"
) {
...
}
Run Code Online (Sandbox Code Playgroud)
当可组合项在子可组合项中呈现时,我似乎无法使用内部测量。
作为参考,我尝试在 ModalBottomSheet 中使用这样的视图。目的是在工作表中拥有可滚动视图,并且粘性视图始终位于底部(如按钮)。我希望可滚动内容仅占用所需的空间,并且在工作表展开状态下并不总是全屏,但事实确实如此weight(1f)。
Column(
modifier = Modifier
.height(IntrinsicSize.Min)
.wrapContentHeight(Alignment.Bottom),
verticalArrangement = Arrangement.Bottom
) {
Column(
content = sheetContent,
modifier = Modifier
.weight(1f)
.wrapContentHeight(Alignment.Bottom)
)
Box {
bottomStickyContent?.let { it() }
}
}
Run Code Online (Sandbox Code Playgroud)
听起来答案是否定的,SubcomposeLayout即使有的话,也不会很快获得 Intrinsic 支持。
我通过代码更新以使用约束布局解决了这个问题。
ConstraintLayout {
val (sticky, column) = createRefs()
Column(
content = sheetContent,
modifier = Modifier
.constrainAs(column) {
top.linkTo(parent.top)
bottom.linkTo(sticky.top)
height = Dimension.preferredWrapContent
}
.wrapContentHeight(Alignment.Bottom)
)
Box(
modifier = Modifier
.constrainAs(sticky) {
bottom.linkTo(parent.bottom)
}
) {
bottomStickyContent?.let { it() }
}
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
4966 次 |
| 最近记录: |