Android ConstraintLayout详解
1. 概述

在本篇文章中,你会学习到有关ConstraintLayout -- 一种构建于弹性Constraints(约束)系统的新型Android Layout。最终你将会在Android Studio中编辑与构建一个相对复杂的Layout。
收获
- 新Layout Manager所使用的Constraints系统
- 创建Constraints来构建弹性高效的Layouts
- 新Layout编辑器的各种功能
需求
2. 获取示例代码
使用Git
$ git clone https://github.com/googlecodelabs/constraint-layout.git
3. 运行示例代码
- 打开Android Studio,选择
File>New>Import Project,选择步骤2下载的示例代码的文件夹constraint-layout-start。 - 点击
Gradle sync按钮。 - 在
Project�面板内打开res/layout/activity_main_done.xml - 选择
Design选项显示最终的layout编辑界面 - 在编辑器左上角选择
Virtual Device to render the layout with为Nexus 5x 完工
4. Constraints 系统概览
Layout引擎使用Contraints指定每个widget来决定他们在layout中的位置。你可以使用Android Studio Layout编辑器界面来手动或者自动指定约束。要更好的理解他,需要我们了解一下他对一个选中的widget的基本控键。
Constraints
Constraints帮助你保持widgets对齐。你可以使用箭头来决定各widgets的对齐规则。例如(�图示 A),从button 2左侧控键设置一个constraint到button 1的右侧控键意味着:button 2会放置于button 1右侧56dp处

控键类型

调整尺寸控键 - 类似于其他设计/绘图应用,该控键允许你调整widget尺寸

侧约束控键 - 该控键让你指定widget的位置。例如,你可以使用widget的左侧控键到其他widget的右侧控键相隔
24dp。
基线约束控键 - 该控键帮助你对齐任意两个widget的文字部分,与widget的大小无关。例如你有两个不同尺寸的widget但是你想要他们的文字部分对齐。

《ConstraintLayout从入门到放弃》
太长;别读
5. ConstraintLayout应用
一)开启
现在,让我们开始来构建你自己的Constraint Layout。
从左侧导航栏打开 res/layout/activity_main_start.xml。
- 载入constraint-layout依赖
constraint-layout依赖构建在一个分离的支持库里,该依赖支持从Android2.3(Gingerbread)到最新的版本。这个项目在app/build.gradle里已经包含了该依赖
dependencies {
...
compile 'com.android.support.constraint:constraint-layout:1.0.0-alpha2'
}
**回到
res/layout/activity_main_start.xml**该layout已经有了一个空的
ConstraintLayout。
<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="match_parent">
</android.support.constraint.ConstraintLayout>
在编辑器底部转换到Design选项

- 添加
ImageView
添加一个ImageView到layout。在编辑器内,找到ImageView拖到layout内。

ImageView一旦拖到layout中,UI会提示需要resource。constraint-layout-start已经包含了resources,请选择@drawable/singaporeresource。
一旦选中ImageView,你可以点击并按住调整尺寸控键来调整图片大小。

- 添加
TextView
找到TextView并拖到layout内。
我们会看到一些警告,因为在
ImageView以及TextView内没有contentDescription属性。内容描述(Content Description)属性对于构建可访问应用非常重要。让我们为该属性添加@string/dummy。
在右侧,Inspector面板可以改变已选择widget的各种属性。

- 选择
ImageView并添加@string/dummy到contentDescription属性 - 在Inspector面板,你可以看到
ImageView的其他属性。修改scaleType为centerCrop。 - 接着,我们选择
TextView,使用该面板修改text值为@string/singapore。
二)手动创建Constraints
创建一个约束,你需要在widget的某个控键上点击并按住,然后拖到两一个widget的约束控键内。一旦显示绿色,你就可以松手了最终约束就会被创建。

注意:该部分讲有关手动创建约束的,需要将左上角的自动创建约束按钮关闭
在开始之前,确保ImageView和TextView在layout内。我们的目标是在容器、ImageView以及TextView之间创建约束。
假设我们想要TextView置于ImageView下方。我们可以在TextView的顶部控键与ImageView的底部控键创建一个约束,如图:

移除约束:移除某个约束只需点击指定约束的控键;移除全部约束需要点击如下按钮:
下一步,创建ImageView跟容器顶部的约束

最后,创建ImageView左右两侧的约束

创建基线约束 - 连接widget的基线控键到另一个的基线
三)熟悉Inspector
在此部分,我们会了解一下Inspector。它在UI编辑器的右侧。附带有已选择widget的各种相关属性,而且还显示了该视图是如何对齐与约束的。
- 移除
TextView - 添加
ImageView底部约束
此时,UI构建起如下图:

以下部分描述了不同的元素和他们的使用方法:
Margins - widget的外围上下左右为margins。你可以点击按钮设置不同的值来改变margins。在上边截图中,margins设置为16dp
移除constraint - 在Inspector内点击连接widget与container的线,可以移除约束。当然也可以点击已设置约束的控键来移除。
相对于约束来放置widget - 当在一个widget有至少两个相对的连接,比如说顶部和底部,或者左侧和右侧,然后就可以使用滑动条来调节widget在链接中的位置。你还可以改变屏幕方向来进一步调整方位。

控制widget内部尺寸 - Inspector内部的线让你可以控制widget内部尺寸。






四)自动创建Constraints
Autoconnect自动创建widgets之间的连接。开始之前
- 打开
res/layout/activity_main_autoconnect.xml - 开启
Autoconnect(译注:小磁铁图标)
接下来,选中ImageView并且拖到layout的中心,如下图所示:

下一步,下方的动图展示了以下几个步骤

ImageView对齐顶部并使用Inspector(AnySize)来确保他扩展到两侧- 放置两个button在右下角。使用Inspector面板来修改最右边button的
text为@string/upload以及左侧改为@string/discard - 将一个
TextView和一个Plain Text放到layout中。 - 调整
TextView和Plain Text为48dp。并自动创建约束。 - 同样的选中上传button放置到右侧。
- 最后放置取消button离上传button
32dp的位置
五)使用Inference创建Constraints
(译注:待更新)
FAQ: (感谢Little_Mango提供的问题)
兄弟控件对齐方式只有top left bottom right,无x,y中心点对齐,这样两个View依然无法做到水平方向中点对齐。
使用chains父子控件间宽高约束过于简单,只有wrap_content,fixed,match,即包裹内容,匹配父容器,和绝对数值,无法做到类似子控件的宽度等于父控件的宽度的的1/4的需求。
使用Guidelines(新版的指南好像没有介绍)兄弟、父子之间宽高属性之间无约束,比如A控件宽度等于屏幕宽度的1/4,A控件的高度等于自身的宽度。B控件的宽等于A控件的宽度,B控件的高度等于A控件的高度的1/2.
a. 参考 2
b. 使用ratios
c. 参考 b不清楚是否能通过代码动态修改约束,如果不支持这种操作,那么类似容器垂直方向图片张数不一致这种需求也无法动态修改。
使用 barriers这个布局是否有布局的动画支持?如果没有,那么动画如何修改?通过修改控件的height和width是否会和约束冲突?
动画支持
作者:田浩浩_DockOne
链接:https://www.jianshu.com/p/a8b49ff64cd3
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
Android ConstraintLayout详解的更多相关文章
- Android ConstraintLayout详解(from jianshu)
Android ConstraintLayout详解 https://www.jianshu.com/p/a8b49ff64cd3 1. 概述 在本篇文章中,你会学习到有关Constraint ...
- 约束布局ConstraintLayout详解
约束布局ConstraintLayout详解 转 https://www.jianshu.com/p/17ec9bd6ca8a 目录 1.介绍 2.为什么要用ConstraintLayout 3.如何 ...
- Android Notification 详解(一)——基本操作
Android Notification 详解(一)--基本操作 版权声明:本文为博主原创文章,未经博主允许不得转载. 微博:厉圣杰 源码:AndroidDemo/Notification 文中如有纰 ...
- Android Notification 详解——基本操作
Android Notification 详解 版权声明:本文为博主原创文章,未经博主允许不得转载. 前几天项目中有用到 Android 通知相关的内容,索性把 Android Notificatio ...
- Android ActionBar详解
Android ActionBar详解 分类: Android2014-04-30 15:23 1094人阅读 评论(0) 收藏 举报 androidActionBar 目录(?)[+] 第4 ...
- Android 签名详解
Android 签名详解 AndroidOPhoneAnt设计模式Eclipse 在Android 系统中,所有安装 到 系统的应用程序都必有一个数字证书,此数字证书用于标识应用程序的作者和在应用程 ...
- Android编译系统详解(一)
++++++++++++++++++++++++++++++++++++++++++ 本文系本站原创,欢迎转载! 转载请注明出处: http://blog.csdn.net/mr_raptor/art ...
- Android布局详解之一:FrameLayout
原创文章,如有转载,请注明出处:http://blog.csdn.net/yihui823/article/details/6702273 FrameLayout是最简单的布局了.所有放在布局里的 ...
- 【整理修订】Android.mk详解
Android.mk详解 1. Android.mk 的应用范围 Android.mk文件是GNU Makefile的一小部分,它用来对Android程序进行编译. 一个Android.mk文件可以编 ...
随机推荐
- angularjs ng-repeat下验证问题
angularjs验证要求name唯一,repeat情况,name 等通过${index}等绑定,也无法获取值 通过ng-from的方法,这样验证name重复也可以了. <ng-form nam ...
- python request包使用指西
request是Python的一个网络模块包,使用它可以快速写一些强大的爬虫脚本
- flume介绍及应用
版权声明:本文为yunshuxueyuan原创文章.如需转载请标明出处: http://www.cnblogs.com/sxt-zkys/QQ技术交流群:299142667 flume的概念 1. ...
- 【HTML/XML 3】XML 简介,来源
导读:在标记语言出现之前,计算机中的数据一直都是以神秘的二进制在进行处理,但是,标记语言的出现,慢慢的改变了这种认识.那么,标记语言都经过了什么样的发展呢?它又有什么用处呢? 一.追根溯源(XML的产 ...
- 我是一个线程 - IBM刘欣
来自:码农翻身(微信号:coderising) 作者:IBM刘欣 我是一个线程,我一出生就被编了个号: 0×3704,然后被领到一个昏暗的屋子里, 这里我发现了很多和我一模一样的同伴. 我身边的同伴0 ...
- 只有代码不会撒谎,如何通过Spring boot源码查看其对于各个框架的默认配置
我发现很多开发对于看源码都有种恐惧心理,其实不必这样,大部分优秀的源码写的都挺直观的,很多时候,你在搜索引擎上搜到的一些东西并不一定是对的,但源码肯定造不了假,毕竟不管你怎么想,它就在那里,该是什么意 ...
- 理解 mysql行锁和表锁
在调用存储过程中,就会涉及到表锁,行锁这一概念:所谓区别:有索引的时候就是行锁,没有索引的时候就是表索. innodb 的行锁是在有索引的情况下,没有索引的表是锁定全表的. 表锁演示(无索引) Ses ...
- 最近公共祖先(Least Common Ancestors)
题意: 给定一棵有根树T,给出若干个查询lca(u, v)(通常查询数量较大),每次求树T中两个顶点u和v的最近公共祖先,即找一个节点,同时是u和v的祖先,并且深度尽可能大(尽可能远离树根).通常有以 ...
- java.sql.SQLException: [Microsoft][ODBC 驱动程序管理器] 未发现数据源名称而且未指定默认驱动程序解决方法
开发程序须要登录功能 .就不想用大数据库.直接用java连接access. 在自己机器上一切正常, url直连 和配置数据源都没有问题. 公布到windows server2008 上 , ...
- 多线程调用COM组件的体会(CoInitialize)
调用任何COM组件之前,你必须首先初始化COM套件环境,即调用CoInitialize或CoInitializeEx.COM套件环境在线程的生存周期内有效,线程退出前需要调用CoUninitializ ...






