FlexboxLayout
是16
年 Google I/O
上开源的一个布局控件,使得 Android 里的 CSS Flexible Layout
模块也能拥有一样强大的功能。同时还发布了强大的ConstraintLayout
,感兴趣的同窗能够去看看 Android ConstraintLayout 详解。FlexboxLayout
能够理解为高级的 LinearLayout
,由于这两个布局都将其子视图按序排列。两者之间的重要差别在于 FlexboxLayout
具备 换行 的特性。同时 FlexboxLayout
还为 RecycleView
提供了管理器 FlexboxLayoutManager
,使得 FlexboxLayout
更增强大了。android
FlexboxLayout
项目开源地址:flexbox-layoutgit
本篇文章demo源码地址:FlexboxLayoutDemogithub
dependencies {
//FlexboxLayout
implementation 'com.google.android:flexbox:1.0.0'
}
复制代码
注意:从1.1.0开始,这个库将与AndroidX一块儿使用。若是您使用1.1.0或以上版本,请迁移到AndroidX。 若是您尚未迁移到AndroidX,请使用1.0.0。bash
XML布局文件app
<com.google.android.flexbox.FlexboxLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/flexbox_layout"
android:layout_width="match_parent"
android:layout_height="match_parent">
<TextView
android:id="@+id/textview1"
android:layout_width="120dp"
android:layout_height="20dp"
android:layout_margin="2dp"
android:background="#43eeff"
android:gravity="center"
android:text="1"/>
<TextView
android:id="@+id/textview2"
android:layout_width="120dp"
android:layout_height="60dp"
android:layout_margin="2dp"
android:background="#ef3344"
android:gravity="center"
android:text="2"/>
<TextView
android:id="@+id/textview3"
android:layout_width="120dp"
android:layout_height="90dp"
android:layout_margin="2dp"
android:background="#ee998f"
android:gravity="center"
android:text="3"/>
<TextView
android:id="@+id/textview4"
android:layout_width="120dp"
android:layout_height="100dp"
android:layout_margin="2dp"
android:background="#eeff22"
android:gravity="center"
android:text="4"/>
<TextView
android:id="@+id/textview5"
android:layout_width="120dp"
android:layout_height="80dp"
android:layout_margin="2dp"
android:background="#3322ff"
android:gravity="center"
android:text="5"/>
</com.google.android.flexbox.FlexboxLayout>
复制代码
运行后的效果以下图:ide
咱们能够看到并无换行,和咱们使用 LinearLayout
并无区别,接下来咱们看下 FlexboxLayout
的一些经常使用属性。工具
flexDirection
属性决定主轴项目排列方向。相似 LinearLayout
的 vertical
和 horizontal
,可是 FlexboxLayout
更增强大,不只支持横向和纵向还能够设置不一样的排列的起点。布局
row
(默认值):主轴为水平方向,起点在左端。row_reverse
:主轴为水平方向,起点在右端。column
:主轴为垂直方向,起点在上沿。column_reverse
:主轴为垂直方向,起点在下沿。下面咱们在xml中添加 flexDirection
属性,并设置起点在下端:学习
app:flexDirection="column_reverse"
复制代码
运行后的效果以下图:flex
能够看到项目是从底部开始由下而上排列的。
默认 FlexboxLayout
和 LinearLayout
同样是不带换行属性的,可是 flexWrap
属性能够支持换行排列。这就是 FlexboxLayout
方便的地方了。换行方式有两种,一种是按项目排列方向换行,一种是反方向换行。
nowrap
(默认):不换行。
wrap
:按正常方向换行。
wrap_reverse
:按反方向换行。
下面咱们在xml中添加 flexWrap
属性,按照正常方向换行:
app:flexWrap="wrap"
复制代码
运行后的效果以下图:
justifyContent
属性定义了项目在主轴上的对齐方式。
flex_start
(默认值):左对齐。
flex_end
:右对齐。
center
: 居中。
space_between
:两端对齐,项目之间的间隔都相等。
space_around
:每一个项目两侧的间隔相等。项目之间的间隔比项目与边框的间隔大一倍。
下面咱们在xml中添加 justifyContent
属性,设置右对齐:
app:justifyContent="flex_end"
复制代码
运行后的效果以下图:
若是须要在项目的排列方向上均分剩余的空间怎么办呢?很简单space_around
属性就是这样的,效果以下图
alignItems
属性定义项目在副轴轴上如何对齐,咱们经过一张图来了解这个属性比较直观一点。
flex_start
:交叉轴的起点对齐。
flex_end
:交叉轴的终点对齐。
center
:交叉轴的中点对齐。
baseline
: 项目的第一行文字的基线对齐。
stretch
(默认值):若是项目未设置高度或设为auto,将占满整个容器的高度。
这也是为何咱们的每个项目的高度都是不相同的,可是能够看到前面每一个项目的高度都是同样的,由于默认属性 stretch
让每一个项目的高度设置为了填满容器的高度(这里的高度是指同一轴上的最高高度) 如今咱们设置对齐方式为中心对齐,添加属性:
app:alignItems="center"
复制代码
运行后的效果以下图:
能够看到是根据每一个项目的中心对齐,这里单独说一下baseline
属性,熟悉ConstraintLayout
的同窗应该比较好理解这个属性,其实就是按照项目内的文本线来对齐项目。效果以下
能够看到项目对齐是按照项目内的文本基线来对齐的。很好理解!须要注意的是项目中若是有的没有文本基线,那么默认他的基线就是左上角也就是起点左右位置。
alignContent
属性定义了多根轴线的对齐方式。若是项目只有一根轴线,该属性不起做用。
flex_start
:与交叉轴的起点对齐。
flex_end
:与交叉轴的终点对齐。
center
:与交叉轴的中点对齐。
space_between
:与交叉轴两端对齐,轴线之间的间隔平均分布。
space_around
:每根轴线两侧的间隔都相等。因此,轴线之间的间隔比轴线与边框的间隔大一倍。
stretch
(默认值):轴线占满整个交叉轴。
alignContent
和 justifyContent
其实里面的属性值都是同样的 ,一个是设置主轴的对齐方式,一个是设置多个轴的对齐方式,通俗的讲能够理解为好比是项目是水平换行,justifyContent
就是设置垂直方向的对齐方式,若是项目是垂直方向对齐方式,那么justifyContent
就是设置水平方向的对齐方式。如今咱们想让每一个项目距离上右下左的距离是同样的,须要把alignContent
和justifyContent
都设置为space_around
就能够了。
app:alignContent="space_around"
app:justifyContent="space_around"
复制代码
运行后的效果以下图:
showDividerHorizontal
控制显示水平方向的分割线,值为none
| beginning
| middle
| end
其中的一个或者多个。
dividerDrawableHorizontal
设置Flex 轴线之间水平方向的分割线。
showDividerVertical
控制显示垂直方向的分割线,值为none
| beginning
| middle
| end
其中的一个或者多个。
dividerDrawableVertical
设置子元素垂直方向的分割线。
showDivider
控制显示水平和垂直方向的分割线,值为none
| beginning
| middle
| end
其中的一个或者多个。
dividerDrawable
设置水平和垂直方向的分割线,可是注意,若是同时和其余属性使用,好比为 Flex 轴、子元素设置了justifyContent="space_around"
、alignContent="space_between"
等等。可能会看到意料不到的空间,所以应该避免和这些值同时使用。
除以上以外,FlexboxLayout
不只有自身的属性,还能够设置子元素的属性。这也是 FlexboxLayout
能完成聪明布局的缘由之一。
默认状况下子元素的排列方式按照文档流的顺序依次排序,而 order
属性能够控制排列的顺序,负值在前,正值在后,按照从小到大的顺序依次排列。简而言之就是你能够定义子元素的排列顺序。
咱们给子元素加上 order
属性而且自定义他们的顺序。
layout_flexGrow
属性定义项目的放大比例,默认为0
,即若是存在剩余空间,也不放大。其实就是 LinearLayout
中的weight
属性,若是全部项目的layout_flexGrow
属性都为1
,则它们将等分剩余空间。若是一个项目的layout_flexGrow
属性为2
,其余项目都为1
,则前者占据的剩余空间将比其余项多一倍。
layout_flexShrink
属性定义了项目的缩小比例,默认为1
,即若是空间不足,该项目将缩小(设置了换行则无效)。若是全部项目的 layout_flexShrink
属性都为1
,当空间不足时,都将等比例缩小。若是一个项目的 flex-shrink
属性为0
,其余项目都为1
,则空间不足时,前者不缩小。负值对该属性无效。
layout_alignSelf
属性容许单个子元素有与其余子元素不同的对齐方式,可覆盖 alignItems
属性。默认值为auto
,表示继承父元素的 alignItems
属性,若是没有父元素,则等同于stretch
。
auto
(default)
flex_start
flex_end
center
baseline
stretch
该属性可能取6个值,除了auto
,其余都与align_items
属性彻底一致,咱们设置alignItems
为flex_start
属性,其中一个子元素设置layout_alignSelf
属性为baseline
。
baseline
的基线是第一个元素的 baseline
基线。
layout_flexBasisPercent
属性定义了在分配多余空间以前,子元素占据的主轴空间的百分比。它的默认值为auto
,即子元素的原本大小。
咱们设置第一个和第三个都占据的主轴空间的80%,给子元素添加属性
app:layout_flexBasisPercent
复制代码
FlexboxLayout
的属性基本讲解完了,若是一脸懵逼那么请 看第二遍。FlexboxLayout
能帮你完成各类你须要的布局,可谓 LinearLayout
的增强版。好比咱们须要作一个相似于Tag标签的布局,那么 FlexboxLayout
能帮你轻轻松松实现。这里须要用到 FlexboxLayoutManager
,也就是 FlexboxLayout
对 RecycleView
提供的布局管理器 布局中添加RecycleView。
<android.support.v7.widget.RecyclerView
android:id="@+id/recyclerView"
android:layout_width="match_parent"
android:layout_height="match_parent"/>
复制代码
代码中对RecycleView添加布局管理器,并设置 FlexboxLayout
的主属性
RecyclerView recyclerView = findViewById(R.id.recyclerView);
FlexboxLayoutManager flexboxLayoutManager = new FlexboxLayoutManager(this);
flexboxLayoutManager.setFlexWrap(FlexWrap.WRAP);
flexboxLayoutManager.setFlexDirection(FlexDirection.ROW);
flexboxLayoutManager.setAlignItems(AlignItems.STRETCH);
flexboxLayoutManager.setJustifyContent(JustifyContent.FLEX_START);
recyclerView.setLayoutManager(flexboxLayoutManager);
复制代码
运行后的效果以下图:
轻轻松松实现了Tag标签的效果,是否是很简单,一样的方式咱们还能够实现一个图片流布局。
FlexboxLayout
的使用如今已经讲解完了,相信各位对这个控件的强大已经有所了解了,不妨亲自动手感觉下这个控件的强大。Google开放了愈来愈多的控件和开发辅助工具,对于开发者的咱们来讲固然是好的。固然咱们本身也要保持一颗热爱学习的心,不要抗拒新的东西,不断学习 充实本身! 知行合一。