ConstraintLayout布局基础用法

最近刚开始使用AS,打开layout第一眼就发现了ConstraintLayout这个新的布局,怀着好奇的心态,我查阅了很多相关的资料;

简单来说,它就是RelativeLayout的升级版本,但是区别与相对布局更加强调约束;何为约束,即控件之间的关系;

它能让你的布局更加扁平化,一般来说一个界面一层就够了;同时借助于AS我们能极其简单的完成界面布局。

工作区

我们先来看看 Android Studio 2.2 Preview1 提供的工作区。

Paste_Image.png

在工作区中有两种预览,一种设计预览,一种叫做蓝图的东西。两者可以辅助进行布局预览,非常Nice。

Paste_Image.png

眼睛图标:用来控制是否显示约束的东西。

Paste_Image.png

磁铁图标:用来自动吸附的东西,就是说两个按钮放在一起的时候会自动按照一定的约束条件进行链接。

Paste_Image.png

清理图标:用来清除所有的约束,当鼠标放倒一个控件上时也会有一个清理图标出现,点击可以清除当前选中的控件的约束。

Paste_Image.png

灯泡图标:用来自动推断约束条件的东西,运用这个可以更加智能快速的完成布局。

Paste_Image.png

调整手柄

Paste_Image.png

拖动该手柄能帮助你调整整个控件的大小。

约束手柄

Paste_Image.png

这个约束手柄位于控件的四边,在四边上有四个小圆点,拖动该圆点并指向另外的控件的一边,哪么可以让该控件对其到指向的控件。当然你可以设置margin来提供对应的间距。如果需要清理掉单个约束,点击该圆点即可。
手柄限制:
左右两边的手柄只能链接到另外一个控件的左右两边,上下手柄同样。

基线手柄

Paste_Image.png

该手柄仅仅出现在有文字的控件中使用,或者继承TextView的控件中使用,其作用是对齐两个控件的文字基线。
基线限制:
基线只能链接到另一个控件的基线。 基线也不能与手柄进行链接。

谷歌的案例

1.首先选择一个约束手柄,并按住鼠标拖动到另外一个控件的手柄原点上,当链接线变成绿色的时候松开鼠标即可创建一个约束。


20160521091948156.png

2.添加图片控件,链接TextView控件的顶部手柄到ImageView底部手柄,并拖动一定间距。可以看出约束添加时文本控件自动吸附到了图片的底部。

20160521091949160.png

3.拖动图片控件顶部手柄到根布局顶部。


20160521091949167.png

4.最后我们同时添加图片左边与右边的约束使其居中对齐。


20160521091950172.png

5.添加基线约束。


20160521091951173.png

是不是很简单?从未感觉布局如此简单,如果使用传统布局进行拖动必定不能做到多屏幕适配的问题,而约束布局却不会,约束强调相互关系,并不固定位置。

约束

约束本质上对视图定义的规则,规则声明视图的位置和屏幕上对齐方式。
相对布局中也有类似的属性,但ConstraintLayout对视图的控制力更强;
例如,相对布局的属性允许我们放置视图:

  • layout_toRightOf
  • layout_toLeftOf
  • layout_toTopOf
  • layout_toBottomOf

然而,ConstraintLayout用于更多的特性:

  • layout_constraintTop_toTopOf — 期望视图的上边对齐另一个视图的上边
  • layout_constraintTop_toBottomOf — 期望视图的上边对齐另一个视图的底边
  • layout_constraintTop_toLeftOf — 期望视图的上边对齐另一个视图的左边
  • layout_constraintTop_toRightOf — 期望视图的上边对齐另一个视图的右边
  • layout_constraintBottom_toTopOf — 期望视图的下边对齐另一个视图的上边
  • layout_constraintBottom_toBottomOf — 期望视图的底边对齐另一个视图的底边
  • layout_constraintBottom_toLeftOf — 期望视图的底边对齐另一个视图的左边
  • layout_constraintBottom_toRightOf — 期望视图的底边对齐另一个视图的右边
  • layout_constraintLeft_toTopOf — 期望视图的左边对齐另一个视图的上边
  • layout_constraintLeft_toBottomOf — 期望视图的左边对齐另一个视图的底边
  • layout_constraintLeft_toLeftOf — 期望视图的左边对齐另一个视图的左边
  • layout_constraintLeft_toRightOf — 期望视图的左边对齐另一个视图的右边
  • layout_constraintRight_toTopOf — 期望视图的右边对齐另一个视图的上边
  • layout_constraintRight_toBottomOf — 期望视图的右边对齐另一个视图的底边
  • layout_constraintRight_toLeftOf — 期望视图的右边对齐另一个视图的左边
  • layout_constraintRight_toRightOf — 期望视图的右边对齐另一个视图的右边
  • 如果需要,属性支持开始结尾也可用在对齐。
    注意:ConstraintLayout也向下兼容到API 9

总结

通过本篇文章的学习,基本上一个简单的不需要滚动的布局都可以使用约束布局来完成,也仅仅只需要一层就可以了,所有的控件无论在多一层足够了。

这是否意味着抛弃其他控件?并不是的!约束布局仅仅只是一种新的思路,其适用于界面不太复杂,并且不滚动的界面中布局,如果界面元素很多甚至超过屏幕,哪么并不建议使用约束布局。

另外约束布局仅仅是简单快捷的布局,其性能负担随着界面中的控件数量以及约束条件的增加而增加;所以使用时还需要多多考究。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,454评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,553评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,921评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,648评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,770评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,950评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,090评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,817评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,275评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,592评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,724评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,409评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,052评论 3 316
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,815评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,043评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,503评论 2 361
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,627评论 2 350

推荐阅读更多精彩内容