今天开始学习RelativeLayout(相对布局),相对布局在平时布局的时候用的较多,因为Android适配方面的原因。相对布局可以控制组件摆放的位置(放在任一组件的上下左右等位置),下面来看看类的定义(http://developer.android.com/reference/android/widget/RelativeLayout.html):

相对布局有几个非常常用的属性在这里列个表格说下:

RelativeLayout的常用属性
编号 属性名称 对应的变量 意义
1 android:layout_below RelativeLayout.BELOW 放在指定组件的下面
2 android:layout_toLeftOf RelativeLayout.LEFT_OF 放在指定组件的左边
3 android:layout_toRightOf RelativeLayout.RIGHT_OF 放在指定组件的右边
4 android:alignTop RelativeLayout.ALIGN_TOP 以指定组件为参考进行上对齐
5 android:alignButtom RelativeLayout.ALIGN_BUTTOM 以指定组件为参考进行下对齐
6 android:alignLeft RelativeLayout.ALIGN_LEFT 以指定组件为参考进行左对齐
7 android:alignRight RelativeLayout.ALIGN_RIGHT 以指定组件为参考进行右对齐

下面同样写个例子来说明。

效果如下:

我用RelativeLayout来自定义title(比较常见)。

main.xml:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/LinearLayout1"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" > <RelativeLayout
android:layout_width="fill_parent"
android:layout_height="45dip"
android:background="@drawable/head_bg" > <ImageButton
android:id="@+id/main"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentRight="true"
android:layout_centerVertical="true"
android:background="@drawable/main" /> <ImageButton
android:id="@+id/fresh"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:layout_centerVertical="true"
android:layout_marginLeft="10dp"
android:background="@drawable/fresh" /> <TextView
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:gravity="center"
android:text="Kay"
android:textColor="#FFFFFFFF"
android:textSize="24sp" />
</RelativeLayout> <ImageView
android:id="@+id/imageView1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/img_1" /> </LinearLayout>

上面用到的属性有一个上面没有说到就是android:layout_alignParentLeft(
layout_alignParentRight)和
android:layout_alignParentTop分别表示相对父布局靠左(靠右)和靠上,至于消除系统title前面已经说过了(http://blog.csdn.net/kaypro/article/details/9858807

接下来就是和以前一样用java代码来实现上面的效果:

package com.example.relativelayoutdemo;

import android.os.Bundle;
import android.provider.Contacts.Organizations;
import android.provider.ContactsContract.CommonDataKinds.Organization;
import android.app.Activity;
import android.graphics.Color;
import android.text.Layout;
import android.view.Gravity;
import android.view.Menu;
import android.view.ViewGroup;
import android.view.ViewGroup.LayoutParams;
import android.view.Window;
import android.widget.ImageButton;
import android.widget.ImageView;
import android.widget.LinearLayout;
import android.widget.RelativeLayout;
import android.widget.TextView; public class MainActivity extends Activity { @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
requestWindowFeature(Window.FEATURE_NO_TITLE);
// 获取密度(用于dp转换成px值)
float scale = this.getResources().getDisplayMetrics().density;
// setContentView(R.layout.activity_main);
// 定义LinearLayout装载RelativeLayout和ImageView
LinearLayout lLayout = new LinearLayout(this);
// 设置垂直显示
lLayout.setOrientation(LinearLayout.VERTICAL);
// 定义LinearLayout的高和宽
LinearLayout.LayoutParams lLayoutParams = new LinearLayout.LayoutParams(
ViewGroup.LayoutParams.MATCH_PARENT,
ViewGroup.LayoutParams.MATCH_PARENT); // 定义RelativeLayout
RelativeLayout rLayout = new RelativeLayout(this);
// 定义RelativeLayout的高和宽
RelativeLayout.LayoutParams rLayoutParams = new RelativeLayout.LayoutParams(
ViewGroup.LayoutParams.WRAP_CONTENT, (int) (45 * scale + 0.5f));
// 设置RelativeLayout的背景
rLayout.setBackgroundResource(R.drawable.head_bg); // 定义两个ImageButton
ImageButton main = new ImageButton(this);
ImageButton fresh = new ImageButton(this);
// 定义两个ImageButton的高和宽
RelativeLayout.LayoutParams mainParams = new RelativeLayout.LayoutParams(
ViewGroup.LayoutParams.WRAP_CONTENT,
ViewGroup.LayoutParams.WRAP_CONTENT);
RelativeLayout.LayoutParams freParams = new RelativeLayout.LayoutParams(
ViewGroup.LayoutParams.WRAP_CONTENT,
ViewGroup.LayoutParams.WRAP_CONTENT);
// 设置两个ImageButton的背景
main.setBackgroundResource(R.drawable.main);
fresh.setBackgroundResource(R.drawable.fresh);
// 为两个ImageButton添加规则
// 在父布局的右边(相当于android:alignParentRight="true")
mainParams.addRule(RelativeLayout.ALIGN_PARENT_RIGHT);
// 垂直居中显示
mainParams.addRule(RelativeLayout.CENTER_VERTICAL);
// 在父布局的左边(android:alignParentLeft="false")
freParams.addRule(RelativeLayout.ALIGN_PARENT_LEFT);
freParams.addRule(RelativeLayout.CENTER_VERTICAL);
// layout_marginLeft="10dp"(这里dp转换成像素)
freParams.leftMargin = (int) (10 * scale + 0.5f); TextView tv = new TextView(this);
tv.setGravity(Gravity.CENTER);
tv.setTextColor(Color.WHITE);
tv.setTextSize(24);
tv.setText("Kay"); // 定义ImageView和设置背景图
ImageView img = new ImageView(this);
img.setBackgroundResource(R.drawable.img_1);
// RelativeLayout添加main fresh tv这三个view
rLayout.addView(fresh, freParams);
rLayout.addView(tv, lLayoutParams);
rLayout.addView(main, mainParams); // LinearLayout添加RelativeLayout和ImageView
lLayout.addView(rLayout, rLayoutParams);
lLayout.addView(img, lLayoutParams); // 显示
super.setContentView(lLayout, lLayoutParams); } }

效果和上面xml实现的一样,好了,今天就说到这里了。

一步一步学android之布局管理器——RelativeLayout的更多相关文章

  1. 一步一步学android之布局管理器——LinearLayout

    线性布局是最基本的一种布局,在基本控件篇幅中用到的都是LinearLayout,线性布局有两种方式,前面也有用到,一种是垂直的(vertical),一种是水平的(horizontal).我们同样来看下 ...

  2. android的布局管理器

    理论上通过setContentView(view)能够把一个view设置到activity中,但当你有很多个view控件的时候,就需要用android的布局管理器来管理view控件了. android ...

  3. Android课程---布局管理器中的线性布局

    线性布局实例: <?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:andro ...

  4. Android课程---布局管理器

  5. android开发4:Android布局管理器1(线性布局,相对布局RelativeLayout-案例)

    控件类概述 View 可视化控件的基类 属性名称 对应方法 描述 android:background setBackgroundResource(int) 设置背景 android:clickabl ...

  6. Android UI组件:布局管理器

    为了更好的管理Android应用的用户界面中的组件,Android提供了布局管理器.通过使用布局管理器,Android应用的图形用户界面具有良好的平台无关性.通常,推荐使用布局管理器来管理组件的分布. ...

  7. android中常用的布局管理器

    Android中的几种常用的布局,主要介绍内容有: View视图 RelativeLayout    相对布局管理器 LinearLayout     线性布局管理器 FrameLayout     ...

  8. 【详细】Android入门到放弃篇-YES OR NO-》各种UI组件,布局管理器,单元Activity

    问:达叔,你放弃了吗? 答:不,放弃是不可能的,丢了Android,你会心疼吗?如果别人把你丢掉,你是痛苦呢?还是痛苦呢?~ 引导语 有人说,爱上一个人是痛苦的,有人说,喜欢一个人是幸福的. 人与人之 ...

  9. [置顶] Android布局管理器 - 详细解析布局实现

    布局管理器都是以ViewGroup为基类派生出来的; 使用布局管理器可以适配不同手机屏幕的分辨率,尺寸大小; 布局管理器之间的继承关系 : 在上面的UML图中可以看出, 绝对布局 帧布局 网格布局 相 ...

随机推荐

  1. python 自定义信号处理器

    说明: 这里所说的信号与kill 命令中的信号指的是同一个. #!/usr/bin/python #!coding:utf-8 import sys,time,signal def now(): re ...

  2. ubuntu下C编程,编译基础( 转)

    buntu下C编程,编译基础     C 编程中相关文件后缀 .a 静态库 (archive) .c C源代码(需要编译预处理) .h C源代码头文件 .i C源代码(不需编译预处理) .o 对象文件 ...

  3. delphi 文件搜索,遍历所有子目录

    function ListFiles(path: string): TStringList; var SearchRec: TSearchRec; found: integer; begin resu ...

  4. Linux网桥

    linux网桥的功能 转发数据包 网桥的功能在延长网络跨度上类似于中继器,然而它能提供智能化连接服务,即根据帧的终点地址处于哪一网段来进行转发和滤除.网桥对站点所处网段的了解是靠"自学习&q ...

  5. Linux学习之二十、循环

    原文地址:http://vbird.dic.ksu.edu.tw/linux_basic/0340bashshell-scripts_5.php 回圈 (loop) 除了 if...then...fi ...

  6. javascript数组去重算法-----2

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  7. Redis简介以及如何在Windows上安装Redis

    Redis简介 Redis是一个速度非常快的非关系型内存数据库. Redis提供了Java,C/C++,C#,PHP,JavaScript,Perl,Object-C,Python,Ruby,Erla ...

  8. vpn pptp配置

    安装 yum install pptpd 配置pptpd 改动/etc/pptpd.conf设置 localip 192.168.20.1 remoteip 192.168.20.234-238,19 ...

  9. easyui的验证

    加一个JS来重写验证,文件名为:validator.js 内容为: //扩展easyui表单的验证 $.extend($.fn.validatebox.defaults.rules, { //验证汉子 ...

  10. css笔记:如何将一个页面平均分成四个部分?

    今天,我在刷面试题的时候,突然想到一道题:如何将一个页面平均分成四个部分(div)呢?其实难度也不大,于是直接上代码 <!DOCTYPE html> <html lang=" ...