Android ConstraintLayout约束布局使用实例介绍

 更新时间:2022年10月10日 09:18:43   作者:知奕奕  
ConstraintLayout是Google在Google I/O 2016大会上发布的一种新的布局容器(ViewGroup),它支持以灵活的方式来放置子控件和调整子控件的大小,下面这篇文章主要给大家介绍了关于Android中ConstraintLayout约束布局详细解析的相关资料,需要的朋友可以参考下

基本结构

约束结构原理:将一个组件与约束布局关联后,通过 modifier 来指定组件位置

导入 compose 约束布局包

打开 build.gradle(:app) 文件

在依赖中添加以下这一行,之后点击顶部的 sync now 进行 gradle 配置

androidx.constraintlayout:constraintlayout-compose:1.0.1

约束布局使用步骤 

  1. ConstraintLayout 定义一个约束布局
  2. val (button, text) = createRefs() 所有需要和约束布局相关联的组件都必须要在这里进行注册!如果仅注册一个组件,那就用 createRef,多个组件就用上面那样子(这一段代码使用了 kotlin 的解构赋值)
  3. Modifier.constrainAs(button) 在组件的 modifier 中将自身与约束布局相关联!
  4. top.linkTo 最后用这办法在约束布局里面定位组件
@Composable
fun ConstraintLayoutContent() {
    ConstraintLayout() {
        val (button, text) = createRefs()
        Button(
            onClick = { /*TODO*/ },
            modifier = Modifier.constrainAs(button) {
                top.linkTo(parent.top, margin = 16.dp)
            }
        ) {
            Text(text = "btn")
        }
    }
}

继续约束

紧接着上面的代码,我们指定一个 text 跟在 button 的下面

@Composable
fun ConstraintLayoutContent() {
    ConstraintLayout() {
        ...
        Text(text = "nullclear", modifier = Modifier.constrainAs(text) {
            // 直接拿button作为参照点进行布局
            top.linkTo(button.bottom, margin = 16.dp)
            // 水平约束对齐父类
            centerHorizontallyTo(parent)
        })
    }
}

参考线

渲染结果

createGuidelineFromStart 从最左侧开始一定距离后构造一个垂直参考线

fraction = 0.5f 距离(左侧的)长度,0.5f 恰好是屏幕的一半长

linkTo 在这里面设置约束的左侧(start)和右侧(end)

Dimension.preferredWrapContent 让文本自动换行,不破坏结构

如果我们不加上 width 这一行的话,文本会冲破 guideline 的左侧限制而超出!

@Composable
fun ConstraintLayoutContent2() {
    ConstraintLayout {
        val text = createRef()
        val guideline = createGuidelineFromStart(fraction = 0.5f)
        Text(text = "helloworld ansd htiwhiqeusadjasdl d joi hdaslh dqlwh as qwe", modifier = Modifier.constrainAs(text) {
            linkTo(start = guideline, end = parent.end)
            width = Dimension.preferredWrapContent
        })
    }
}

约束解耦

直接拿上面写好的代码解耦了

约束集合

ConstraintSet 设置一个约束集合,在里面提前设置好各个组件的约束条件!

下方代码分别设置了两个组件 button 和 text 的约束条件;

private fun decoupleConstraints(margin: Dp): ConstraintSet {
    return ConstraintSet {
        val button = createRefFor("button")
        val text = createRefFor("text")
        constrain(button) {
            top.linkTo(parent.top, margin)
        }
        constrain(text) {
            top.linkTo(button.bottom, margin)
        }
    }
}

解耦调用

按照原版的写法,我们需要在 constraintlayout 中写明约束条件,但由于我们把约束条件写在了外部,那么直接调用即可

Modifier.layoutId 直接根据于约束集合中定义的名称来应用指定的约束条件;

@Composable
fun DecoupleConstraintsLayout() {
    BoxWithConstraints {
        // 响应式布局
        val constraints = if (maxWidth < maxHeight) {
            decoupleConstraints(16.dp)
        } else {
            decoupleConstraints(160.dp)
        }
        // 把响应式布局的if判断作为参数传入,约束布局即可按照对应法则布置组件
        ConstraintLayout(constraints) {
            // layoutId对应我们在约束集合中配置的名称!
            Button(onClick = { /*TODO*/ }, modifier = Modifier.layoutId("button")) {
                Text(text = "button")
            }
            Text(text = "text", modifier = Modifier.layoutId("text"))
        }
    }
}

到此这篇关于Android ConstraintLayout约束布局使用实例介绍的文章就介绍到这了,更多相关Android ConstraintLayout内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • android实现多线程下载文件(支持暂停、取消、断点续传)

    android实现多线程下载文件(支持暂停、取消、断点续传)

    本篇文章主要介绍了androids实现多线程下载文件,主要包括暂停、取消、断点续传等功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下。
    2017-02-02
  • Phonegap使用拍照功能时的内存问题

    Phonegap使用拍照功能时的内存问题

    最近几天在学习使用phonegap进行android应用的开发,网上的资料比较乱,个人参考了很多资料,也试验了很多次,一直在摸索,总算小有心得,这此过程中也遇到了一些问题,这里给大家分享下解决Phonegap使用拍照功能时的内存问题的方法,这里简单的整理一下
    2015-05-05
  • Android中实现ProgressBar菊花旋转进度条的动画效果

    Android中实现ProgressBar菊花旋转进度条的动画效果

    大家在一些页面经常会遇到加载中需要显示一个加载动画,像旋转的菊花旋转的圈圈动画效果,本文通过实例代码给大家讲解下,需要的朋友参考下吧
    2021-09-09
  • Android系统在shell中的df命令实现

    Android系统在shell中的df命令实现

    今天小编就为大家分享一篇关于Android系统在shell中的df命令实现,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2018-12-12
  • Android ListView滚动到指定的位置

    Android ListView滚动到指定的位置

    这篇文章主要给大家介绍了Android中的ListView如何滚动到指定的位置,文章给出了两种解决的方法,并给出详细的示例代码,相信会对大家的理解和学习很有帮助,有需要的朋友们下面来一起看看吧。
    2016-10-10
  • Android实现从底部弹出的Dialog的实例代码

    Android实现从底部弹出的Dialog的实例代码

    这篇文章主要介绍了Android实现从底部弹出的Dialog的实例代码,非常不错,具有参考借鉴价值 ,需要的朋友可以参考下
    2018-04-04
  • Android为按钮控件绑定事件的五种实现方式

    Android为按钮控件绑定事件的五种实现方式

    本篇文章主要是介绍了Android为按钮控件绑定事件的五种实现方式,具有一定的参考价值,感兴趣的小伙伴们可以参考一下。
    2016-11-11
  • Apache Cordova Android原理应用实例详解

    Apache Cordova Android原理应用实例详解

    这篇文章主要为大家介绍了Apache Cordova Android原理应用实例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-11-11
  • Android 退出多Activity的application的方式方法

    Android 退出多Activity的application的方式方法

    在开发过程中,我们常常需要一个退出功能,来退出该应用的所有Activity,本篇文章主要介绍了Android 退出多Activity的application的方式,有兴趣的可以了解一下。
    2017-02-02
  • Android浅析viewBinding和DataBinding

    Android浅析viewBinding和DataBinding

    这篇文章主要介绍了Android浅析viewBinding和DataBinding,文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下
    2022-09-09

最新评论