更多Android高级架构进阶视频学习请点击:https://space.bilibili.com/474380680
本篇文章将从LinearLayout、RelativeLayout、FrameLayout、AbsoluteLayout、GridLayout来介绍常用View布局:
一、UI的描述
对于Android
应用程序中,所有用户界面元素都是由View
和ViewGroup
对象构建的。View
是绘制在屏幕上能与用户进行交互的一个对象。而对于ViewGroup
来说,则是一个用于存放其他View
和ViewGroup
对象的布局容器!

Android
为我们提供了View
和ViewGroup
的两个子类的集合,提供常用的一些输入控件(比如按钮,图片和文本域等)和各种各样的布局模式(比如线程布局,相对布局,绝对布局,帧布局,表格布局等)。
二、用户界面布局
在你APP
软件上的,用户界面上显示的每一个组件都是使用层次结构View
和ViewGroup
对象来构成的,比如,每个ViewGroup
都是不可见容器,每个ViewGroup
视图组用于组织子视图View
的容器,而它的子视图View
可能是输入一些控件或者在某块区域的小部件UI
。如果你有了层次结构树,你可以根据自己的需要,设计出一些布局,但要尽量简单,因为越简单的层次结构最适合性能。
要声明布局,可以在代码中实例化对象并构建,最简单的方法也可以使用xml
文件。
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" >
<TextView android:id="@+id/text"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="TextView" />
<Button android:id="@+id/button"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Button" />
</LinearLayout>
三、 在Android
中提供了几个常用View布局:
-
LinearLayout
线性布局 -
RelativeLayout
相对布局 -
FrameLayout
帧布局 -
AbsoluteLayout
绝对布局 -
TableLayout
表格布局 -
GridLayout
网格布局
四、 描述一下几个重要的
线性布局:
指子控件以水平或垂直方式排列。
相对布局:
指子控件以控件之间的相对位置或子控件相对于父容器的位置排列。
帧布局:
指所有子控件均放在左上角且后面元素直接覆盖在前面元素之上。
绝对布局:
指子控件通过绝对定位x,y位置来决定其位置摆放。
表格布局:
指以行列的形式放置子控件,每一行是一个TableRow对象或者View对象。

4.1 LinearLayout线性布局
常用属性:
-
id:
为该组件添加一个资源id
-
orientation:
布局中的排列方式,有两种方式:horizontal
水平vertical
竖直 -
layout_width:
布局的宽度,用wrap_content
表示组件的实际宽度,match_parent
表示填充父容器 -
layout_height:
布局的长度,用wrap_content
表示组件的实际长度,match_parent
表示填充父容器 -
gravity:
控制组件所包含的子元素的对齐方式 -
layout_gravity:
控制该组件在父容器里的对齐方式 -
background:
为该组件添加一个背景图片
LinearLayout
是一个视图组,可以在一个方向垂直或者水平分布所有子项,用android:orientation
属性。
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" >
<EditText
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:hint="输入账号" />
<EditText
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:hint="输入密码" />
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="登录" />
</LinearLayout>
4.2RelativeLayout
相对布局
RelativeLayout
是一个相对布局的视图组,用来显示相对位置的子视图类,在默认情况下,所有子视图对会分布在左上角。
-
layout_alignParentTop:
为true
,视图的上边界与父级的上边界对齐 -
layout_centerVertical:
为true
,将子类放置在父类中心 -
layout_below:
将该视图放在资源ID
下方 -
layout_toRightOf:
将该视图放在资源ID
右边
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent" >
<EditText
android:id="@+id/name"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:hint="你的名字" />
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_below="@id/name"
android:layout_alignParentRight="true"
android:text="正确" />
</RelativeLayout>
4.3 GridView
网格布局
GridView
其实是一个网格一样的视图组件,是一个ViewGroup
的二维视图。用适配器可以将布局进行填充。

4.4 ListView列表组件
ListView
是一个用于显示列表的可以滚动的视图组,列表项也可以用适配器进行添加内容的。

更多Android高级架构进阶视频学习请点击:https://space.bilibili.com/474380680
原文链接:https://www.jianshu.com/p/58d63e31ea18