Android开发网

首页|Android开发环境|Android开发教程|Android开发视频|Android游戏开发|Android开发实例|Android开发书籍|鸡啄米博客

Android学习指南之七:表格布局TableLayout

       前面两节讲了常用Layout之FrameLayout、LinearLayout绝对布局AbsoluteLayout和相对布局RelativeLayout,本文继续讲另一种比较常用的布局--表格布局。

       表格布局简介

       表格布局TableLayout以行列的形式管理子元素,每一行是一个TableRow布局对象,当然也可以是普通的View对象,TableRow离每放一个元素就是一列,总列数由列数最多的那一行决定。

       表格布局实例

       我们看一个例子:

XML/HTML代码
  1. <?xml version=”1.0″ encoding=”utf-8″?>  
  2. <TableLayout android:id=”@+id/TableLayout01″   
  3. android:layout_width=”fill_parent” android:layout_height=”fill_parent”   
  4. android:stretchColumns=”0″ xmlns:android=”http://schemas.android.com/apk/res/android”><TableRow android:layout_width=”fill_parent”   
  5. android:layout_height=”20dip”>  
  6. <TextView android:text=”色彩透明度测试” android:textSize=”18dip”   
  7. android:layout_span=”2″ 合并两列   
  8. android:layout_gravity=”center”   
  9. android:layout_width=”fill_parent” android:layout_height=”fill_parent”>  
  10. </TextView>  

       再看一下显示效果:

Android学习指南之七:表格布局TableLayout

       其中 android:stretchColumns=”0″ 作用是让第一列可以扩展到所有可用空间;下面我们讲一下TableLayout几个重要的属性:

       collapseColumns – 设置隐藏那些列,列ID从0开始,多个列的话用”,”分隔。

       stretchColumns – 设置自动伸展那些列,列ID从0开始,多个列的话用”,”分隔。

       shrinkColumns -设置自动收缩那些列,列ID从0开始,多个列的话用”,”分隔。

       可以用”*”来表示所有列,同一列可以同时设置为shrinkable和stretchable。

       我们再举一个例子来看一下:

XML/HTML代码
  1. <?xml version=”1.0″ encoding=”utf-8″?>  
  2. <TableLayout xmlns:android=”http://schemas.android.com/apk/res/android”   
  3. android:layout_width=”fill_parent”   
  4. android:layout_height=”fill_parent”   
  5. android:stretchColumns=”1″>   第二列自动伸展<TableRow>  
  6. <TextView  
  7. android:layout_column=”1″     我是第二列   
  8. android:text=”打开…”   
  9. android:padding=”3dip” /> 元素内容与边界之间保留3dip的距离   
  10. <TextView  
  11. android:text=”Ctrl-O”   
  12. android:gravity=”right”   
  13. android:padding=”3dip” />  
  14. </TableRow><TableRow>  
  15. <TextView  
  16. android:layout_column=”1″   
  17. android:text=”保存…”   
  18. android:padding=”3dip” />  
  19. <TextView  
  20. android:text=”Ctrl-S”   
  21. android:gravity=”right” 元素本身的内容向右对齐   
  22. android:padding=”3dip” />  
  23. </TableRow><TableRow>  
  24. <TextView  
  25. android:layout_column=”1″   
  26. android:text=”另存为…”   
  27. android:padding=”3dip” />  
  28. <TextView  
  29. android:text=”Ctrl-Shift-S”   
  30. android:gravity=”right”   
  31. android:padding=”3dip” />  
  32. </TableRow><View  
  33. android:layout_height=”2dip”   
  34. android:background=”#FF909090″ /><TableRow>  
  35. <TextView  
  36. android:text=”X”   
  37. android:padding=”3dip” />  
  38. <TextView  
  39. android:text=”导入…”   
  40. android:padding=”3dip” />  
  41. </TableRow><TableRow>  
  42. <TextView  
  43. android:text=”X”   
  44. android:padding=”3dip” />  
  45. <TextView  
  46. android:text=”导出…”   
  47. android:padding=”3dip” />  
  48. <TextView  
  49. android:text=”Ctrl-E”   
  50. android:gravity=”right”   
  51. android:padding=”3dip” />  
  52. </TableRow><View  
  53. android:layout_height=”2dip”   
  54. android:background=”#FF909090″ /><TableRow>  
  55. <TextView  
  56. android:layout_column=”1″   
  57. android:text=”退出”   
  58. android:padding=”3dip” />  
  59. </TableRow>  
  60. </TableLayout>  

       下面是显示效果:

Android学习指南之七:表格布局TableLayout

       我加粗显示的地方都有解释,大家可以留意一下。

       提示:TableRow也是一个Layout,里面的元素会水平排列,如果TableRow的父元素不是TableLayout的话,那么他会表现的像一个LinearLayout。

Tags:Layout,xml | 2012/6/10 | 发表评论

相关文章: