ConstraintLayout使用笔记

2019-04-19  本文已影响0人  Kyle_Xiong

ConstraintLayout是官方推荐使用的布局,使用它可以有效的减少布局层数... 使用Android Studio创建布局文件时已经使用ConstraintLayout作为了默认根,布局这篇文字主要记录ConstraintLayout的一些使用及使用过程中遇到的问题。

一、相对位置属性

二、Margins属性:同RelativeLayout属性

三、Margins when connected to a Gone widget

当前View与另一个View绑定后,另一个View的属性设置为了Gone,则以下属性会生效

四、权重

app:layout_constraintHorizontal_bias="0.3" ( app:layout_constraintVertical_bias="0.3"纵向)
可以通过设置app:layout_constraintHorizontal_bias属性进行位置的调整,表示距离左侧(因为是横向,纵向则是距离顶部)30%的的距离。默认为0.5,即居中

五、View大小

view的大小除了传统的wrap_content、指定尺寸、match_parent(官方不推荐使用match_parent)外,还可以设置为0dp(官方取名叫MATCH_CONSTRAINT),0dp在constraint有着特殊含义。他的作用会随着不同的设置有不同的含义:

1. layout_constraintWidth_default

Note:当宽度设置为wrap_content时,内容区域会超过约束(如TextView文本显示超出屏幕),可通过如下属性解决:

2.layout_constraintDimensionRatio

layout_constraintDimensionRatio,即宽和高成一定的比例,其值可以是"width:height"的形式,也可以是width/height的值。该属性生效的前提:宽和高其中有一项为0dp,有constraint。下面按照有几个0dp来分别介绍下:

3.max min

六、链(layout_constraintHorizontal_chainStyle)

如图,在一个水平或者竖直方向上,一排view两两互相约束,即为链


image

链的第一个元素称为链头,可以通过设置layout_constraintHorizontal_chainStyle来控制链的分布形式,分布形式有以下3种:

<?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">

    <TextView
        android:id="@+id/tvA"
        android:layout_width="50dp"
        android:layout_height="50dp"
        android:background="#F44336"
        android:textColor="@color/white"
        android:gravity="center"
        android:text="A"
        app:layout_constraintEnd_toStartOf="@id/tvB"
        app:layout_constraintHorizontal_chainStyle="spread"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />

    <TextView
        android:id="@+id/tvB"
        android:layout_width="50dp"
        android:layout_height="50dp"
        android:background="#8BC34A"
        android:textColor="@color/white"
        android:gravity="center"
        android:text="B"
        app:layout_constraintEnd_toStartOf="@id/tvC"
        app:layout_constraintStart_toEndOf="@id/tvA"
        app:layout_constraintTop_toTopOf="parent" />

    <TextView
        android:id="@+id/tvC"
        android:layout_width="50dp"
        android:layout_height="50dp"
        android:background="#2196F3"
        android:textColor="@color/white"
        android:gravity="center"
        android:text="C"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toEndOf="@id/tvB"
        app:layout_constraintTop_toTopOf="parent" />

</android.support.constraint.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">

    <TextView
        android:id="@+id/tvA"
        android:layout_width="0dp"
        android:layout_height="50dp"
        android:background="#F44336"
        android:textColor="@color/white"
        app:layout_constraintHorizontal_weight="1"
        android:gravity="center"
        android:text="A"
        app:layout_constraintEnd_toStartOf="@id/tvB"
        app:layout_constraintHorizontal_chainStyle="spread_inside"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />

    <TextView
        android:id="@+id/tvB"
        android:layout_width="0dp"
        android:layout_height="50dp"
        android:background="#8BC34A"
        android:textColor="@color/white"
        app:layout_constraintHorizontal_weight="1"
        android:gravity="center"
        android:text="B"
        app:layout_constraintEnd_toStartOf="@id/tvC"
        app:layout_constraintStart_toEndOf="@id/tvA"
        app:layout_constraintTop_toTopOf="parent" />

    <TextView
        android:id="@+id/tvC"
        android:layout_width="0dp"
        android:layout_height="50dp"
        android:background="#2196F3"
        app:layout_constraintHorizontal_weight="2"
        android:textColor="@color/white"
        android:gravity="center"
        android:text="C"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toEndOf="@id/tvB"
        app:layout_constraintTop_toTopOf="parent" />

</android.support.constraint.ConstraintLayout>

七、辅助组件

1.GuideLine

即参考线的意思,有水平参考线和竖直参考线两种。他的作用就像是一个虚拟的参考线,只是用来方便其他View以他为锚点来布局。
如上一篇所了解到的,ConstraintLayout 的定位原则就是一个View参考其他View的相对布局,如果有的时候当前布局没有合适的参考View,而建一个专门用于定位的View又会太重,这种情况正是GuideLine的用武之地。
Guideline的大部分的属性如layout_width都是不会生效的,而他的位置的确定是由下面三个属性之一来确定的:

2.Group

Group是一个可以同时控制多个view 可见性的虚拟View。
可以向下面这样使用

  <android.support.constraint.Group
       ...
        android:visibility="invisible"
        app:constraint_referenced_ids="a,c" />

constraint_referenced_ids用来指定这个Group包好的view

参考文章

上一篇 下一篇

猜你喜欢

热点阅读