[置顶] 使用FlexboxLayout完成优雅的布局

时间:2021-10-14 16:31:08

去年 Google I/O 上发布了 ConstraintLayout使得在构建复杂布局的同时能够让视图层级得到精简。与此同时,也开源了 FlexboxLayout使得 Android 里的 CSS Flexible Layout 模块也能拥有同样强大的功能。

下面我们介绍几个例子来说明一下 FlexboxLayout 的得力之处。FlexboxLayout 可以理解为高级的 LinearLayout ,因为这两个布局都将其子视图按序排列。二者之间的重要差异在于 FlexboxLayout 具有 “换行” 的特性。 同时FlexboxLayout还为RecycleView提供了管理器FlexboxLayoutManager,使得FlexboxLayout更加强大了。

使用

项目中添加依赖

compile 'com.google.android:flexbox:0.2.6'

FlexboxLayout 如果您加入 flexWrap=“wrap” 属性,且当前行中剩余空间不够的话,FlexboxLayout 就会将视图放进新行中,可以优雅的实现流式布局 如下图所示:

一种布局适配各种屏幕尺寸
[置顶]        使用FlexboxLayout完成优雅的布局

另外一个需要强调的做法就是将 layout_flexGrow 属性设置到一个独立的子项上。这有助于在有可用空间剩余时优化最终布局的观感。layout_flexGrow 属性的运作原理类似于 LinearLayout 中的 layout_weight 属性。这意味着 FlexboxLayout 将根据 layout_flexGrow 设置的值,为同一行中的每个子项分配剩余空间 。
[置顶]        使用FlexboxLayout完成优雅的布局

与 RecyclerView 结合使用

如果是在RecycleView中使用则添加

compile 'com.google.android:flexbox:0.3.0-alpha3'

Alpha版本包括RecyclerView的集成

FlexboxLayout 的另一个优点是,它可以与 RecyclerView 结合使用。随着最新 alpha 版的发布,新版 Flexbox 布局管理器对 RecyclerView 布局管理器进行了扩展,现在您可以用更高效利用内存的方式,在可滚动容器中使用 Flexbox 的功能。

请注意,您现在仍然可以使用 ScrollView 结合 FlexboxLayout 的方式在可滚动容器中实现 flexbox 功能。但是,如果布局中包含的项目数量过大,您可能会遭遇一些故障,甚至出现内存不足的情况。因为 FlexboxLayout 在用户进行滚动操作导致视图被移出屏幕时不会考虑到视图循环。

一个真实的案例,与 RecyclerView 结合使用对于 Google Photos 、News 这些应用来说十分重要,因为它们都需要处理大量项目,并且项目的种类非常繁多。

在 FlexboxLayout 存储库里有这么一个示例,RecyclerView 中显示的每个图像的宽度都不相同,但是通过将 flexWrap 配置设置为 wrap:

并将每个子项的 flexGrow 设为正值:(如您所见,您可以通过 Flexbox布局管理器 和 Flexbox 布局管理器的 LayoutParams 为子项配置属性,而非从 xml 配置它)

[置顶]        使用FlexboxLayout完成优雅的布局