TableLayout表格布局,将子元素的位置分配到行或列中。TableLayout布局由许多的TableRow(行) 组成,它没有列的概念,列是由行中的控件数目决定的。TableLayout布局也是实际中常用的布局方式。
TableLayout布局不会显示行、列 、单元格的边框线。TableLayout布局应用如图7-17所示。
图7-17 TableLayout1
TableLayout布局文件请参考代码清单7-20,完整代码请参考chapter7_5工程中tablelayout1.xml代码部分(chapter7_5/res/layout/tablelayout1.xml)。
【代码清单7-20】
<?xml version="1.0" encoding="utf-8"?>
<TableLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent" android:layout_height="match_parent">
<TableRow>
<TextView android:text="@string/row1_1" android:padding="3dip" />
<TextView android:text="@string/row1_2" android:padding="3dip" />
<TextView android:text="@string/row1_3" android:padding="3dip" />
</TableRow>
<TableRow>
<TextView android:text="@string/row2_1" android:padding="3dip" />
<TextView android:text="@string/row2_2" android:padding="3dip" />
<TextView android:text="@string/row2_3" android:padding="3dip" />
</TableRow>
<TableRow>
<TextView android:text="@string/row3_1" android:padding="3dip" />
<TextView android:text="@string/row3_2" android:padding="3dip" />
<TextView android:text="@string/row3_3" android:padding="3dip" />
</TableRow>
<TableRow>
<TextView android:text="@string/row4_1" android:padding="3dip" />
<TextView android:text="@string/row4_2" android:padding="3dip" />
<TextView android:text="@string/row4_3" android:padding="3dip" />
</TableRow>
<TableRow>
<TextView android:text="@string/row5_1" android:padding="3dip" />
<TextView android:text="@string/row5_2" android:padding="3dip" />
<TextView android:text="@string/row5_3" android:padding="3dip" />
</TableRow>
<TableRow>
<TextView android:text="@string/row6_1" android:padding="3dip" />
<TextView android:text="@string/row6_2" android:padding="3dip" />
<TextView android:text="@string/row6_3" android:padding="3dip" />
</TableRow>
</TableLayout>
下面再看一个合并单元格TableLayou布局应用图7-18所示。
图7-18 TableLayout2
TableLayout布局文件请参考代码清单7-21,完整代码请参考chapter7_5工程中tablelayout2.xml代码部分(chapter7_5/res/layout/tablelayout2.xml)。
【代码清单7-21】
<?xml version="1.0" encoding="utf-8"?>
<TableLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent" android:layout_height="match_parent"
android:stretchColumns="0,1,2">
<TableRow>
<TextView android:text="@string/row1_1" android:padding="3dip" />
<TextView android:text="@string/row1_2" android:padding="3dip" />
<TextView android:text="row1_3" android:padding="3dip" />
</TableRow>
<TableRow>
<TextView android:text="@string/row2_1" android:padding="3dip" />
<TextView android:text="@string/row2_2" android:padding="3dip"
android:layout_span="2" android:background="#ff0060" />
</TableRow>
<TableRow>
<TextView android:text="@string/row3_1" android:padding="3dip" />
<!-- android:layout_column="1" -->
<TextView android:text="@string/row3_2" android:padding="3dip" />
<TextView android:text="row3_3" android:padding="3dip" />
</TableRow>
<TableRow>
<TextView android:text="@string/row4_1" android:padding="3dip" />
<TextView android:text="@string/row4_2" android:padding="3dip" />
<TextView android:text="row4_3" android:padding="3dip" />
</TableRow>
<TableRow>
<TextView android:text="@string/row5_1" android:padding="3dip" />
<TextView android:text="@string/row5_2" android:padding="3dip" />
<TextView android:text="row5_3" android:padding="3dip" />
</TableRow>
<TableRow>
<TextView android:text="@string/row6_1" android:padding="3dip" />
<TextView android:text="@string/row6_2" android:padding="3dip" />
<TextView android:text="row6_3" android:padding="3dip" />
</TableRow>
</TableLayout>
TableLayout标签内的android:stretchColumns="0,1,2"属性是第一列、第二列、第三列自动调节列宽。<TableRow>内的TextView控件中的属性android:layout_span="2"是合并一个单元格,如图7-18显示的粉色背景就是合并的单元格。
出自《Android开发案例驱动教程》第七章
7.5 TableLayout布局详解
原创
©著作权归作者所有:来自51CTO博客作者tony关东升的原创作品,请联系作者获取转载授权,否则将追究法律责任
提问和评论都可以,用心的回复会被更多人看到
评论
发布评论
相关文章
-
承前启后,Java对象内存布局和对象头JVM Java
-
【Android 布局】TableLayout(表格布局)
文章目录TableLayout(表格布局)1.TableLayout的介绍
android 布局 xml 返回顶部 -
GridLayout与TableLayout布局
记录下GridLayout与TableLayout布局的一些知识点,这两个布局对比起来弄,感觉明显比较更能加深印象。GridLayout的使用设置:GridLayout 布局
GridLayout TableLayout rowspan android sed -
【鸿蒙 HarmonyOS】UI 布局 ( 网格布局 TableLayout )
网格布局 TableLayout
鸿蒙 HarmonyOS 网格布局 TableLayout xml -
Android 基础知识4-2.8 TableLayout(表格布局)详解
表格布局是以行数和列数来确定位置进行排列。就像一间教室,确定好行数与列数就能让同学有序入座。注意:我们需要先添加
android android studio 学习 xml 布局文件