赞
踩
自学编程路线、面试题集合/面经、及系列技术文章等,资源持续更新中…
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
万事俱备,该摆放这个控件了。
使用MeasureScope.layout方法向外部报告大小,并摆放自己,这个方法会返回一个MeasureResult,正好是外部整个lambda表达式所要求的返回值。
layout(placeable.width,height) {
placeable.placeRelative(0,placeableY)
}
完整代码:
fun Modifier.firstBaselineToTop(
firstBaseLineToTop: Dp
) = this.then(
layout { measurable, constraints ->
val placeable = measurable.measure(constraints = constraints)
check(placeable[FirstBaseline] != AlignmentLine.Unspecified)
val firstBaseLine = placeable[FirstBaseline]
val placeableY = firstBaseLineToTop.roundToPx() - firstBaseLine
val height = placeable.height + placeableY
layout(placeable.width,height) {
placeable.placeRelative(0,placeableY)
}
}
)
@Preview
@Composable
fun useFirstBaselineToTop() {
Column {
Text(“Hi,there”, modifier = Modifier.firstBaselineToTop(24.dp))
}
}
@Preview
@Composable
fun usePadding() {
Column {
Text(“Hi,there”,modifier = Modifier.padding(top = 24.dp))
}
}
下面是自定义的一个简单的Column布局。因为和自定义Modifier差不多,不多说了。
@Composable
fun CustomColumn(
modifier: Modifier = Modifier,
content: @Composable () -> Unit
) {
Layout(modifier = Modifier, content = content) { measurables, constraints ->
// 测量每一个子组件
val placeables = measurables.map {
it.measure(constraints = constraints)
}
// yPos用于记录当前组件的y位置
var yPos = 0
// 向父元素报告大小,这里和父元素一样大
layout(constraints.maxWidth,constraints.maxHeight) {
// 放置每一个子元素
placeables.forEach { placeable ->
placeable.placeRelative(0,yPos)
yPos += placeable.height
}
}
}
}
总结
可以看出Jetpack Compose面向组合实现UI树相较于传统View模式的灵活性。
在这里我和身边一些朋友特意整理了一份快速进阶为Android高级工程师的系统且全面的学习资料。涵盖了Android初级——Android高级架构师进阶必备的一些学习技能。
附上:我们之前因为秋招收集的二十套一二线互联网公司Android面试真题(含BAT、小米、华为、美团、滴滴)和我自己整理Android复习笔记(包含Android基础知识点、Android扩展知识点、Android源码解析、设计模式汇总、Gradle知识点、常见算法题汇总。)
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
止,不再深入研究,那么很难做到真正的技术提升。**
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。