前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >ConstraintLayout优势在哪

ConstraintLayout优势在哪

原创
作者头像
allanlin
发布于 2020-08-21 13:49:34
发布于 2020-08-21 13:49:34
3.3K00
代码可运行
举报
文章被收录于专栏:Android开发之路Android开发之路
运行总次数:0
代码可运行

| 导语 ConstraintLayout是Android Jetpack里引入的全新布局类,可以理解为RelativeLayout+LinearLayout的混合强化版,同时新版Android Studio的布局编辑器也提供了对ConstraintLayout完善的编辑支持。使用ConstraintLayout,可以很方便地在一个层级上实现复杂的布局,功能也很完善,是Android官方目前非常重视的一个Layout(替代以前的RelativeLayout),因此ConstraintLayout值得来探究一番。

一. ConstraintLayout简介

ConstraintLayout是Google IO 2016引入的一个全新布局Layout,隶属于Jetpack项目(即包含在androidx包里),目前release最新版本是1.1.3,在build.gradle里添加依赖即可,如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
implementation 'androidx.constraintlayout:constraintlayout:1.1.3'

关于ConstraintLayout的详细用法,可以参考网上的资料和Android官方文档(https://developer.android.google.cn/training/constraint-layout),对着文档操作一番,很容易就上手了。

本篇主要想介绍ConstraintLayout几个强大并且RelativeLayout缺乏的特性,感兴趣的话请往下看。

二. ConstraintLayout新特性

1. Constraint(约束)

Constraint即约束,即对一个View的Left(Start),Top,Right(End),Bottom四个方向添加Constraint条件后,此View的位置也就确定下来了,Constraint也是ConstraintLayout最基本的操作。

一个Constraint条件包括源View(即自己)和目标View(其他view或者Parent),具体到XML里是 layout_constraintTop_toTopOf layout_constraintStart_toEndOf这些属性,和RelativeLayout的layout_toStartOf / layout_toLeftOf非常相似,一般通过Android Studio的可视化编辑器来完成约束的操作。

相比RelativeLayout,ConstraintLayout的Constraint优势主要体现在两个方面,1是完善的可视化编辑支持,2是Constraint结合后面会介绍的Bias/Chain/Barrier等特性,可以更加灵活地布局。

2. 可视化编辑器

这里简单介绍下Android Studio(3.5)的可视化编辑功能,新版的AS布局编辑器和ConstraintLayout高度集成。

2.1. 创建Constraint

如上图,要为一个View添加约束,先选中它,然后有两种方式:

第一种方式是按住边上的圆点拖动箭头,然后指向要依赖的View上的某条边即可,如(1),Constraint创建成功后会有一条蓝色的折线;

第二种方式是在最右侧的4宫格里点击+按钮添加,AS会添加约束到最近的那个View,如(2),添加成功后,(3)这里可以编辑Margin的值。

一般通过第一种方式添加约束比较方便,(2)这里主要是更新margin等属性的值。

2.2. 快捷操作菜单

如上图,在编辑区右键可以弹出快捷菜单,像一些需要多个View一起操作的选项(比如Align,Chains等),需要同时选中多个View后再右键,才能操作。

值得一提的是,ConstraintLayout不管是概念上还是编辑器设计上,和iOS的AutoLayout都非常的相似,iOS再一次走在了前面^_^,如下图:

3. 对Visibility为GONE的处理

RelativeLayout相信大家都可能遇到一个问题,假设ViewA依赖ViewB来定位,如果ViewB被设置成了GONE,ViewA的位置就乱了,相当于约束失效了。

ConstraintLayout对此问题做了兼容处理,假设有如下3个Button,Button3的约束依赖于Button2:

我们把Button2 Visibility设置为GONE,表现如下:

可以看到,ConstraintLayout在此场景下,约束依旧生效!Button2相当于宽高变为0了,但约束还生效。

4. Bias

Bias即偏移值,对应XML里的layout_constraintHorizontal_bias / layout_constraintVertical_bias,取值范围从0到1,默认是0.5,代表是位置偏移比例。

当在某个方向上添加约束后,View默认是居中的(Bias=0.5),如下图:

这时候就可以通过修改Bias的值来移动位置,比如修改成0.2,如下图:

更方便的操作是修改编辑器上的滑块(从0到100,对应XML里的0到1),如下图:

5. Barrier/Guideline

Guideline比较简单,可以理解成一个不可见的View放在ConstraintLayout某个位置,然后子View就可以以他作为Constraint目标来定位。

Barrier意为屏障,和Guideline相似,也是一个不可见的View,但Barrier可以保证一直位于某几个View的Top/Bottom/Left/Right下面,有些场景下可能很有用。

举个例子,如下图,下面的ImageView需要保持在上面一排按钮下方40dp处,简单处理可以添加一个指向Button2下方的约束。

但假设Button3的高度变大了,整体效果就不合预期了,如下:

这时候就可以添加一个Barrier,设置barrierDirection="bottom",而且绑定上面3个Button,ImageView再添加指向Barrier的约束,效果如下,中间那根虚线就是Barrier(用户不可见)。现在不管3个Button高度怎么变化,Barrier都会保持在最下方。

创建Barrier的操作步骤如下:

第一步,创建Barrier,如下:

第二步,完成View的绑定。

在ComponentTree窗口里,直接拖动对应的子View到Barrier里就完成绑定了,如下:

第三步,View添加约束到Barrier。

6. Chain

Chain即为链条,可以实现多个子View按一定的比例并排在一起,ConstraintLayout借助此功能,可以实现LinearLayout大部分效果。

借用官方文档的一张图,如下:

有4种排列方式,也即chainStyle(xml里叫layout_constraintVertical_chainStyle),分别为:

1:Spread

子View居中平均分布,左右间距也平均分割。

2:Spread inside

第一个和最后一个贴边,其他的View平均分布。

3:Weighted

子View按Weighted参数比例分布,和LinearLayout的Weight参数一样。注意的是,本身并不存在叫Weighted的chainStyle,而是在第一种style模式下,子View的宽度设为0,同时设置layout_constraintHorizontal_weight参数就能进行比例划分。

4:Packed

所有子View居中贴在一起。

注意的是,chain并不是说设置一下chainStyle的参数,A,B,C 3个按钮就能如图上一样排在一起,A,B,C本身还是需要通过Constraint约束来排成一排,然后设置第一个View(这里是A)的chainStyle参数,就可以控制A,B,C的排布情况。

可以看到,ConstraintLayout通过chainStyle就可以实现多个View的居中排列, 比较方便,LinearLayout如果要实现如上几个效果,还必须通过添加一些EmptyView辅助来实现。

创建Chain的具体操作如下:

第一步,选择要排成一起的子View,注意,这些子View不要带Constraint,有的话要清除掉Constraint,因为已有的Constraint会影响后续的操作,如下:

第二步,同时选中这些view,右键菜单,创建对应方向的Chain,如下:

创建成功后,可以看到3个View相互之间已经添加了Constraint约束,如下:

第三步,我们需要3个Button顶部对齐,可以再选中3个View,右键菜单,创建Align,如下:

创建成功后,可以发现就是最前面chainStyle=”Spread”的表现了,因为默认的chainStyle就是Spread,如下图:

第四步,可以通过修改第一个View的layout_constraintHorizontal_chainStyle参数,来控制排列样式,具体参照最前面的内容。

三. 总结

总结一下,ConstraintLayout相比RelativeLayout+LinearLayout,优势主要体现在:

1)可以减少层级,性能提高

对于一些复杂的布局,传统做法里,可能root是一个RelativeLayout,对于一些需要比例排布的子View,再嵌套LinearLayout,这样就多了一个层级。而使用ConstraintLayout的话,通过前面介绍的Chain等功能,完全可以在一个ConstraintLayout里实现。层级减少,意味着渲染性能提升,官方的数据是渲染速度比RelativeLayout提高大约40%,可以再研究下。

2)可视化编辑能力完善

最新版的AS布局编辑器,可以说就是和ConstraintLayout高度集成的,以前我们在编辑器里更多可能是编辑属性的值,但ConstraintLayout的约束和元素定位,利用可视化编辑器,可以大大地提高开发效率。

3)实用的新特性

ConstraintLayout增加了Bias/Guideline/Barrier等额外新特性,相比传统做法里需要代码判断等方式,可以说简化了开发者的逻辑,只需要XML里配置即可完成。

与此同时,ConstraintLayout也存在一些劣势,比如说有一定的熟悉成本,涉及的概念比较多,xml可能会比较复杂和繁乱(借助可视化编辑器可以不需要关心xml内容),也可能存在一些未知的bug。

总体来看,ConstraintLayout是Android官方很重视且逐步在推广的一个标准布局,而且和iOS的AutoLayout布局方式也很相似,相信有比较光明的未来!

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
暂无评论
推荐阅读
使用GDAL实现DEM的地貌晕渲图(一)
以前一直以为对DEM的渲染就是简单的根据DEM的高度不同赋予不同的颜色就可以。后来实际这么做的时候获取的效果跟别的软件相比,根本体现不出地形起伏的变化。如果要体现出地形的起伏变化,需要得到地貌晕渲图才行。晕渲法假设地形接受固定于某一位置光源的平行光线,随坡面与光源方向的夹角不同,产生不同色调明暗效果。 根据文献[1][2],可以通过计算DEM格网点的法向量与日照方向的的夹角,来确定该格网点的像素值。
charlee44
2019/08/13
1.1K0
使用GDAL实现DEM的地貌晕渲图(二)
之前我在《使用GDAL实现DEM的地貌晕渲图(一)》这篇文章里面讲述了DEM晕渲图的生成原理与实现,大体上来讲是通过计算DEM格网点的法向量与日照方向的的夹角,来确定该格网点的晕渲强度值。但其实关于这一点我不是很理解,这样做随着坡面与光源方向的夹角不同,确实产生了不同色调明暗效果;但晕渲图同时又有“阴坡面越陡越暗,阳坡面越陡越亮”的特性的,而阴阳坡面的划分又是跟坡度和坡向相关,之前的生成方法能体现出这种特性吗?
charlee44
2019/08/13
1K0
使用GDAL实现DEM的地貌晕渲图(三)
之前在《使用GDAL实现DEM的地貌晕渲图(一)》和《使用GDAL实现DEM的地貌晕渲图(二)》这两篇文章中详细介绍了DEM生成地貌晕渲图的原理与实现。不过之前生成的都是晕渲强度值对应的灰度图,而实际的应用过程中都会将DEM晕渲成彩色图。
charlee44
2019/08/13
1.3K0
DEM转换为gltf
DEM(地形文件)天然自带三维信息,可以将其转换成gltf模型文件。DEM是栅格数据,可以通过GDAL进行读取;gltf是一种JSON格式,可以采用nlohmann/json进行读写。
charlee44
2020/01/14
1.3K0
DEM转换为gltf
使用OSG创建一个简单的地形
在网上参考了一些资料,使用OSG创建地形最简单的办法就是使用OSG::HeightField类,它是描述类似于DEM网格的四角面片。首先给出具体实现代码:
charlee44
2022/05/05
1.8K0
使用OSG创建一个简单的地形
点集合的三角剖分
点集合的三角剖分是指如何将一些离散的点集合组合成不均匀的三角形网格,使得每个点成为三角网中三角面的顶点。这个算法的用处很多,一个典型的意义在于可以通过一堆离散点构建的TIN实现对整个构网区域的线性控制,比如用带高程的离散点构建的TIN来表达地形。
charlee44
2023/10/26
4120
点集合的三角剖分
通过CGAL将一个多边形剖分成Delaunay三角网
对于平面上的点集,通过Delaunay三角剖分算法能够构建一个具有空圆特性和最大化最小角特性的三角网。空圆特性其实就是对于两个共边的三角形,任意一个三角形的外接圆中都不能包含有另一个三角形的顶点,这种形式的剖分产生的最小角最大。
charlee44
2020/03/19
3.2K0
[CGAL]带岛多边形三角化
[CGAL]带岛多边形三角化 CGAL带岛多边形三角化,并输出(*.ply)格式的模型
用户3519280
2023/07/06
2830
OpenGL显示图片
最近想用C++在windows下实现一个基本的图像查看器功能,目前只想到了使用GDI或OpenGL两种方式。由于实在不想用GDI的API了,就用OpenGL的方式实现了一下基本的显示功能。
charlee44
2022/05/05
3.7K0
OpenGL显示图片
OpenCV系列(18)|三角剖分
应用:人脸检测的核心技术 代码: #include <opencv2/imgproc.hpp> #include <opencv2/highgui.hpp> #include <iostream> #include <fstream> using namespace cv; using namespace std; static void help() { cout << "\nThis program demonstrates iterative construction of\n"
用户9831583
2022/06/16
6610
OpenCV系列(18)|三角剖分
基于均值坐标(Mean-Value Coordinates)的图像融合算法的优化实现
我在之前的文章《基于均值坐标(Mean-Value Coordinates)的图像融合算法的具体实现》中,根据《Coordinates for Instant Image Cloning》这篇论文,详细论述了图像融合中泊松融合算法的优化算法——均值坐标(Mean-Value Coordinates)融合算法的具体实现。其实在这篇论文中,还提出了两种优化实现,能够进一步提升效率,这里就论述一下其优化算法的具体实现。
charlee44
2020/03/21
1.2K0
【三维算法:CGAL】
CGAL是计算几何算法库,是一个大型C++库的几何数据结构和算法,如Delaunay三角网、网格生成、布尔运算的多边形以及各种几何处理算法。
用户3519280
2023/07/06
6350
图像处理之直方图均衡化拉伸
在OpenCV中,实现直方图均衡化比较简单,调用equalizeHist函数即可。具体代码如下:
charlee44
2022/05/05
1.4K0
图像处理之直方图均衡化拉伸
3.1.2 使用绘图API绘制Contour的思路
A week or so back I wrote about a package I ported/modified to create the Delaunay triangulation in Flash with a few AS3 classes. As I noted there, such atriangulated irregular network (TIN) allows us to interpolateisolines — lines of constant value (aka isarithms, commonly called contours).
周星星9527
2018/08/08
5420
3.1.2 使用绘图API绘制Contour的思路
【失败也分享】C++ OpenCV人脸Delaunay三角形提取及仿射变换的使用
最近这几篇OpenCV相关的文章都是与人脸有关,其实最主要是就是想做人脸替换的小试验,大概流程是:
Vaccae
2021/03/12
1.7K0
空间射线与三角形相交算法的两种实现
任何复杂的三维模型都可以视作空间三角面片的集合,很容易碰到的一个问题就是空间射线与三角形相交的问题,例如拾取、遮蔽检测等。这里就总结下该问题的两种算法实现。
charlee44
2020/02/24
2.7K1
Qt5 和 OpenCV4 计算机视觉项目:6~9
在上一章中,我们了解了光学字符识别(OCR)技术。 我们借助 Tesseract 库和预训练的深度学习模型(EAST 模型)来识别扫描文档和照片中的文本,该模型已随 OpenCV 一起加载。 在本章中,我们将继续进行对象检测这一主题。 我们将讨论 OpenCV 以及其他库和框架提供的几种对象检测方法。
ApacheCN_飞龙
2023/04/27
3.4K0
Qt5 和 OpenCV4 计算机视觉项目:6~9
从K近邻算法、距离度量谈到KD树、SIFT+BBF算法
前两日,在微博上说:“到今天为止,我至少亏欠了3篇文章待写:1、KD树;2、神经网络;3、编程艺术第28章。你看到,blog内的文章与你于别处所见的任何都不同。于是,等啊等,等一台电脑,只好等待..”。得益于田,借了我一台电脑(借他电脑的时候,我连表示感谢,他说“能找到工作全靠你的博客,这点儿小忙还说,不地道”,有的时候,稍许感受到受人信任也是一种压力,愿我不辜负大家对我的信任),于是今天开始Top 10 Algorithms in Data Mining系列第三篇文章,即本文「从K近邻算法谈到KD树、SIFT+BBF算法」的创作。
全栈程序员站长
2022/09/06
1.1K0
从K近邻算法、距离度量谈到KD树、SIFT+BBF算法
matlab命令,应该很全了!「建议收藏」
1、!dir 可以查看当前工作目录的文件。 !dir& 可以在dos状态下查看。
全栈程序员站长
2022/11/10
7.2K0
PbootCMS 后台登录界面“3D 云”背景
1.找到后台登录模板文件:/apps/admin/view/default/index.html
Savalone
2020/04/21
9.6K3
相关推荐
使用GDAL实现DEM的地貌晕渲图(一)
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档