当前位置: 首页 > news >正文

09. 【Android教程】表格布局 TableLayout

学完了 Android 两个经典布局,是不是觉得已经可以应对大多数场景了?我记得当我学完 LinearLayout 和 RelativeLayout 之后,我觉得 UI 布局已经可以出师了,在本人从事了多年的 Android 研究之后,可以很负责任的告诉你,的确可以出师了。

大多数场景都可以通过这两个布局方式组合出来,不过光靠这两招出师可能会走不少弯路,因为 Google 还为我们提供了很多实用的 Layout,比如今天要学的 TableLayout,它是一种表格样式,在很多 App 里面都会用到。当然你完全可以用 LinearLayout + RelativeLayout 实现,不过学完本节你就会发现,用 TableLayout 实现表格布局是多么简单的一件事情!

1. TableLayout 的特性

和其他 Layout 一样,TableLayout 也派生自 ViewGroup,它可以将内部的 View 或者 Layout 整齐的排成几行几列,按照表格的形式摆放。我用使用<TableRow/>标签标识一行,在标签内的 View 或者 Layout 都将摆放在同一行中。

注:看到行标签,大家可以想到,TableLayout 是不需要注明表格列的数量的,因为 Android 系统会自动根据我们声明在<TableRow/>中的元素推算出最终表格的列数

2. 关键属性的用法

刚刚提到,我们用<TableRow/>来声明表格的一行,而很多属性都是作用于<TableRow/>内部 View 的,这个也是和其他 Layout 不太一样的地方,需要注意,下面就分别介绍一下 TableLayout 中这两类属性。

2.1 作用于 TableLayout 的属性

  • android:stretchColumns:
    当表格的某些列宽度比较窄的时候,你可以通过给 TableLayout 设置stretchColumns属性来设置某些列向行方向伸展,最多可占据一整行。该属性的参数直接填入需要拉伸的列的序号即可(从 0 开始),另外支持多输入,各个列序号通过“,”分隔。如果需要对所有列拉伸,可以直接用“*”表示,如下:
    <!-- 针对所有列做拉伸 -->
    android:stretchColumns="*"<!-- 针对第1列、4列、13列做拉伸 -->
    android:stretchColumns="0,3,12"
    
  • android:shrinkColumns:
    这是与 stretchColumns 相对的属性,如果某些列的所占的空间太大,那么可以通过该属性设置可收缩的列。当该列子控件的内容太多(比如 TextView 中文本太长),已经挤满所在行,那么该子控件的内容将往列方向显示(TextView 折行显示)。

注:虽然从名字上讲,一个是扩展,一个是收缩,但二者并不冲突。一个列可以同时具备stretchColumnsshrinkColumns属性。若此,那么当该列的内容过多时,将“多行”显示其内容。当然这里不是真正的多行,而是系统根据需要自动调节该行的 layout_height。

  • android:collapseColumns:
    隐藏部分列的内容,使用方法和上述两个属性一样,直接填入列的序号即可,支持多个列。

这 3 个属性的用法示例如下:

<?xml version="1.0" encoding="utf-8"?>
<TableLayout xmlns:android="http://schemas.android.com/apk/res/android"xmlns:tools="http://schemas.android.com/tools"android:layout_width="match_parent"android:layout_height="match_parent"android:shrinkColumns="0"android:stretchColumns="1,2"android:collapseColumns="3"tools:context=".MainActivity"><TableRow><TextViewandroid:id="@+id/center"android:layout_width="wrap_content"android:layout_height="wrap_content"android:background="#EE0D0D"android:text="column1, Emercy Android Study"android:textSize="20sp" /><TextViewandroid:layout_width="wrap_content"android:layout_height="wrap_content"android:background="#DBEE14"android:text="column2"android:textSize="20sp" /><TextViewandroid:layout_width="wrap_content"android:layout_height="wrap_content"android:background="#7492CC"android:text="column3"android:textSize="20sp" /><TextViewandroid:layout_width="wrap_content"android:layout_height="wrap_content"android:background="#09A234"android:text="column4"android:textSize="20sp" /></TableRow><TableRow><TextViewandroid:layout_width="wrap_content"android:layout_height="wrap_content"android:background="#FF80AB"android:text="row2"android:textSize="20sp" /></TableRow>
</TableLayout>

示例中定义另一个两行的表格,根据元素最多的行可以计算出表格的列数,然后设置了shrinkColumns为第一行,stretchColumns为第二、三行,最后collapseColumns为最后一行,最终显示的效果如下:

2.2 作用于 TableRow 内部 View 的属性

  • android:layout_span:
    通常情况下,一个 View 只会占据一列的宽度,但是如果对某个 View 设置了layout_span=n,那么该 View 会超出所在列,占据 n 个列。
  • android:layout_column:
    设置 View 在第几列显示。

这两个属性比较好理解,我们直接在上面的例子中,在第二行加上这两个参数:

<TableRow><TextViewandroid:layout_column="1"android:layout_span="3"android:layout_width="wrap_content"android:layout_height="wrap_content"android:background="#FF80AB"android:text="row2"android:textSize="20sp" /></TableRow>

设置当前 TextView 在第 2 列显示,并占 3 列的宽度,效果如下:

3. TableLayout 的注意点

可以看到,用 TableLayout 去完成一个表格样式是非常容易的,关于 TableLayout 有 3 点需要注意:

  1. <TableRow/>标签是不需要设置layout_widthlayout_height的,系统会自动给这两个属性分别赋值为match_parentwrap_content。也就是说,我们的每一行一定是占满 TableLayout 的宽度,而高度则由内部的 View 来决定;
  2. TableLayout 表格的列数,由元素最多的<TableRow/>的元素数量决定;
  3. 表格每一列的宽度就是该列最大的 View 宽度。

4. 小结

TableLayout 的功能比较简单,属性也很好理解,就是用来完成一个列表形式的布局,虽然形式比较单一,但是在相应场景中会有事半功倍的效果,相信在学会 LinearLayout 和 RelativeLayout 之后的你应该能够完全掌握。

注:大家学完之后可以思考一下本节中的所有 UI 样式如果用 LinearLayout 和 RelativeLayout 如何实现?

http://www.lryc.cn/news/570469.html

相关文章:

  • 安全测试工具APPScan安装与使用教程
  • 一文梳理人脸识别,看完全都懂了!
  • 碎片拼接
  • urp教务系统简单利用
  • Ecovadis认证意义是什么?什么是Ecovadis认证?
  • 奇偶排序(Odd-Even Sort)
  • 如何给Fedora 15添加磁盘(或盘片)
  • wireshark使用抓包详细图文教程
  • 学习何凯明在图像中的降噪技术和识别率问题
  • 项目文章 ▏组蛋白乳酸化驱动的B7-H3表达促进肿瘤免疫逃避
  • 快准牌电脑发软件_做自媒体视频剪辑、加字幕、文字音频互转,什么软件免费又好用?...
  • AI 神经网略小白学习笔记(一) -- 环境搭建
  • 第11章 结构 笔记
  • MyBatis+Spring整合示例程序
  • 技术突破与落地应用:端到端 2.0 时代辅助驾驶TOP10 论文深度拆解系列【第四篇(排名不分先后)】
  • 2024年【全套】Android零基础入门教程(知识精讲+强化实战(1),今日头条android面试
  • 工厂模式Factory Pattern
  • 英一真题阅读单词笔记 12年
  • 创始人IP如何崛起:系统化打造的实践路径 | 创客匠人
  • qq群关系数据库 mysql_QQ群关系数据库
  • Arduino 随身听
  • 1. 2019年《斯坦福大学CS330多任务和元学习》第1讲:简介与概述【中文字幕】
  • 《史蒂夫·乔布斯传》(Steve Jobs)官方正式中文版高清PDF
  • 华为OD-2024年E卷-英文输入法[100分] -- python
  • 班级html网页设计实例,静态网页班级网站设计.doc
  • PMP成本管理时,合同成本的计算和注意事项
  • Python实现人机五子棋
  • 计算机操作系统 第四章练习
  • Vue-Leaflet地图组件开发(四)高级功能与深度优化探索
  • 几个软件的静默安装方法(1)