ConstraintLayout简单效果

简介: ConstraintLayout简单效果

多个功能使用方法


基线对齐

  1. xml

基线对齐xml

  1. 属性
layout_constraintBaseline_toBaselineOf
复制代码
  1. 效果

image.png


角度约束

  1. xml

角度约束xml

  1. 属性
app:layout_constraintCircle="@id/iv_cycle_main"
        app:layout_constraintCircleAngle="45"
        app:layout_constraintCircleRadius="200dp"
复制代码
  1. 效果

image.png


百分百偏移

  1. xml

百分比偏移

  1. 属性
app:layout_constraintVertical_bias="0.3"
        app:layout_constraintHorizontal_bias="0.2"
复制代码
  1. 效果

image.png


gone margin隐藏时的边距

  1. xml

xml

  1. 属性
app:layout_goneMarginLeft="100dp"
        app:layout_goneMarginTop="200dp"
复制代码
  1. 效果

image.png


设置控件尺寸spread撑满水平剩余宽度

  1. xml

xml2. 属性

app:layout_constraintWidth_default="spread"
        app:layout_constraintHeight_default="spread"
复制代码
  1. 效果

image.png


控件百分百宽度

  1. xml

xml

  1. 属性
app:layout_constraintWidth_percent="0.5"
复制代码
  1. 效果

image.png


根据宽高比设置控件尺寸

  1. xml

xml

  1. 属性
app:layout_constraintDimensionRatio="1:2"
复制代码
  1. 效果

image.png


将多个控件链式布局

  1. xml

xml

  1. 属性
app:layout_constraintHorizontal_chainStyle="spread"
复制代码
  1. 效果

image.png


GuideLine辅助线的使用

  1. xml

xml

  1. 属性
<androidx.constraintlayout.widget.Guideline
        android:id="@+id/guideline"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:orientation="vertical"
        app:layout_constraintGuide_percent="0.2"
        />
复制代码
  1. 效果

image.png


控件分组后同步显示或隐藏

  1. xml

xml

  1. 属性
<androidx.constraintlayout.widget.Group
        android:id="@+id/tv_group"
        app:constraint_referenced_ids="iv_group1,iv_group2,iv_group3"
        android:layout_width="wrap_content"
        android:visibility="visible"
        android:layout_height="wrap_content"/>
复制代码
  1. 效果


placeholder使用,点击图标展示效果

  1. xml

xml

  1. 属性
<androidx.constraintlayout.widget.Placeholder
        android:id="@+id/place1"
        android:layout_width="200dp"
        android:layout_height="200dp"
        app:layout_constraintRight_toRightOf="parent"
        app:layout_constraintBottom_toBottomOf="parent"
        />
复制代码
  1. 效果

点击图标,机器人图标会从左上角移动到右下角的站位位置

image.png


flow_wrapMode实现链约束

  1. xml

xml

  1. 属性
<androidx.constraintlayout.helper.widget.Flow
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        app:constraint_referenced_ids="tvFlow1,tvFlow2,tvFlow3,tvFlow4,tvFlow5"
        app:layout_constraintLeft_toLeftOf="parent"
        app:flow_wrapMode="chain"
        app:layout_constraintTop_toTopOf="parent" />
复制代码
  1. 效果

image.png


flow_wrapMode链约束中对每一行、第一行、最后一行设置链约束

  1. xml

xml

  1. 属性
<androidx.constraintlayout.helper.widget.Flow
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        app:constraint_referenced_ids="tvFlow1,tvFlow2,tvFlow3,tvFlow4,tvFlow5"
        app:layout_constraintLeft_toLeftOf="parent"
        android:orientation="horizontal"
        app:flow_horizontalGap="20dp"
        app:flow_wrapMode="chain"
        app:flow_horizontalStyle="spread_inside"
        app:flow_lastHorizontalStyle="packed"
        app:layout_constraintTop_toTopOf="parent" />
复制代码
  1. 效果

image.png


流式布局中的对齐约束flow_verticalAlign、flow_horizontalAlign

  1. xml

xml

  1. 属性
<androidx.constraintlayout.helper.widget.Flow
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        app:constraint_referenced_ids="tvFlow1,tvFlow2,tvFlow3,tvFlow4,tvFlow5"
        app:layout_constraintLeft_toLeftOf="parent"
        app:flow_verticalAlign="top"
        app:flow_wrapMode="chain"
        app:layout_constraintTop_toTopOf="parent" />
复制代码
  1. 效果

image.png


流式布局中的数量约束flow_maxElementsWrap

  1. xml

xml

  1. 属性
<androidx.constraintlayout.helper.widget.Flow
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        app:constraint_referenced_ids="tvFlow1,tvFlow2,tvFlow3,tvFlow4,tvFlow5"
        app:layout_constraintLeft_toLeftOf="parent"
        app:flow_wrapMode="chain"
        app:flow_maxElementsWrap="3"
        app:layout_constraintTop_toTopOf="parent" />
复制代码
  1. 效果

image.png


使用Layer图层设置多个控件的组合背景

  1. xml

xml

  1. 属性
<androidx.constraintlayout.helper.widget.Layer
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:background="@drawable/shp_round"
        android:padding="10dp"
        app:constraint_referenced_ids="tv_head,tv_footer,tv_left,tv_right"
        tools:ignore="MissingConstraints" />
复制代码
  1. 效果

image.png


图片处理器ImageFilterView

  1. xml

xml

  1. 属性
app:altSrc="@drawable/shp_round"
        app:crossfade="0.5"
        app:roundPercent="1"
复制代码
  1. 效果

image.png


画出类似原型图的控件

  1. xml

xml

  1. 属性
<androidx.constraintlayout.utils.widget.MockView
        android:id="@+id/mock_icon"
        android:layout_width="100dp"
        android:layout_height="100dp"
        app:layout_constraintLeft_toLeftOf="parent"
        app:layout_constraintTop_toTopOf="parent"
        app:layout_constraintBottom_toBottomOf="parent"
        android:layout_marginLeft="14dp"
        />
复制代码
  1. 效果

image.png


屏障(将屏障两侧的view分隔开布局)

  1. xml

xml

  1. 属性
<androidx.constraintlayout.widget.Barrier
        android:id="@+id/barrier"
        android:layout_width="wrap_content"
        app:barrierDirection="end"
        app:constraint_referenced_ids="tv_access,tv_about"
        android:layout_height="wrap_content"/>
复制代码
  1. 效果

image.png



相关文章
|
6月前
|
Android开发
ConstraintLayout 的使用
ConstraintLayout 的使用
46 1
ConstraintLayout 的使用
|
5月前
|
Android开发 开发者
深入了解 Android 中的 RelativeLayout 布局
深入了解 Android 中的 RelativeLayout 布局
|
缓存 Android开发
Android TabLayout的使用详解
Android TabLayout的使用详解
135 0
|
Android开发
Android ConstraintLayout
Android ConstraintLayout
102 0
|
XML Android开发 数据格式
Android TabLayout的使用与总结
最近的新项目里老是会用到tablayout,便想着自己也总结下,加深印象,于是他来啦!
|
XML Android开发 数据格式
|
XML 数据可视化 Android开发
ConstraintLayout (这到底是什么)
本文讲的是ConstraintLayout (这到底是什么),我想先讨论一下我在学习这个很酷的布局时的经验。当 Google 发布这个布局后我就开始学习了,在这个过程中我遇到了很多的问题。我想找一些优秀的教程,但是结果都是一些教我在可视化编辑器里拖拽图片的东西,这些对我一点用都没有。
1176 0
|
Android开发
Android CoordinatorLayout(一) 初探CoordinatorLayout
相信很多人用过CoordinatorLayout或了解过这个控件,这次我们来聊聊这个让人又爱又恨的控件。对我来说,爱是因为它的“协调”功能灰常66666,很是因为有时候滑动真的是卡。
1226 0
|
Android开发
Android CoordinatorLayout 导文
之前写了一篇seekbar做滑动验证,想不到会有人支持,其实我自己觉得写得不是很好,包括做的也不是很好,但是还是有人给我点赞,真的感觉很开心,之后也会更用心的去写文章。
967 0