Android(安卓)RelativeLayout 相对布局

Android RelativeLayout (相对布局)让您可以指定子视图相对于彼此的位置。每个视图的位置可以指定为相对于同级元素或相对于父元素。


RelativeLayout 属性

以下是 RelativeLayout 特有的重要属性:

编号属性 & 描述
1

android:id

这是唯一标识布局的 ID。

2

android:gravity

这指定了对象应如何在 X 轴和 Y 轴上定位其内容可能的值有 topbottomleftrightcentercenter_verticalcenter_horizontal 等。

3

android:ignoreGravity

表示什么视图不应受重力影响。

使用 RelativeLayout,您可以通过右边框对齐两个元素,或者使一个元素位于另一个元素下方,在屏幕中居中,居中,以此类推。默认情况下,所有子视图都绘制在布局的左上角,因此必须使用 RelationLayout.LayoutParams 提供的各种布局属性定义每个视图的位置。

下面给出了 LayoutParams 和一些重要属性:

编号属性 & 描述
1

android:layout_above

将此视图的底边放置在给定的定位点视图 ID 上方,并且必须是对另一个资源的引用,格式为 "@[+][package:]type:name"

2

android:layout_alignBottom

使此视图的底边与给定锚定视图 ID 的底边匹配,并且必须是对另一资源的引用,格式为 "@[+][package:]type:name"

3

android:layout_alignLeft

使此视图的左边缘与给定锚定视图 ID 的左边缘匹配,并且必须是对另一资源的引用,格式为 "@[+][package:]type:name"

4

android:layout_alignParentBottom

如果为 true,则使此视图的底边与父视图的底线匹配必须是布尔值,truefalse

5

android:layout_alignParentEnd

如果为 true,则使此视图的结束边缘与父视图的结束边匹配必须是布尔值,truefalse

6

android:layout_alignParentLeft

如果为 true,则使此视图的左边缘与父视图的左边匹配必须是布尔值,truefalse

7

android:layout_alignParentRight

如果为 true,则使此视图的右边缘与父视图的右边匹配必须是布尔值,truefalse

8

android:layout_alignParentStart

如果为 true,则使此视图的起始边与父视图的起始边缘匹配必须是布尔值,truefalse

9

android:layout_alignParentTop

如果为 true,则使此视图的顶边与父视图的顶边缘匹配必须是布尔值,truefalse

10

android:layout_alignRight

使此视图的右边缘与给定锚定视图 ID 的右边缘匹配,并且必须是对另一资源的引用,格式为 "@[+][package:]type:name"

11

android:layout_alignStart

使此视图的起始边缘与给定锚定视图 ID 的起始边缘匹配,并且必须是对另一资源的引用,格式为 "@[+][package:]type:name"

12

android:layout_alignTop

使此视图的上边缘与给定锚定视图 ID 的上边缘匹配,并且必须是对另一资源的引用,格式为 "@[+][package:]type:name"

13

android:layout_below

将此视图的上边缘放置在给定的定位点视图 ID 下方,并且必须是对另一个资源的引用,格式为 "@[+][package:]type:name"

14

android:layout_centerHorizontal

如果为 true,则在其父级内水平居中放置此子级必须是布尔值,truefalse

15

android:layout_centerInParent

如果为 true,则将此子对象在其父对象内水平和垂直居中必须是布尔值,truefalse

16

android:layout_centerVertical

如果为 true,则将此子级垂直居中于其父级必须是布尔值,truefalse

17

android:layout_toEndOf

将此视图的起始边缘定位到给定定位点视图 ID 的末尾,并且必须是对另一资源的引用,格式为 "@[+][package:]type:name"

18

android:layout_toLeftOf

将此视图的右边缘放置在给定定位点视图 ID 的左侧,并且必须是对另一资源的引用,格式为 "@[+][package:]type:name"

19

android:layout_toRightOf

将此视图的左边缘放置在给定定位点视图 ID 的右侧,并且必须是对另一资源的引用,格式为 "@[+][package:]type:name"

20

android:layout_toStartOf

将此视图的结束边缘定位到给定定位点视图 ID 的开头,并且必须是对另一资源的引用,格式为 "@[+][package:]type:name"


实例

这个例子将带您通过简单的步骤来展示如何使用相对布局创建您自己的 Android 应用程序。按照以下步骤修改我们在Hello World 实例章节中创建的 Android 应用程序:

步骤描述
1您将使用 Android Studio IDE 创建一个 Android 应用程序,并将其放到包 com.example.demo 下并命名为 demo,如Hello World 实例一章中所述。
2修改 res/layout/activity_main.xml 文件的默认内容,以在相对布局中包含几个小部件
3运行应用程序以启动 Android 模拟器并验证应用程序中所做更改的结果。

以下是修改后的主 activity 文件 src/com.example.demo/MainActivity.java 的内容。此文件可以包括每个基本生命周期方法。

  1. package com.example.demo;
  2. import android.os.Bundle;
  3. import android.app.Activity;
  4. public class MainActivity extends Activity {
  5. @Override
  6. protected void onCreate(Bundle savedInstanceState) {
  7. super.onCreate(savedInstanceState);
  8. setContentView(R.layout.activity_main);
  9. }
  10. }

下面是 res/layout/activity_main.xml 文件的内容:

  1. <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
  2. android:layout_width="fill_parent"
  3. android:layout_height="fill_parent"
  4. android:paddingLeft="16dp"
  5. android:paddingRight="16dp" >
  6. <EditText
  7. android:id="@+id/name"
  8. android:layout_width="fill_parent"
  9. android:layout_height="wrap_content"
  10. android:hint="@string/reminder" />
  11. <LinearLayout
  12. android:orientation="vertical"
  13. android:layout_width="fill_parent"
  14. android:layout_height="fill_parent"
  15. android:layout_alignParentStart="true"
  16. android:layout_below="@+id/name">
  17. <Button
  18. android:layout_width="wrap_content"
  19. android:layout_height="wrap_content"
  20. android:text="New Button"
  21. android:id="@+id/button" />
  22. <Button
  23. android:layout_width="wrap_content"
  24. android:layout_height="wrap_content"
  25. android:text="New Button"
  26. android:id="@+id/button2" />
  27. </LinearLayout>
  28. </RelativeLayout>

下面是 res/values/strings.xml 文件的内容,定义了两个常量:

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <resources>
  3. <string name="action_settings">Settings</string>
  4. <string name="reminder">Enter your name</string>
  5. </resources>

让我们尝试运行我们修改过的 Hello World!我们刚刚修改的应用程序。我假设您在进行环境设置时创建了 AVD。要从 Android Studio 运行应用程序,请打开项目的 activity 文件之一,然后单击工具栏上的运行 Eclipse Eclipse Run Icon 图标。Android studio 在您的AVD 上安装应用程序并启动它,如果您的设置和应用程序一切正常,它将显示以下模拟器窗口:

分类导航