`

Android布局管理(4)

阅读更多

 

         蠢话,这几天进度还是挺快的,我们已经到了Android布局管理器了。接下来让我们认识最常见的布局方式,也是安卓默认的布局放方式:

  •    LinearLayout    线性布局方式

          分为:垂直和水平布局

  • FrameLayout      框架布局方式
  • TableLayout       表格布局方式

      这个需要重点讲一下:

TableLayout属性:

  android:collapseColumns:将TableLayout里面指定的列隐藏,若有多列需要隐藏,请用逗号将需要隐藏的列序号隔开。             

  android:stretchColumns:设置指定的列为可伸展的列,以填满剩下的多余空白空间,若有多列需要设置为可伸展,请用逗号将需要伸展的列序号隔开。                

  android:shrinkColumns:设置指定的列为可收缩的列。当可收缩的列太宽(内容过多)不会被挤出屏幕。当需要设置多列为可收缩时,将列序号用逗号隔开。

 列元素(Button)属性:(奇怪的是button 里面没有android:layout_column 和android:layout_span两个属性,写进去无反应,还不知道为什么)

  android:layout_colum:设置该控件在TableRow中指定的列

  android:layout_span:设置该控件所跨越的列数

<TableLayout xmlns:tools="http://schemas.android.com/tools"
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/TableLayout1"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    tools:context=".MainActivity" >

    <TableRow
        android:id="@+id/tableRow1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content" >

        <EditText
            android:id="@+id/editText1"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:ems="10"
            android:text="请选择学校" />

        <Button
            android:id="@+id/button1"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="检索" />
    </TableRow>
    <View 
            android:layout_height="2px"
            android:background="#FF909090"
        
                   />

    <TableRow
        android:id="@+id/tableRow2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content" >

        <TextView
            android:id="@+id/textView1"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="选择院校" />

        <RadioGroup
            android:id="@+id/radioGroup1"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:orientation="vertical" >
        </RadioGroup>

    </TableRow>

    <RadioButton
        android:id="@+id/radio0"
        android:checked="true"
        android:text="信息院" />

    <RadioButton
        android:id="@+id/radio1"
        android:text="电气院" />

</TableLayout>

 

演示效果如下:

其中view是定义了一条分割线

 


接下来我们用tablelayout做一个表格数据,处理表格上,通常我们都用Tablelayout

 <TableRow
        android:id="@+id/tableRow1"
        >

        <TextView
            android:layout_column="0"
            android:gravity="center_horizontal"
            android:padding="8px"
            android:id="@+id/TextView1"
            
            android:text="学号" />

        <TextView
            android:id="@+id/TextView2"
            android:layout_column="1"
            android:gravity="center_horizontal"
            android:padding="8px"
           
            android:text="姓名" />

        <TextView
            android:id="@+id/textView3"
            android:layout_column="2"
            android:gravity="center_horizontal"
            android:padding="8px"
            android:text="班级" />

        <TextView
            android:id="@+id/textView4"
            android:layout_column="3"
            android:gravity="center_horizontal"
            android:padding="8px"
            android:text="地址" />

    </TableRow>
    <View 
            android:layout_height="2px"
            android:background="#FFF04334"
        
        />

    <TableRow
        android:id="@+id/tableRow2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content" >
        
        
        <TextView
            android:layout_column="0"
            android:gravity="center_horizontal"
            android:padding="3px"
            android:id="@+id/TextView1"
            
            android:text="201208010427" />

        <TextView
            android:id="@+id/TextView2"
            android:layout_column="1"
            android:gravity="center_horizontal"
            android:padding="3px"
           
            android:text="张依依" />

        <TextView
            android:id="@+id/textView3"
            android:layout_column="2"
            android:gravity="center_horizontal"
            android:padding="3px"
            android:text="计科四班" />

        <TextView
            android:id="@+id/textView4"
            android:layout_column="3"
            android:gravity="center_horizontal"
            android:padding="3px"
            android:text="湖南长沙天马学生公寓" />
        
    </TableRow>

    <TableRow
        android:id="@+id/tableRow3"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content" >
        <TextView
            android:layout_column="0"
            android:gravity="center_horizontal"
            android:padding="3px"
            android:id="@+id/TextView1"
            
            android:text="201208010428" />

        <TextView
            android:id="@+id/TextView2"
            android:layout_column="1"
            android:gravity="center_horizontal"
            android:padding="3px"
           
            android:text="周婷婷" />

        <TextView
            android:id="@+id/textView3"
            android:layout_column="2"
            android:gravity="center_horizontal"
            android:padding="3px"
            android:text="计科三班" />

        <TextView
            android:id="@+id/textView4"
            android:layout_column="3"
            android:gravity="center_horizontal"
            android:padding="3px"
            android:text="湖南长沙天马学生公寓3区4栋435" />
    </TableRow>

 

显示效果如下:


我们发现了一个很大的缺陷,就是多打出来的字都不见了,因为超过了屏幕显示长度,那么怎么办呢,别着急,tablelayout定义了很多方法,例如:

<TableLayout xmlns:tools="http://schemas.android.com/tools"
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/TableLayout1"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:shrinkColumns="3"  //允许第4列收缩

    android:stretchColumns="2"  //允许第3列被拉伸
    tools:context=".MainActivity" >

 

运行效果:



 这样看起来是不是效果好了很多,酷,大家一起来试试吧。

还可以加上

 android:collapseColumns="0,3"   这一句的意思是第一列和第三列隐藏

效果:


还可以添加表格背景图:



 

 
 


 

 


 

  • 大小: 123.8 KB
  • 大小: 131.8 KB
  • 大小: 130.8 KB
  • 大小: 66.7 KB
  • 大小: 149.6 KB
分享到:
评论

相关推荐

    android布局管理器代码

    在Android开发中,布局管理器是构建用户界面(UI)的关键元素。它们负责组织和定位UI组件,确保屏幕上的元素合理、美观地排列。本文将深入探讨Android中的常见布局管理器,尤其是基于XML的布局,以及如何在Activity...

    Android布局管理器

    【Android布局管理器】是Android应用开发中的核心概念,它决定了UI组件在屏幕上的排列方式。在Android中,布局管理器主要有五种类型:线性布局(LinearLayout)、表格布局(TableLayout)、相对布局(RelativeLayout...

    Android开发——布局管理

    本文将深入探讨Android布局管理的基本概念、常用布局类型以及如何优化布局性能。 首先,Android提供了几种内置的布局类型,以满足不同设计需求: 1. **线性布局(LinearLayout)**:这是最基础的布局,支持水平或...

    android布局_Android布局_android_

    本文将深入探讨Android布局的各种类型及其使用方法,旨在帮助开发者更好地理解和掌握Android应用的UI设计。 首先,我们来了解Android中的基本布局类型: 1. **线性布局(LinearLayout)**:这是最基础的布局,它...

    Android UI组件布局管理器

    在Android开发中,UI设计是至关重要的,而布局管理器(Layout Manager)则是构建用户界面的核心工具。Android提供了六种主要的布局管理器,每种都有其特定的用途和优势,使得开发者能够根据需求创建出各种各样的界面...

    android 布局管理

    本篇将深入探讨Android布局管理的各个方面,包括基本布局、布局属性、嵌套布局以及性能优化策略。 一、基本布局 Android提供了多种基本布局容器,它们各自具有特定的排列方式: 1. **线性布局(LinearLayout)**...

    Android 相对布局实例

    在Android开发中,布局管理器是构建用户界面的关键部分,其中相对布局(RelativeLayout)是一种常见的布局方式。相对布局允许我们根据各个视图之间的相对位置来安排它们,这为设计复杂且灵活的用户界面提供了可能。...

    android 中页面布局使用demo

    这个“android 中页面布局使用demo”应该是为了帮助开发者深入理解并实践Android中的各种布局管理器。下面我们将详细探讨Android布局及其在实际应用中的使用。 Android支持多种布局管理器,每种都有其特定的用途: ...

    android studio之布局管理器之间的互相嵌套.docx

    Android Studio 之布局管理器之间的互相嵌套 Android Studio 中的布局管理器是指用于安排 UI 组件的容器,它们可以单独使用,也可以互相嵌套以满足复杂的布局需求。在本文中,我们将探讨 Android Studio 中布局...

    android布局控件总结

    LinearLayout 线性布局 控制组件 横向 或者 纵向 排列 RelativeLayout 相对布局 子组件的位置总是相对兄弟...AbsoluteLayout 绝对布局 组件位置通过x, y坐标来控制, 布局容器不再管理组件位置, 大小, 这些都可以自定义;

    Android 显示/隐藏 布局

    在Android开发中,布局管理是应用界面设计的关键部分。布局可以是线性的、相对的、网格状的,甚至是自定义的,它们决定了用户界面的结构和交互方式。本主题聚焦于如何在Android应用中不使用`visibility`属性来显示或...

    android布局管理器

    很好用的 android布局管理 可自动生成代码 涵盖android所有的布局和控件 可大大提高UI布局设计效率

    Android学习笔记13:表格布局管理器TableLayout

    在Android开发中,表格布局管理器(TableLayout)是一种常用且强大的组件,它允许开发者创建类似于HTML中的表格的布局。TableLayout是LinearLayout的扩展,它通过行和列的方式来组织子视图(Views)。本篇学习笔记将...

    android 布局别名的应用

    在Android开发中,布局别名(Layout Aliases)是一种实用的技术,它可以帮助开发者更高效地管理应用程序的界面布局,尤其是在处理屏幕适配问题时。本文将深入探讨布局别名的概念、用途以及如何在实际项目中应用。 #...

    android界面布局详解

    总之,Android界面布局涉及到了用户界面的构建、布局的定义和管理,以及如何通过XML或代码来实现这些布局。理解这些概念对于开发出美观、响应式的Android应用至关重要。通过熟练掌握布局机制,开发者能够创建出适应...

    Basic4Android布局开发工具

    **标题解析:**"Basic4Android布局开发工具" 在标题中提到的“Basic4Android”是一种基于Java语言的Android应用程序开发框架,它为开发者提供了一种更简单的编程方式,特别是对于那些不熟悉复杂的Java语法或者...

    Android核心技术与实例详解—Android布局管理器

    在Android开发中,布局管理器是构建用户界面(UI)的核心工具,它们负责组织和...在"Android核心技术与实例详解—Android布局管理器.pdf"中,你将找到更多关于这些布局的实例和技巧,帮助你深入理解和应用这些知识。

    android框架布局demo

    在Android开发中,布局...通过下载并研究"android框架布局demo",你将有机会亲手实践这些概念,进一步加深对Android布局管理的理解,并提高你的应用开发技能。记得不断探索和尝试,让自己的应用界面更加精美和高效。

    Android学习笔记16:布局管理器的嵌套

    在Android开发中,布局管理器是构建用户界面的关键组成部分,它们负责组织和定位视图(View)或视图组(ViewGroup)。本篇学习笔记主要探讨的是如何在Android应用中进行布局管理器的嵌套,这是一项提升界面复杂性和...

Global site tag (gtag.js) - Google Analytics