线性布局,表格布局、帧布局和相对布局的介绍参看上一篇博文:
Android的布局管理器(上篇)
- 网格布局
- 绝对布局
网格布局
- 网格布局由GridLayout类表示,它是Android4.0新增的布局管理器。如果希望在更早的Android平台上使用该布局管理器,则需要导入相应支撑库。
- GridLayout的作用类似HTML中的table标签,它把整个容器划分成rows × Columns个网格,每个网格可以放置一个组件,除此之外也可以设置一个组件横跨多少列,一个组件纵跨多少行。
参考:浅谈android4.0开发之GridLayout布局
如果需要设置某控件跨越多行或多列,只需将该子控件的android:layout_rowSpan或者layout_columnSpan属性设置为数值,再设置其layout_gravity属性为fill即可,前一个设置表明该控件跨越的行数或列数,后一个设置表明该控件填满所跨越的整行或整列。
GridLayout的常用属性
- android:alignmentMode 设置该布局管理器采用的对齐模式
- android:columnCount 设置该网格的列数量
- android:columnOrderPreserved 设置该网格布局管理器是否保留列序号
- android:rowCount 设置该网格的行数目
- android:rowOrderPreserved 设置该网格布局管理器是否保留行序号
- android:useDefaultMargins 设置布局管理器是否使用默认的页边距
GridLayout.LayoutParams常用属性
- android:layout_column 设置该子组件在GridLayout的第几列
- android:layout_columnSpan 设置该子组件在GridLayout横向上跨几行
- android:layout_gravity 设置该子组件采用何种方式占据该网格的空间
- android:layout_row 设置该子组件在GridLayout的第几行
- android:layout_rowSpan 设置该子组件在GridLayout纵向上跨几行
xml示例
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
>
<GridLayout
android:columnCount="4"
android:rowCount="7"
android:layout_gravity="bottom"
android:layout_width="match_parent"
android:layout_height="wrap_content"
>
<TextView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_columnSpan="4"
android:paddingBottom="30dp"
android:paddingLeft="16dp"
android:paddingTop="30dp"
android:text="22 * 10"
android:textSize="30sp"
android:textStyle="bold" />
<Button
style="@style/Base.Widget.AppCompat.Button.Borderless.Colored"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_columnSpan="4"
android:layout_gravity="right"
android:layout_margin="5dp"
android:text="clear" />
<Button
style="@style/Base.Widget.AppCompat.Button.Borderless.Colored"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_column="0"
android:layout_gravity="left"
android:layout_margin="5dp"
android:layout_row="2"
android:background="#fff8f8"
android:text="7" />
<Button
style="@style/Base.Widget.AppCompat.Button.Borderless.Colored"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_column="1"
android:layout_margin="5dp"
android:layout_row="2"
androi