跳到主要内容

FlexboxLayout弹性盒子布局

说明

Flex是Flexible Box的缩写,意为「弹性布局」,在前端css样式中应用甚为广泛,之前做过React-Native和微信小程序,页面布局大多使用flex弹性布局,可以在不同屏幕尺寸上提供一致的布局结构,可以简便、完整、响应式地实现各种页面布局,今天为大家打开Android移动端的flex布局大门--FlexboxLayout,在android中我们经常所见的标签、流式布局等都可以用FlexboxLayout来实现

使用示例

<?xml version="1.0" encoding="utf-8"?>
<ScrollView xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:android="http://schemas.android.com/apk/res/android"
xsi:noNamespaceSchemaLocation="layout.xsd"
android:background="#333333"
android:layout_height="match_parent"
android:layout_width="match_parent">
<FlexboxLayout android:layout_height="200dp"
android:layout_width="match_parent"
android:background="#888888"
android:flexDirection="row"
android:flexWrap="wrap">

<Button android:layout_width="wrap_content"
android:layout_weight="1"
android:layout_order="1"
android:layout_flexGrow="20.0"
android:layout_flexShrink="20.0"
android:layout_alignSelf="auto"
android:layout_height="wrap_content"
android:text="1"/>

<Button android:layout_width="wrap_content"
android:layout_weight="1"
android:layout_height="wrap_content"
android:text="2"/>

<Button android:layout_width="wrap_content"
android:layout_weight="1"
android:layout_height="wrap_content"
android:text="3"/>

<Button android:layout_width="wrap_content"
android:layout_weight="1"
android:layout_height="wrap_content"
android:text="4"/>

<Button android:layout_width="wrap_content"
android:layout_weight="1"
android:layout_height="wrap_content"
android:text="5"/>
<Button android:layout_width="wrap_content"
android:layout_weight="1"
android:layout_height="wrap_content"
android:text="6"/>
</FlexboxLayout>
</ScrollView>

属性说明

公有属性

请参考 公有属性

私有属性

属性名说明可选值
flexDirection属性决定主轴的方向(即内部子元素的排列方向)row(默认值):水平显示,起点在左端
row_reverse:水平显示,起点在右端,与row相反的顺序
column:垂直显示,起点在顶部
column_reverse:垂直显示,起点在底部,与column相反的顺序
xml中使用app:flexDirection="row",代码中使用flexboxLayout.setFlexDirection(FlexDirection.ROW)
flexWrap决定是否换行nowrap(默认值):不换行
wrap:按正常方向换行,第一行在上方
wrap_reverse:按反方向换行,第一行在下方 /
justifyContent决定元素在主轴上的对齐方式flex_start(默认值):主轴方向起点对齐
flex_end:主轴方向终点对齐
center: 主轴方向居中对齐
space_between:主轴方向两端对齐,元素之间的间隔都相等
space-around:每个元素两侧的间隔相等所以,元素之间的间隔比元素与布局边框的间隔大一倍 /
更多属性参考 https://www.cnblogs.com/taixiang/p/9177215.html/