一步一步学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 网络编程第三版
为服务端增加多线程解决方案 1.服务端代码如下: ***这个版本并没有真正的起到多线程的作用,主要原因在于t.join():以后的版本会改进这个问题*** #!/usr/bin/python #!co ...
- Oracle EBS-SQL (INV-2):检查帐户别名发放记录.sql
SELECT FU.description 操作者, ITM.SEGMENT1 物料编码, ITM.DESC ...
- 在ubuntu10.0.4下更新git
今天想到要在ubuntu10.0.4下下载android的源码学习一下.源码下载用到了git.以前安装过git以为应该没什么问题的,没想到报了 “fatal: git 1.7.2 or later r ...
- 使用plist的好处
首先:帮助节省内存.OpenGL ES纹理要求宽和高都是2的n次幂的倍数.我们可以考虑将小的图片拼大图片,然后统一加载. 其次:提高渲染速度.OpenGL ES要求切换的纹理越少越好,将图片拼成大图 ...
- 几种常用单片机I/O口线的驱动能力
摘要: 详细分析了几种常见单片机的I/O口结构,并据此分析其驱动能力大小 在控制系统中,经常用单片机的I/O口驱动其他电路.几种常用单片机I/O口驱动能力在相关的资料中的说法是:GMS97C2051. ...
- delphi 发送Windwos消息控制按钮(控制计算器里的某一个按钮)
procedure TfrmMain.btnSendClick(Sender: TObject); var hCalc, h1: Cardinal; begin WinExec('calc', SW_ ...
- C语言入门(16)——C语言的数组
和结构体类似,数组也是一种复合数据类型,它由一系列相同类型的元素组成.C语言支持一维数组和多维数组.如果一个数组的所有元素都不是数组,那么该数组称为一维数组. 一维数组的定义方式 在C语言中使用数组必 ...
- POJ 1182 食物链(并查集拆点)
[题目链接] http://poj.org/problem?id=1182 [题目大意] 草原上有三种物种,分别为A,B,C A吃B,B吃C,C吃A. 1 x y表示x和y是同类,2 x y表示x吃y ...
- POJ——多项式的加法
1:多项式加法 查看 提交 统计 提问 总时间限制: 1000ms 内存限制: 5000kB 描述 我们经常遇到两多项式相加的情况,在这里,我们就需要用程序来模拟实现把两个多项式相加到一起.首先 ...
- Sass 的基本语法规则
转自:http://www.cnblogs.com/qqloving/p/3676852.html 自从发现可编程的css语法 Sass和基于Sass的css库compass 一个给我的感觉像c# 另 ...