一步一步学android之布局管理器——RelativeLayout
今天开始学习RelativeLayout(相对布局),相对布局在平时布局的时候用的较多,因为Android适配方面的原因。相对布局可以控制组件摆放的位置(放在任一组件的上下左右等位置),下面来看看类的定义(http://developer.android.com/reference/android/widget/RelativeLayout.html):
相对布局有几个非常常用的属性在这里列个表格说下:
| 编号 | 属性名称 | 对应的变量 | 意义 |
| 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的更多相关文章
- 一步一步学android之布局管理器——LinearLayout
线性布局是最基本的一种布局,在基本控件篇幅中用到的都是LinearLayout,线性布局有两种方式,前面也有用到,一种是垂直的(vertical),一种是水平的(horizontal).我们同样来看下 ...
- android的布局管理器
理论上通过setContentView(view)能够把一个view设置到activity中,但当你有很多个view控件的时候,就需要用android的布局管理器来管理view控件了. android ...
- Android课程---布局管理器中的线性布局
线性布局实例: <?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:andro ...
- Android课程---布局管理器
- android开发4:Android布局管理器1(线性布局,相对布局RelativeLayout-案例)
控件类概述 View 可视化控件的基类 属性名称 对应方法 描述 android:background setBackgroundResource(int) 设置背景 android:clickabl ...
- Android UI组件:布局管理器
为了更好的管理Android应用的用户界面中的组件,Android提供了布局管理器.通过使用布局管理器,Android应用的图形用户界面具有良好的平台无关性.通常,推荐使用布局管理器来管理组件的分布. ...
- android中常用的布局管理器
Android中的几种常用的布局,主要介绍内容有: View视图 RelativeLayout 相对布局管理器 LinearLayout 线性布局管理器 FrameLayout ...
- 【详细】Android入门到放弃篇-YES OR NO-》各种UI组件,布局管理器,单元Activity
问:达叔,你放弃了吗? 答:不,放弃是不可能的,丢了Android,你会心疼吗?如果别人把你丢掉,你是痛苦呢?还是痛苦呢?~ 引导语 有人说,爱上一个人是痛苦的,有人说,喜欢一个人是幸福的. 人与人之 ...
- [置顶] Android布局管理器 - 详细解析布局实现
布局管理器都是以ViewGroup为基类派生出来的; 使用布局管理器可以适配不同手机屏幕的分辨率,尺寸大小; 布局管理器之间的继承关系 : 在上面的UML图中可以看出, 绝对布局 帧布局 网格布局 相 ...
随机推荐
- python 自定义信号处理器
说明: 这里所说的信号与kill 命令中的信号指的是同一个. #!/usr/bin/python #!coding:utf-8 import sys,time,signal def now(): re ...
- ubuntu下C编程,编译基础( 转)
buntu下C编程,编译基础 C 编程中相关文件后缀 .a 静态库 (archive) .c C源代码(需要编译预处理) .h C源代码头文件 .i C源代码(不需编译预处理) .o 对象文件 ...
- delphi 文件搜索,遍历所有子目录
function ListFiles(path: string): TStringList; var SearchRec: TSearchRec; found: integer; begin resu ...
- Linux网桥
linux网桥的功能 转发数据包 网桥的功能在延长网络跨度上类似于中继器,然而它能提供智能化连接服务,即根据帧的终点地址处于哪一网段来进行转发和滤除.网桥对站点所处网段的了解是靠"自学习&q ...
- Linux学习之二十、循环
原文地址:http://vbird.dic.ksu.edu.tw/linux_basic/0340bashshell-scripts_5.php 回圈 (loop) 除了 if...then...fi ...
- javascript数组去重算法-----2
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- Redis简介以及如何在Windows上安装Redis
Redis简介 Redis是一个速度非常快的非关系型内存数据库. Redis提供了Java,C/C++,C#,PHP,JavaScript,Perl,Object-C,Python,Ruby,Erla ...
- vpn pptp配置
安装 yum install pptpd 配置pptpd 改动/etc/pptpd.conf设置 localip 192.168.20.1 remoteip 192.168.20.234-238,19 ...
- easyui的验证
加一个JS来重写验证,文件名为:validator.js 内容为: //扩展easyui表单的验证 $.extend($.fn.validatebox.defaults.rules, { //验证汉子 ...
- css笔记:如何将一个页面平均分成四个部分?
今天,我在刷面试题的时候,突然想到一道题:如何将一个页面平均分成四个部分(div)呢?其实难度也不大,于是直接上代码 <!DOCTYPE html> <html lang=" ...