Android随笔——搞定流动布局(FlexboxLayout)

简介: 转载请标明地址 QuincySx:[http://www.jianshu.com/p/fbeb3808a17f]简介FlexboxLayout 是 Google 推出的一个布局,它的作用就和 LinearLayout 相似,如果只是功能相似的...

转载请标明地址 QuincySx:[http://www.jianshu.com/p/fbeb3808a17f]


简介

FlexboxLayout 是 Google 推出的一个布局,它的作用就和 LinearLayout 相似,如果只是功能相似的话,那个谷歌就没有推出他的必要性了,他是一个聪明的布局,他和LinearLayout最大的区别就是能够换行,并且可以和 RecyclerView 无缝使用,今天我们就一点点的来介绍一下这个布局

使用方式

  1. 添加依赖 compile 'com.google.android:flexbox:0.3.0'

2.在布局中使用

<com.google.android.flexbox.FlexboxLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent">
</com.google.android.flexbox.FlexboxLayout>

这个布局的最新版本、用法大家可以去 Github 上去看,点这里

注: 0.3.0 或以上版本才可以与 RecyclerView 配合使用

主要的几个属性

flexDirection 属性

这个属性的作用就和 LinearLayoutorientation 属性类似,用来控制视图显示是横向还是竖向
row:默认值 表示横向排列
row_reverse:表示横向排列,但是是从右往左排
column:表示竖向排列
column_reverse:表示竖向排列,从下到上排列

flexWrap 属性

这个属性是表示换不换行,因为这个控件默认是不会换行的
nowrap:默认值 不会换行
wrap:换行
wrap:换行,但是排列顺序是反的

alignItems 属性

这是属性是表示各个 View 的对齐方式,这个控件默认的对齐方式是 View 高或宽是一样的,怎讲呢,如果你的排列方式是横向的,那么每个子控件的宽都是一样宽的,但是你的排列方式是竖向的,那么每个子控件的高是相同的
stretch:默认值 表示子控件的高或宽相同
flex_start:左对齐/上对齐 这里它是根据 flexDirection 属性的值不同会有响应变化
flex_end:右对齐/下对齐
center:根据中线居中对齐
baseline:根据内容对齐,和 ConstraintLayout 里面那个对齐有一点类似的意思

justifyContent 属性

这个属性是表示在主轴上的排列方式,再控件无法排列满整个布局时
flex_start:默认值 整体控件都连在一起排列在上方,或下方
center:控件都连在一起,居中排列
flex_end:整体控件都连在一起排列在上方,或下方
space_around:控件都分散开排列,第一个控件,与最后一个控件与父容器有间隔
space_between:遇上一个属性类似,差别在第一个控件,与最后一个控件是贴在父容器边上的

alignContent 属性

此属性与上一个属性是类似的,当开启了换行,由于显示了多行主轴就可能发生了变化,所以效果也会产生变换,当前这个属性就是针对多轴的情况而使用的属性
flex_start:默认值 整体控件都连在一起排列在上方,或下方
center:控件都连在一起,居中排列
flex_end:整体控件都连在一起排列在上方,或下方
space_around:控件都分散开排列,第一个控件,与最后一个控件与父容器有间隔
space_between:遇上一个属性类似,差别在第一个控件,与最后一个控件是贴在父容器边上的

目录
相关文章
|
9月前
|
XML Android开发 数据安全/隐私保护
10. 【Android教程】网格布局 GridLayout
10. 【Android教程】网格布局 GridLayout
368 1
|
5月前
|
ARouter Android开发
Android不同module布局文件重名被覆盖
Android不同module布局文件重名被覆盖
|
7月前
|
移动开发 监控 前端开发
构建高效Android应用:从优化布局到提升性能
【7月更文挑战第60天】在移动开发领域,一个流畅且响应迅速的应用程序是用户留存的关键。针对Android平台,开发者面临的挑战包括多样化的设备兼容性和性能优化。本文将深入探讨如何通过改进布局设计、内存管理和多线程处理来构建高效的Android应用。我们将剖析布局优化的细节,并讨论最新的Android性能提升策略,以帮助开发者创建更快速、更流畅的用户体验。
106 10
|
9月前
|
Android开发
08. 【Android教程】相对布局 RelativeLayout
08. 【Android教程】相对布局 RelativeLayout
134 0
|
5月前
|
ARouter Android开发
Android不同module布局文件重名被覆盖
Android不同module布局文件重名被覆盖
299 0
|
7月前
|
编解码 Android开发
【Android Studio】使用UI工具绘制,ConstraintLayout 限制性布局,快速上手
本文介绍了Android Studio中使用ConstraintLayout布局的方法,通过创建布局文件、设置控件约束等步骤,快速上手UI设计,并提供了一个TV Launcher界面布局的绘制示例。
158 1
|
8月前
|
Android开发 Kotlin
kotlin开发安卓app,如何让布局自适应系统传统导航和全面屏导航
使用`navigationBarsPadding()`修饰符实现界面自适应,自动处理底部导航栏的内边距,再加上`.padding(bottom = 10.dp)`设定内容与屏幕底部的距离,以完成全面的布局适配。示例代码采用Kotlin。
198 15
|
7月前
|
XML 数据可视化 API
Android经典实战之约束布局ConstraintLayout的实用技巧和经验
ConstraintLayout是Android中一款强大的布局管理器,它通过视图间的约束轻松创建复杂灵活的界面。相较于传统布局,它提供更高灵活性与性能。基本用法涉及XML定义约束,如视图与父布局对齐。此外,它支持百分比尺寸、偏移量控制等高级功能,并配有ConstraintSet和编辑器辅助设计。合理运用可显著提高布局效率及性能。
368 0
|
7月前
|
Android开发
AutoX——当Android中clickable属性显示为false,实际可点击的布局如何处理
AutoX——当Android中clickable属性显示为false,实际可点击的布局如何处理
100 0
|
8月前
|
XML Android开发 数据安全/隐私保护
使用RelativeLayout布局Android界面
使用RelativeLayout布局Android界面