ConstraintLayout布局学习总结

参考链接:
https://developer.android.com/training/constraint-layout/index.html?utm_campaign=android%20studio_launch_2.2_091916&utm_source=anddev&utm_medium=blog#add-constraintlayout-to-your-project

http://quanqi.org/2016/05/20/code-labs-constraint-layout/

前言

Google I/O 2016 上发布了 ConstraintLayout,刚发布出来的时候也跟着试玩了一下,看着官方的例子也写了一个布局,但是没有深入去看。最近刚刚将Android Studio升级到了Android Studio2.2正式版,期待已久的Android studio 2.2确实给我们带来了很多新的功能。其中两项跟本文相关就是:

  • New Layout Editor
  • ConstraintLayout

很多人都说ConstraintLayout是一项大的革新,但是也有人说Google是在开历史倒车,下面我就以自己的试水经验谈谈自己的感受。首先我想说ConstraintLayout确实是一个新的很强大的布局,最起码在减小布局层级这一块作用很大。然后ConstraintLayout虽有优点但也不能完全取代RelativeLayout和LinearLayout,以前都是手写XML的,忽然让我们拖控件(说真的,拖控件拖的我眼珠子都瞪大了,手都拖麻了)有点不好适应,而且有的拖动很难实现,可能还有待完善吧。但是拖了两天发现自己越拖越顺手,有经验后拖的越来越快。

Everything you can do with ConstraintLayout is available directly from the Layout Editor's visual tools, because the layout API and the Layout Editor were specially built for each other. So you can build your layout with ConstraintLayout entirely by drag-and-dropping instead of editing the XML.
你能够对ConstraintLayout 做的任何处理都可以使用布局编辑器工具实现,由于这个布局的api和布局编辑器都是互相量身定制的。所以你使用 ConstraintLayout 来编写实现你的布局时完全可以只使用拖拽而不需要编辑XML。---来自官网

准备阶段

为了使用ConstraintLayout请执行下面的步骤:
1,首先先将自己的Android studio升级到Android studio2.2正式版或者以上版本
2,保证你有最新的Constraint Layout库:

  • 点击Tools > Android > SDK Manager.
  • 点击SDK Tools选项卡
  • 点开Support Repository,并且选择ConstraintLayout for Android还有Solver for ConstraintLayout.选中Show Package Details,如果没有下载过的话,就点击OK下载
  • 在项目中添加依赖库
dependencies {
        compile 'com.android.support.constraint:constraint-layout:1.0.0-alpha8'
}
Paste_Image.png

现在就可以使用了

基础教程

基本概念

先认识一下基础东西


E7565621-16E8-4010-B2F9-F19DC5BC66F2.png

关于操作
其实实际操作就是切换到设计视图模式,然后先把一个需要的控件拖进来。然后对各个约束操作手柄进行操作。侧边操作手柄决定侧边距离父控件或者相对于其它控件的距离,尺寸约束可以修改控件的大小,直接点击到控件上拖动,可以改变控件的位置,但是这样拖动到某一个位置,并不是它实际的位置,假如不利用侧边、基准线等约束,实际运行效果控件会跑到(0,0).

When creating constraints, remember the following rules:
当创建约束的时候需要记住以下的一些原则:

  • Every view must have at least two constraints: one horizontal and one vertical.
    每个View必须至少有两个约束:一个水平方向的一个垂直方向的

假如不满足上面的原则,XML文件就回报红

23F830F7-584D-49F2-B0AB-F81D3240E7C1.png

也就是说只需要设置一个水平方向的约束和一个垂直方向的约束就可以不报错了

64F530AF-3288-482C-9B15-754927893E8C.png

我们需要做的就是点击左侧侧边约束的点,然后往左边拖,箭头变绿,然后松手,就可以了,然后点击上边的侧边约束往上面拖,箭头变绿松手,

也可以点击侧边约束,拖到其它控件的侧边,这种叫Alignment constraint排列约束


盗图自官网

基准线约束:
比如想让第二个textview在第一个的右边,然后水平对齐,这里要借助第二个textview的左侧侧边约束点和基准线约束手柄。关于基准线手柄,我有一些话说:首先有的控件没有基准线手柄比如ImageView等;手拖时不好拖,开始不知道,我都是先放大,然后点上去,等基准线位置变色才可以拖出来(拖的我也是醉了),其实有个小技巧官网上有提:To create a baseline constraint, hover your mouse over the baseline handle for two seconds until the handle blinks white. Then click and drag the line to another baseline. 将鼠标悬置在基准线约束手柄的上面等两秒钟会发现手柄区域变白色,然后点击并拖动,你会发现会有蓝色小箭头出现,把这个箭头拖到另外一个基准线上,就完成了基准线约束。实在感觉不好拖就在XML里面写这个属性吧 app:layout_constraintBaseline_toBaselineOf="@+id/textView1"

79FE84D9-A73A-47BA-8F8F-40358B483523.png

Constrain to a guideline,可以理解为指导线,辅助线约束
这个算是个新概念,用着感觉还是极好的。。


9E3FF69D-3E05-497D-B0FE-E7D90E5B89AF.png
B918F5C4-C50E-47E2-A4A5-5024E8850BA4.png

看上图Imageview的位置可以完全靠这两条线决定

关于设置宽高

下面是使用新的布局编辑器编写布局的界面


EBD9C720-00F8-498F-954C-7951083EAD6B.png

当我们点击到一个控件上的时候,你会发现右上角有一个四方块,这个地方就是代表控件的一些属性其中包括宽高,比例等

A5DFD102-994F-4C4B-BC9B-DD1311E251DD.png

下面解释上图各个图标代表的含义:

  • Wrap Content:
    The view expands exactly as needed to fit its contents.这个相当于Wrap Content,不用多说
  • Any Size:
    根据它的约束需要任意扩展,可以理解为"match constraints"而不是"match_parent",
  • Fixed:
    这个代表自己设置固定的数值dp

这几个属性可以只要点击一下图标就可以了切换为其他属性。
*注意:在ConstraintLayout中的人和一个view都不应该设置为match_parent而应该使用Any Size(0dp);

举个栗子🌰

目前我发现使用这个ConstrainLayout有个比较坑的地方就是,有时候你拖好了一个控件,但是以前设置好的控件又回到解放前了(就是前面设置的约束自动消失)

下面是一个我做的一个小视频
http://odwl8g8h2.bkt.clouddn.com/constraintlayout_first.mp4

总结

刚开始学习还有很多不懂的地方,以上有出错的地方请指出

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

推荐阅读更多精彩内容