Android Layout 布局

本文深入解析Android中的LinearLayout布局及其属性使用,包括方向、填充方式、权重等,通过实例代码展示如何利用LinearLayout实现控件的有序排列与空间分配。

原文地址: http://android.tgbus.com/Android/tutorial/201104/348551.shtml

一个Android视图有很多控件,那么怎么来控制它们的位置排列呢?我们需要容器来存放这些控件并控制它们的位置排列,就像HTML中div,table一样,Android布局也起到同样的作用。

  Android布局主要有以下几种:LinearLayout,RelativeLayout,TableLayout,AbsoluteLayout.最后一种AbsoluteLayout是通过指定控件的x/y坐标来定位的,不太灵活所以已经不推荐使用了。

  (1)LinearLayout

  LinearLayout线性布局,包含在LinearLayout里面的控件按顺序排列成一行或者一列,类似于Swing里的FlowLayout和Silverlight里的StackPanel,它的常用的属性主要包括:

  Orientation方向,即指定LinearLayout是代表一行还是一列,可以为horizontal或vertical,如android:orientation="vertical",当然也在可以在代码里通过setOrientation()方法来设置。

  FillMode填充方式,所有在LinearLayout的控件都必须指定它的填充方式,即设置android:layout_width和android:layout_height,可以为三种值(1)具体的像素值,如20px(2)wrap_content,表示按控件文本实际长度显示(3)fill_parent,表示填充剩下的所有可用空间。

  Weight权重,如果你想让一行或一列的控件按比例显示,这时候权重就起到作用了,如想让一行里面两控件其中一控件占两倍于另一控件的空间,可以把其中一控件的android:layout_weight设置为1,另一个为2即可。

  我们来看看代码:

  Java代码:

<?xml version="1.0" encoding="utf-8"?>

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"

android:orientation="vertical" 
android:layout_width="fill_parent" 
android:layout_height="fill_parent">

<LinearLayout 
android:orientation="horizontal" 
android:layout_width="fill_parent" 
android:layout_height="fill_parent" 
android:layout_weight="1">

<TextView 
android:text="red" 
android:gravity="center_horizontal" 
android:background="#aa0000" 
android:layout_width="wrap_content" 
android:layout_height="fill_parent" 
android:layout_weight="1" />

<TextView 
android:text="green" 
android:gravity="center_horizontal" 
android:background="#00aa00" 
android:layout_width="wrap_content" 
android:layout_height="fill_parent" 
android:layout_weight="1" />

<TextView 
android:text="blue" 
android:gravity="center_horizontal" 
android:background="#0000aa" 
android:layout_width="wrap_content" 
android:layout_height="fill_parent" 
android:layout_weight="1" />

<TextView 
android:text="yellow" 
android:gravity="center_horizontal" 
android:background="#aaaa00" 
android:layout_width="wrap_content" 
android:layout_height="fill_parent" 
android:layout_weight="1" />

</LinearLayout>

<LinearLayout 
android:orientation="vertical" 
android:layout_width="fill_parent" 
android:layout_height="fill_parent" 
android:layout_weight="1">

<TextView
android:text="row one" 
android:textSize="15pt" 
android:layout_width="fill_parent" 
android:layout_height="wrap_content" 
android:layout_weight="1" />

<TextView 
android:text="row two" 
android:textSize="15pt" 
android:layout_width="fill_parent" 
android:layout_height="wrap_content" 
android:layout_weight="1" />

<TextView
android:text="row three" 
android:textSize="15pt" 
android:layout_width="fill_parent" 
android:layout_height="wrap_content" 
android:layout_weight="1" />

<TextView 
android:text="row four" 
android:textSize="15pt" 
android:layout_width="fill_parent" 
android:layout_height="wrap_content" 
android:layout_weight="1" />

</LinearLayout>

</LinearLayout>

 

  可以看到父类LinearLayout包含了一个水平布局的LinearLayout和一个垂直布局的LinearLayout,它们分别包含了四个平分宽度和高度的TextView,运行效果如下:
  
  效果图:


### Android Studio Layout 布局设计与实现 #### 1. 初识Layout布局Android开发中,`Layout` 是用于定义UI界面的主要工具之一。它决定了屏幕上各个控件的位置和排列方式。常见的两种基本布局是线性布局 (`LinearLayout`) 和相对布局 (`RelativeLayout`)。 #### 2. 创建一个新的Android项目 要开始学习 `Layout` 的设计与实现,首先需要创建一个新的Android项目。打开Android Studio后,选择 **"Start a new Android Studio project"** 并按照提示输入应用名称、公司域名以及其他必要信息[^2]。 #### 3. 编辑布局文件 编辑器中的布局文件通常位于 `res/layout/activity_main.xml` 路径下。开发者可以在其中编写XML代码来定义UI界面的外观和行为。 以下是关于常见布局及其属性的一些说明: - **线性布局 (LinearLayout)** 线性布局是一种简单的容器,它可以将子视图按水平或垂直方向排列。其常用属性如下: - `android:id`: 设置唯一标识符以便于程序中访问此控件。 - `android:layout_width`: 定义宽度,常用的值有 `match_parent`, `wrap_content`。 - `android:layout_height`: 定义高度,同样支持上述选项。 - `android:background`: 可以为控件指定背景颜色或者图像资源。 - `android:orientation`: 控制子元素的方向,取值为 `horizontal`(横向) 或 `vertical`(纵向)[^3]。 下面是一个简单的线性布局示例: ```xml <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" android:layout_width="match_parent" android:layout_height="match_parent"> <Button android:id="@+id/button1" android:text="Button 1" android:layout_width="wrap_content" android:layout_height="wrap_content"/> </LinearLayout> ``` - **相对布局 (RelativeLayout)** 相对布局允许更灵活地控制子视图之间的位置关系。例如,可以让某个按钮始终处于屏幕底部中央,或将一个文本框放置在一个图片上方等。 以下是一段使用相对布局的例子: ```xml <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent"> <TextView android:id="@+id/textView" android:text="Hello World!" android:layout_centerInParent="true" android:layout_width="wrap_content" android:layout_height="wrap_content"/> </RelativeLayout> ``` #### 4. 使用Include标签重用布局 为了减少重复工作并提高效率,在多个地方需要用到相同的布局时,可以利用 `<include>` 标签引入已有的布局文件[^5]。比如如果有一个通用的导航栏,则只需将其单独保存成一个 `.xml` 文件,然后通过 include 插入到其他页面里即可。 #### 5. 准备发布APK 当完成了所有的功能测试并对应用程序感到满意之后,就可以着手准备发布了。此时需生成带有签名的 APK 文件,整个过程并不繁琐,因为 Android Studio 提供了详尽的帮助指引[^4]。 --- ###
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值