android五种布局-霓虹灯效果实现
view子类是android用户界面表示的基本单元
view类的一些子类被称为widges工具;它提供了文本框和按钮类的UI对象的完整实现;
ViewGroup是view的一个扩展,可以容纳多个view;,他可以创建由互相联系的view组成的符合控件
布局:
FramelLayout-帧布局;
LinearLaout--线性布局;
TableLayout--表格布局;
RealativeLayout--相对布局;
Layout布局文件的命名---(禁止用大写字母来参与文件的命名)
一、 LinearLayout(线性布局)
“LinearLayout”翻译成中文是“线性布局”,所谓线性布局就是在该标签下的所有子
元素会根据其orientation属性的值来决定是按行或者是按列逐个显示。
示例main.xml布局文件如下:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:orientation="vertical" >
<TextView
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:text="@string/name_text" />
<EditText
android:layout_width="fill_parent"
android:layout_height="wrap_content"
/>
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/ok_button"
/>
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/no_button"
/>
</LinearLayout>
二、 RelativeLayout(相对布局)
相对布局中的视图组件是按相互之间的相对位置来确定的,并不是线性布局中的必须
按行或按列单个显示。示例布局文件如下:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:orientation="vertical"
>
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerInParent="true"
android:text="@string/button_zh"
android:id="@+id/main"
/>
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerInParent="true"
android:text="@string/button_ys"
android:layout_above="@+id/main"
android:layout_toLeftOf="@+id/main"
/>
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerInParent="true"
android:text="@string/button_yx"
android:layout_above="@+id/main"
android:layout_toRightOf="@+id/main"
/>
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerInParent="true"
android:text="@string/button_zs"
android:layout_below="@+id/main"
android:layout_toRightOf="@+id/main"
/>
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerInParent="true"
android:text="@string/button_zx"
android:layout_below="@+id/main"
android:layout_toLeftOf="@+id/main"
/>
</RelativeLayout>
三、 线性布局与相对布局嵌套使用
布局之间可以相互嵌套使用,以完成更为复杂的布局效果。举例来说,下面是一个线性布局当中包含了相对布局的界面:
<?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" >
<RelativeLayout
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:layout_marginLeft="70dp"
>
<TextView
android:id="@+id/name_nest"
android:layout_width="wrap_content"
android:layout_height="30dp"
android:text="@string/name_text" />
<EditText
android:layout_width="150dp"
android:layout_height="30dp"
android:layout_alignParentTop="true"
android:layout_toRightOf="@+id/name_nest" >
<requestFocus />
</EditText>
</RelativeLayout>
<RelativeLayout
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:layout_marginLeft="70dp"
>
<TextView
android:id="@+id/password_nest"
android:layout_width="wrap_content"
android:layout_height="30dp"
android:text="@string/password_text" />
<EditText
android:layout_width="150dp"
android:layout_height="30dp"
android:layout_toRightOf="@+id/password_nest" />
</RelativeLayout>
<RelativeLayout
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:layout_marginLeft="120dp"
>
<Button
android:id="@+id/button_re"
android:layout_width="50dp"
android:layout_height="35dp"
android:text="@string/login" />
<Button
android:layout_width="50dp"
android:layout_height="35dp"
android:layout_marginLeft="30dp"
android:layout_toRightOf="@+id/button_re"
android:text="@string/register" />
</RelativeLayout>
</LinearLayout>
四、 表格布局:
表格布局的风格跟HTML中的表格比较接近,只是所采用的标签不同。
<TableLayout>是顶级元素,说明采用的是表格布局
<TableRow>定义一个行
<TextView>定义一个单元格的内容
示例布局文件内容如下:
<?xml version="1.0" encoding="utf-8"?>
<TableLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:stretchColumns="*"
>
<TableRow>
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/name"
/>
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/sex"
/>
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/age"
/>
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/weight"
/>
</TableRow>
<TableRow>
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/nameh"
/>
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/sexh"
/>
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/ageh"
/>
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/weighth"
/>
</TableRow>
</TableLayout>
五、 FrameLayout帧布局()
帧布局中的每一个组件都代表一个画面,默认以屏幕左上角作为(0,0)坐标,按组件 定义的先后顺序依次逐屏显示,后面出现的会覆盖前面的画面。用该布局可以实现动画效果。
接下来,我们用三幅图片实现一只小鸟飞翔的动画效果。首先准备好三张连续的小鸟飞行图片。
接着新建一个android project项目;
编写main.xml文件:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:orientation="vertical"
android:gravity="center" >
<TextView
android:id="@+id/view1"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:width="210px"
android:height="50px"
/>
<TextView
android:id="@+id/view2"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:width="180px"
android:height="50px"
/>
<TextView
android:id="@+id/view3"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:width="150px"
android:height="50px"
/>
<TextView
android:id="@+id/view4"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:width="120px"
android:height="50px"
/>
<TextView
android:id="@+id/view5"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:width="90px"
android:height="50px"
/>
<TextView
android:id="@+id/view6"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:width="60px"
android:height="50px"
/>
<TextView
android:id="@+id/view7"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:width="30px"
android:height="50px"
/>
</LinearLayout>
String.xml文件
<?xml version="1.0" encoding="utf-8"?>
<resources>
<color name="color1">#330000</color>
<color name="color2">#550000</color>
<color name="color3">#770000</color>
<color name="color4">#990000</color>
<color name="color5">#bb0000</color>
<color name="color6">#dd0000</color>
<color name="color7">#ff0000</color>
</resources>
Activity.java文件:
package cn.haozi;
import java.util.Timer;
import java.util.TimerTask;
import android.app.Activity;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.widget.TextView;
public class NeoncolorActivity extends Activity {
public int currentColor = 0;
final int[] colorid = new int[] {
R.color.color7, R.color.color6, R.color.color5, R.color.color4,
R.color.color3, R.color.color2, R.color.color1,
};
final int[] names = new int[] {
R.id.view1, R.id.view2, R.id.view3, R.id.view4, R.id.view5, R.id.view6,
R.id.view7,
};
TextView[] textView = new TextView[7];
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
for (int i = 0; i < 7; i++) {
textView[i] = (TextView) findViewById(names[i]);
}
/*
* Handler主要用于异步消息的处理:当发出一个消息之后,首先进入一个消息队列,
* 发送消息的函数即刻返回,而另外一个部分逐个的在消息队列中将消息取出,然后对消息进行出来, 就是发送消息和接收消息不是同步的处理
*/
final Handler handler = new Handler() {
// 发送信息
public void handleMessage(Message msg) {
// what:自定义的消息内容,可以为一切数据类型,对象也包括的
if (msg.what == 01122) {
// 依次改变7个textView的颜色
for (int i = 0; i < 7 - currentColor; i++) {
textView[i].setBackgroundResource(colorid[i
+ currentColor]);
}
for (int i = 7 - currentColor, j = 0; i < 7; i++, j++) {
textView[i].setBackgroundResource(colorid[j]);
}
}
super.handleMessage(msg);
}
};
// 定义一个线程去改变currentColor的变量值
new Timer().schedule(new TimerTask() {
@Override
public void run() {
currentColor++;
if (currentColor >= 6) {
currentColor = 0;
}
// 发送一条消息通知系统改变背景颜色
Message m = new Message();
// 给消息定义一个标识
m.what = 01122;
handler.sendMessage(m);
}
}, 0, 100);
}
}
说明:
由于FrameLayout中后出现的UI控件会覆盖前面出现的UI控件,每次只能显示一个UI控
件,因此,我们可以通过在Activity中对每次显示的图片内容进行切换以实现动画效果。或
许你会想到开启一条线程来控制切换,但在非主线程中不能更新UI界面,所以,我们使用了
Android提供的消息通讯类Handler。该类可以实现非主线程和负责UI的主线程之间的通信,
进而间接实现非主线程更新UI界面。由于sleep方法中的
sendMessageDelayed(obtainMessage(0),delayMillis);本身会延迟发送一个消息,该消息
会被框架传递给handleMessage事件。我们在handleMessage()方法中再次调用sleep()方法,
形成一个循环调用。在我们对界面进行点击之前,两个方法会一直循环调用。前景图片也会
不断的切换,进而实现动画的效果。
android 常用的距离单位;
[/color]PX(像素):每个px对应屏幕上的一个点;
[color=blue]dip或dp(device independent pixels,设备独立像素);一种基于屏幕密度的抽象单位。在每寸160点的显示器上,1dip=1px。但是随着屏幕密度的改变,dip于px的换算会发生改变。
sp(scaled pixels,比例像素):处理字体的大小,可以根据用户的字体大小首选项进行缩放。
in(英寸) :标准的长度单位;
mm(毫米):标准的产度单位;
pt(磅):标准长度的单位,1/72英寸
发表评论
-
C 语言重点知识 面试必备2
2012-03-11 15:26 11731、unsigned int 类型的数据与int类型的数据运算 ... -
C 语言重点知识,面试必备
2012-03-10 22:48 18041、宏定义:也就是常用来做定值用的: ... -
scanf 很有用的用法
2012-03-10 22:26 1000[size=small]1、可用来检查输入值是否被接受[/s ... -
常量与操作符
2012-03-09 22:01 782一、常量 %d属于的是常量类型的替换, int % ... -
常量与操作符
2012-03-09 22:00 731一、常量 %d属于的是常量类型的替换, int % ... -
C语言基础总结
2012-03-09 21:59 985数据类型和变量: 从属的对象不同,空间不同,数据类型的不同可以 ... -
C/C++ 指针部分总结1
2012-03-09 21:57 10801、指向常量的指针,防止通过指针去修改变量的值,而不管变量是否 ... -
自定义view-跟随手指动的小球
2012-02-28 09:07 1909View组件类似于javaSwing中的JPanel。它只是一 ... -
自定义view-跟随手指动的小球
2012-02-28 08:38 0自定义view-跟随手指动的小球自定义view-跟随手指动的小 ... -
使用xml布局和java代码控制UI-图片浏览器
2012-02-28 08:28 1524在android中。XML和java代码同样拥有控制布局的能力 ... -
Android界面编程与视图(view)组件
2012-02-22 17:49 1550android.view.View 已知直接子类: ... -
Android应用的基本组件介绍
2012-02-21 21:30 1275android应用的基本组件介绍: 1、Activit ... -
Android学习-应用与开发环境(一)
2012-02-21 20:59 1036工程; 1、 src文件夹存放源码。 2、 gen下有跟 ... -
JSP分页实例
2011-11-07 19:29 682分页技术实现 在开发网站的项目中难免会遇到各种各样的分页操作 ... -
Servlet和JSP复习笔记
2011-11-07 19:51 7351. 理解典型的Web应用 1.1 浏览器客户端、We ...
相关推荐
本教程将深入探讨如何使用帧布局(FrameLayout)来实现霓虹灯的效果。霓虹灯效果通常指的是动态、色彩鲜艳且带有闪烁或流动感的视觉效果,常见于夜晚的广告牌或者游戏中的特效。 帧布局(FrameLayout)是Android的...
在这个"FrameLayout布局完成霓虹灯效果"的小程序中,开发者可能利用了帧布局的特点,结合其他Android图形库或者自定义视图来实现霓虹灯的动画效果。 霓虹灯效果通常涉及到颜色渐变、闪烁、线条动态流动等元素,这些...
总的来说,创建"android帧布局霓虹灯效果"需要对Android布局系统、定时器机制、Handler消息传递以及颜色动画有深入理解。通过结合这些技术,你可以为用户提供一个吸引人的交互体验,展现出炫酷的霓虹灯特效。
在这个特定的场景中,我们要利用FrameLayout来实现一种闪烁霓虹灯的效果。这种效果通常用于创建吸引用户注意力或者模拟真实世界中的霓虹灯效果,常见于各种动态UI设计中。 首先,理解霓虹灯效果的基本原理:霓虹灯...
本教程将详细介绍如何利用Android的相对布局(RelativeLayout)来实现一个不停变换颜色的霓虹灯效果。 首先,理解相对布局是关键。Relative Layout是Android提供的一种布局管理器,它允许子视图相对于其他视图或...
例如,如果你想要创建一个霓虹灯效果,可以将一个带有渐变色背景的帧布局作为基础,并在其上添加一个可动画化的文本视图,通过改变文本颜色和亮度来模拟霓虹灯闪烁。 在实际应用中,帧布局常与其他布局(如线性布局...
Android 开发实现布局帧布局霓虹灯效果示例主要介绍了 Android 开发实现布局帧布局霓虹灯效果,涉及 Android 界面布局、资源文件操作及属性设置等相关技巧。 知识点1: Android 界面布局 在 Android 开发中,界面...
霓虹灯效果在Android开发中通常用于创建炫酷的视觉效果,尤其是在游戏或者主题应用中。这个项目基于Eclipse,展示了如何实现一个简单的Android霓虹灯动画。在深入讲解之前,我们先了解一下Android开发的基本环境。 ...
在本教程中,我们将深入探讨如何通过巧妙地运用Android布局来实现霓虹灯效果,尤其是关注`FrameLayout`这一布局组件。 首先,`FrameLayout`是Android中的基本布局之一,它允许将多个视图堆叠在一起,并按照Z轴顺序...
根据提供的文件信息,我们可以分析出这是一段Android应用程序的源代码,主要功能是实现一个具有霓虹灯效果的界面。这段代码通过不断改变界面上TextView的颜色来模拟霓虹灯的效果。接下来,我们将从以下几个方面对这...
framelayout布局管理器的使用与练习,
霓虹灯效果在Android开发中通常是指通过动态改变颜色或者动画来模拟霓虹灯闪烁的效果。在这个场景中,我们利用`FrameLayout`作为容器,并结合`Handler`来实现在每1秒内进行一次颜色变化,从而达到霓虹灯的动态视觉...
在提供的"AndroidStudy"压缩包文件中,可能包含了使用这些布局实现的简单应用示例,如计算器或霓虹灯效果。通过学习和分析这些实例,开发者可以更好地理解和掌握各种布局的使用方法,进一步提升Android UI设计能力。...
这种效果能让文本像霓虹灯一样持续滚动,使得全部内容可以被用户看到。在本教程中,我们将深入探讨如何在Android应用中实现跑马灯效果。 首先,要实现跑马灯效果,我们需要使用`TextView`组件。`TextView`是Android...
在Android开发中,有时为了增加视觉效果,开发者可能会希望实现一些动态、炫酷的界面元素,比如多彩霓虹灯效果。这个效果可以通过编程来模拟,让屏幕上的元素周期性地改变颜色,给人一种霓虹灯闪烁的感觉。下面将...
在Android开发中,"跑马灯"效果通常指的是TextView或者自定义View中文字不间断滚动的效果,类似于霓虹灯招牌的动态展示。这个"Android代码-安卓跑马灯大全"资源很可能是包含了一系列实现不同跑马灯效果的示例代码,...
在Android开发中,跑马灯效果通常指的是文字或图片在界面上不断滚动,形成一种循环显示的效果,类似于现实生活中霓虹灯的动态显示。这种效果常用于通知、提示或者广告栏等场景。在这个项目中,我们将探讨如何实现...