用FlexboxLayout构建灵活的布局
2017-03-01 14:08
567 查看
在去年的Google I/O大会上,Google发布了 ConstraintLayout他使我们能够使用一个平面的视图层次来构建复杂的界面布局。Android studio的视图编辑器也对其实现了完整支持。
与此同时,Google开源了FlexboxLayout 他与CSS
Flexible 布局模块具有相同的功能。接下来的例子我们将使用FlexboxLayout实现一些特殊的功能。
你可以把FlexboxLayout理解成一个高级的LinearLayout,他和LinearLayout一样都是在水平和垂直方向上按顺序放置子view,他与LinearLayout最大的不同在于FlexboxLayout 有一个wrapping功能。当你增加flexWrap=”wrap”属性后,假如在当前方向上没有足够的空间可以放置新的子view,他会在新的一行上放置子view。
我们想要在水平方向依次放置一些view,假如有效的空间发生变化后(不同的手机设备、手机方向发生改变、多窗口模式导致的界面重绘等)我们想要在新的一行继续放置上一行没有空闲空间显示的view。
如果你使用传统的布局方式来实现这个功能,如LinearLayout、RelativeLayout你需要定义多个 DP-bucket 布局(例如layout-600dp, layout-720dp, layout-1020dp)来处理多屏幕尺寸的问题。但是上边的对话框只使用了一个FlexboxLayout就实现了这个功能。
这个例子中使用了上边提到的flexWrap=”wrap”属性
2
3
4
5
1
2
3
4
5
你可以从Github上得到完整的布局文件
FlexboxLayout的另外一个好处是他能与RecyclerView结合使用,在最新发布的alpha版本提供了新的RecyclerView布局管理器FlexboxLayoutManager他继承自RecyclerView.LayoutManager,你现在可以用这种更加高效利用内存的方式在滚动容器里实现Flexbox功能。当然你也可以用ScrollView结合FlexboxLayout来达到在可滚动的容器中实现Flexbox功能,但是当容器中的子view数量很多的时候将会导致OutOfMemoryError的发生。事实上有许多可以用FlexboxLayout与RecyclerView结合使用的场景,比如Google
的Photos app 或新闻app。这两个应用都需要显示大量宽度不同的图片。
下边是一个例子,每一个显示在RecyclerView中的图片都有不同的宽度,我们设置flexWrap的值到wrap
2
1
2
然后设置flexGrow的值(这样就不用依次给每个item设置flexGrow值 )
2
3
4
5
6
7
8
9
1
2
3
4
5
6
7
8
9
效果如下:
可以看到无论是横屏还是竖屏都能很好的适配。
本篇文章就结束了,如果您有任何问题,欢迎与我联系。如果文中有错误的地方也欢迎您指证,我将不胜感激。
如果您想要查看完整的例子代码请查看:
Playground 例子app - 使用了FlexboxLayout和FlexboxLayoutManager实现
Cat gallery例子app - 使用FlexboxLayoutManager实现
本文参考自google官方文档 https://android-developers.googleblog.com/2017/02/build-flexible-layouts-with.html
与此同时,Google开源了FlexboxLayout 他与CSS
Flexible 布局模块具有相同的功能。接下来的例子我们将使用FlexboxLayout实现一些特殊的功能。
你可以把FlexboxLayout理解成一个高级的LinearLayout,他和LinearLayout一样都是在水平和垂直方向上按顺序放置子view,他与LinearLayout最大的不同在于FlexboxLayout 有一个wrapping功能。当你增加flexWrap=”wrap”属性后,假如在当前方向上没有足够的空间可以放置新的子view,他会在新的一行上放置子view。
同一布局适配多种屏幕尺寸
我们想要在水平方向依次放置一些view,假如有效的空间发生变化后(不同的手机设备、手机方向发生改变、多窗口模式导致的界面重绘等)我们想要在新的一行继续放置上一行没有空闲空间显示的view。如果你使用传统的布局方式来实现这个功能,如LinearLayout、RelativeLayout你需要定义多个 DP-bucket 布局(例如layout-600dp, layout-720dp, layout-1020dp)来处理多屏幕尺寸的问题。但是上边的对话框只使用了一个FlexboxLayout就实现了这个功能。
这个例子中使用了上边提到的flexWrap=”wrap”属性
<android.support.design.widget.TextInputLayout android:layout_width="100dp" android:layout_height="wrap_content" app:layout_flexgrow="1"> ......1
2
3
4
5
1
2
3
4
5
你可以从Github上得到完整的布局文件
与RecyclerView结合使用
FlexboxLayout的另外一个好处是他能与RecyclerView结合使用,在最新发布的alpha版本提供了新的RecyclerView布局管理器FlexboxLayoutManager他继承自RecyclerView.LayoutManager,你现在可以用这种更加高效利用内存的方式在滚动容器里实现Flexbox功能。当然你也可以用ScrollView结合FlexboxLayout来达到在可滚动的容器中实现Flexbox功能,但是当容器中的子view数量很多的时候将会导致OutOfMemoryError的发生。事实上有许多可以用FlexboxLayout与RecyclerView结合使用的场景,比如Google的Photos app 或新闻app。这两个应用都需要显示大量宽度不同的图片。
下边是一个例子,每一个显示在RecyclerView中的图片都有不同的宽度,我们设置flexWrap的值到wrap
FlexboxLayoutManager layoutManager = new FlexboxLayoutManager(); layoutManager.setFlexWrap(FlexWrap.WRAP);1
2
1
2
然后设置flexGrow的值(这样就不用依次给每个item设置flexGrow值 )
void bindTo(Drawable drawable) { mImageView.setImageDrawable(drawable); ViewGroup.LayoutParams lp = mImageView.getLayoutParams(); if (lp instanceof FlexboxLayoutManager.LayoutParams) { FlexboxLayoutManager.LayoutParams flexboxLp = (FlexboxLayoutManager.LayoutParams) mImageView.getLayoutParams(); flexboxLp.setFlexGrow(1.0f); } }1
2
3
4
5
6
7
8
9
1
2
3
4
5
6
7
8
9
效果如下:
可以看到无论是横屏还是竖屏都能很好的适配。
本篇文章就结束了,如果您有任何问题,欢迎与我联系。如果文中有错误的地方也欢迎您指证,我将不胜感激。
如果您想要查看完整的例子代码请查看:
Playground 例子app - 使用了FlexboxLayout和FlexboxLayoutManager实现
Cat gallery例子app - 使用FlexboxLayoutManager实现
本文参考自google官方文档 https://android-developers.googleblog.com/2017/02/build-flexible-layouts-with.html
相关文章推荐
- 用FlexboxLayout构建灵活的布局
- 使用ConstraintLayout构建一个灵活的布局
- Android可伸缩布局-FlexboxLayout(支持RecyclerView集成)
- Android可伸缩布局-FlexboxLayout(支持RecyclerView集成)
- 【Android 基础】Google新推出的Android布局控件FlexboxLayout
- 安卓开发进阶之弹性布局FlexboxLayout--Part3(翻译)
- FlexBoxLayout结合DBFlow实现流式布局
- [置顶] 使用FlexboxLayout完成优雅的布局
- FlexboxLayout_google开源布局_适配终结者
- Android开发之玩转FlexboxLayout布局
- Android可伸缩布局-FlexboxLayout(支持RecyclerView集成)
- FlexboxLayout——Android弹性布局
- Android FlexboxLayout 聪明的UI布局
- Android可伸缩布局-FlexboxLayout(支持RecyclerView集成)
- 安卓开发进阶之弹性布局FlexboxLayout--Part2(翻译)
- 流失布局Android FlexboxLayout
- Android之FlexboxLayout弹性布局的介绍
- Android布局-FlexboxLayout
- 使用约束布局(ConstraintLayout)构建灵活的UI
- Android FlexboxLayout UI布局