0
点赞
收藏
分享

微信扫一扫

ConstrainLayout 基础教程2,近期想跳槽的程序员必看

老罗话编程 2022-02-02 阅读 71

特性详解

Visibility behavior (可见性的表现)

ConstraintLayout对可见性被标记View.GONE的控件(后称“GONE控件”)有特殊的处理。一般情况下,GONG控件是不可见的,且不再是布局的一部分,但是在布局计算上,ConstraintLayout与传统布局有一个很重要的区别:

  • 传统布局下,GONE控件的尺寸会被认为是0(当做来处理)
  • 在ConstraintLayout中,GONE控件尺寸仍然按其可见时的大小计算,但是其外边距大小按0计算

image.png

这种特殊的行为让我们在无需打乱布局情况下,在标记GONE控件的地方构建布局(如上图),这样的做法对于做简单的布局动画很有用。

Dimensions constraints (尺寸约束)

Minimum and maximum dimensions on ConstraintLayout (最大最小尺寸)

ConstraintLayout本身可以定义自己的最大/最小尺寸:

  • android:minWidth 设置布局的最小宽度
  • android:minHeight 设置布局的最小高度
  • android:maxWidth 设置布局的最大宽度
  • android:maxHeight 设置布局的最大高度

这些最小尺寸当ConstraintLayout被设置为WRAP_CONTENT时有效。

Widgets dimension constraints (控件尺寸约束)

控件的尺寸可以通过android:layout_widthandroid:layout_height来设置,有三种方式:

  • 使用固定值(文字值如123dp或 Dimension reference)
  • 使用WRAP_CONTENT
  • 使用0dp(相当于MATCH_CONSTRAINT

image.png

前两种方式和其他布局的用法相同,最后一种是通过填充约束来重新设置控件的尺寸(如上图 ,(a)是wrap_content,(b)是0dp。代码案例如下:

<Button android:layout_width=“0dp” // 这里对宽度设置MATCH_CONSTRAINT,结合3、4两行实现约束
android:layout_height=“wrap_content”
app:layout_constraintLeft_toLeftOf=“parent”
app:layout_constraintRight_toRightOf=“parent”/>

如果设置了边距,那么外边距就会在尺寸计算中被考虑进去 如上图(c)中的0dp

划重点:0dp并不是类似于以前的MATCH_PARENT,它match的是约束。 如上图(b) 他的左右约束是parent,所以他设置0dp就铺满父宽度,但是©,他的左边有个约束为margin,右边约束到parent,所以这个0dp就是从左约束(那个margin值)到最右边(parent)

**重点:**对于ConstraintLayout中包含的控件,不建议使用MATCH_PARENT。可以通过使用MATCH_CONSTRAINT来定义类似的行为,其中相应的左/右或上/下约束被设置为parent

Enforcing constraints(强制约束)

在 1.1 版本之前,如果将控件的尺寸设置为了 WRAP_CONTENT,那么对控件设置约束(如:minWidth 等)是不起作用的。那么强制约束(Enforcing constraints)的作用就是,在控件被设置 WRAP_CONTENT 的情况下,使约束依然生效。

  • app:layout_constrainedWidth=”true|false”
  • app:layout_constrainedHeight=”true|false”

下面的例子演示了没有设置强制约束和设置了强制约束的对比:

image.png

如图所示,同样设置了最大宽度,imageViewB起作用,imageViewA没有起作用

MATCH_CONSTRAINT dimensions

当尺寸设置为MATCH_CONSTRAINT(0dp,默认行为是使结果大小占用所有可用空间)时。1.1版本之后,还有几个额外的修饰符:

  • layout_constraintWidth_min and layout_constraintHeight_min : 指定当前控件的最小宽度或高度
  • layout_constraintWidth_max and layout_constraintHeight_max : 指定当前控件的最大宽度或高度
  • layout_constraintWidth_percent and layout_constraintHeight_percent : 指定当前控件的宽度或高度是父控件的百分之多少。可设置的值在 0 - 1 之间,1 就是 100%

<ImageView
android:id="@+id/imageViewB"

总结:

各行各样都会淘汰一些能力差的,不仅仅是IT这个行业,所以,不要被程序猿是吃青春饭等等这类话题所吓倒,也不要觉得,找到一份工作,就享受安逸的生活,你在安逸的同时,别人正在奋力的向前跑,这样与别人的差距也就会越来越遥远,加油,希望,我们每一个人,成为更好的自己。

  • 点击此处,与我们一起交流学习

文件夹有以下学习笔记,自行下载!

  • BAT大厂面试题、独家面试工具包,

  • 资料免费领取,包括 数据结构、Kotlin、计算机网络、Framework源码、数据结构与算法、小程序、NDK、Flutter,

  • BAT大厂面试题、独家面试工具包,

  • 资料免费领取,包括 数据结构、Kotlin、计算机网络、Framework源码、数据结构与算法、小程序、NDK、Flutter,

    [外链图片转存中…(img-UxTbUTCD-1643787388600)]

举报

相关推荐

0 条评论