Android——基于监听器的事件处理(转)
事件,我们并不陌生!
所有的基于UI的应用程序,事件都变得不可或缺!试想一下,如果我们做的程序单击按钮和其它控件都没有反应,那么就如同一个人在这个世界上听不到声音一样!
Android为我们提供了两种方式的事件处理:(1)基于监听器的事件处理;(2)基于回调的事件处理。
对于基于监听器的事件处理而言,主要就是为Android界面组件绑定特定的事件监听器;对于基于回调的事件处理而言,主要做法是重写Android组件特定的回调函数,Android大部分界面组件都提供了事件响应的回调函数,我们只要重写它们就行。
本章我们着重讲一下基于监听器的事件处理,基于回调的事件处理放在下一章讲解。
相比于基于回调的事件处理,这是更具“面向对象”性质的事件处理方式。在监听器模型中,主要涉及三类对象:
(1)事件源Event Source:产生事件的来源,通常是各种组件,如按钮,窗口等。
(2)事件Event:事件封装了界面组件上发生的特定事件的具体信息,如果监听器需要获取界面组件上所发生事件的相关信息,一般通过事件Event对象来传递。
(3)事件监听器Event Listener:负责监听事件源发生的事件,并对不同的事件做相应的处理。
一、第一种:内部类作为监听器
将事件监听器类定义成当前类的内部类。
a)使用内部类可以在当前类中复用监听器类,因为监听器类是外部类的内部类。
b)可以自由访问外部类的所有界面组件,这也是内部类的两个优势。
我们前面的例子全部采用的该种方式!
我们可以一起回顾一下:http://blog.csdn.net/jianghuiquan/article/details/8252430
1、activity_main.xml界面文件
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity" > <EditText
android:id="@+id/userName"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:layout_alignParentTop="true"
android:layout_marginTop="34dp"
android:ems="10" > <requestFocus />
</EditText> <EditText
android:id="@+id/passWord"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:layout_below="@+id/userName"
android:layout_marginTop="18dp"
android:ems="10"
android:inputType="textPassword" />
//定义了一个ID为login的按钮
<Button
android:id="@+id/login"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignRight="@+id/userName"
android:layout_below="@+id/passWord"
android:layout_marginTop="36dp"
android:text="登录" /> </RelativeLayout>
2、MainActivity.java程序文件
package com.genwoxue.edittextbutton; import android.os.Bundle;
import android.app.Activity;
import android.widget.EditText;
import android.widget.Button;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Toast; public class MainActivity extends Activity {
private EditText tvUserName=null;
private EditText tvPassword=null;
private Button btnLogin=null; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main); tvUserName=(EditText)super.findViewById(R.id.userName);
tvPassword=(EditText)super.findViewById(R.id.passWord);
btnLogin=(Button)super.findViewById(R.id.login); //为按钮注册监听事件
btnLogin.setOnClickListener(new LoginOnClickListener());
}
//事件监听器
private class LoginOnClickListener implements OnClickListener{
public void onClick(View v){
String username=tvUserName.getText().toString();
String password=tvPassword.getText().toString();
String info="用户名:"+username+"☆☆☆密码:"+password;
Toast.makeText(getApplicationContext(), info,Toast.LENGTH_SHORT).show();
}
}
}

面的理论也许听起来让你头大,尤其java这一套事件监听模型,让很多尽管可能是其它语言编程高手也感觉甚不适应,但如果分析上面代码,则发现实际也是非常简单的。
我们这个案例中:单击按钮,显示用户名和密码!
事件:单击事件;
(1)注册监听事件:btnLogin.setOnClickListener(new LoginOnClickListener());
(2)事件监听器:private class LoginOnClickListener implements OnClickListener
定义LoginOnClickListener类,从OnClickListener接口实现。
就这么简单!
二、第二种:匿名内部类作为事件监听器类
如果事件监听器只是临时使用一次,建议使用匿名内部类形式的事件监听器更合适。
我们仍然以上述例子为例,加以改造,学习一下如何使用“匿名内部类作为事件监听器类”。
1、界面部分不变!
activity_main.xml界面文件
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity" > <EditText
android:id="@+id/userName"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:layout_alignParentTop="true"
android:layout_marginTop="34dp"
android:ems="10" > <requestFocus />
</EditText> <EditText
android:id="@+id/passWord"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:layout_below="@+id/userName"
android:layout_marginTop="18dp"
android:ems="10"
android:inputType="textPassword" />
//定义了一个ID为login的按钮
<Button
android:id="@+id/login"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignRight="@+id/userName"
android:layout_below="@+id/passWord"
android:layout_marginTop="36dp"
android:text="登录" /> </RelativeLayout>
2、源程序加以改造!
MainActivity.java程序文件
package com.genwoxue.anonymousinside;
import android.os.Bundle;
import android.app.Activity;
import android.widget.EditText;
import android.widget.Button;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Toast;
public class MainActivity extends Activity {
private EditText tvUserName=null;
private EditText tvPassword=null;
private Button btnLogin=null;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main); tvUserName=(EditText)super.findViewById(R.id.userName);
tvPassword=(EditText)super.findViewById(R.id.passWord);
btnLogin=(Button)super.findViewById(R.id.login);
btnLogin.setOnClickListener(new OnClickListener(){
public void onClick(View v){
String username=tvUserName.getText().toString();
String password=tvPassword.getText().toString();
String info="用户名:"+username+"☆☆☆密码:"+password;
Toast.makeText(getApplicationContext(), info,Toast.LENGTH_SHORT).show();
}
});
}
}

三、对比

我们对比一下这两种写法:
1、第①种
(1)注册:btnLogin.setOnClickListener(new LoginOnClickListener());
(2)内部类:
private class LoginOnClickListener implements OnClickListener{
public void onClick(View v){
String username=tvUserName.getText().toString();
String password=tvPassword.getText().toString();
String info="用户名:"+username+"☆☆☆密码:"+password;
Toast.makeText(getApplicationContext(), info,Toast.LENGTH_SHORT).show();
}
2、第②种
实际上是把①种合二为一了,使用匿名内部类直接完成了。
btnLogin.setOnClickListener(new OnClickListener(){
public void onClick(View v){
String username=tvUserName.getText().toString();
String password=tvPassword.getText().toString();
String info="用户名:"+username+"☆☆☆密码:"+password;
Toast.makeText(getApplicationContext(), info,Toast.LENGTH_SHORT).show();
}
});
Android——基于监听器的事件处理(转)的更多相关文章
- Android笔记二十四.Android基于回调的事件处理机制
假设说事件监听机制是一种托付式的事件处理,那么回调机制则与之相反,对于基于回调的事件处理模型来说,事件源和事件监听器是统一的,或者说事件监听器全然消失了,当用户在GUI控件上激发某个事件时,控 ...
- Android的两种事件处理机制
UI编程通常都会伴随事件处理,Android也不例外,它提供了两种方式的事件处理:基于回调的事件处理和基于监听器的事件处理. 对于基于监听器的事件处理而言,主要就是为Android界面组件绑定特定的事 ...
- android学习笔记24——事件处理
事件处理 android提供了两种事件处理机制: 1.基于回调的事件处理 2.基于监听器的事件处理(通过绑定特定事件监听器) 注意: android对于基于回调的事件处理而言,主要做法就是重写andr ...
- Android零基础入门第35节:Android中基于回调的事件处理
原文:Android零基础入门第35节:Android中基于回调的事件处理 通过前面两期掌握了Android中基于监听的事件处理的五种形式,那么本期一起来学习Android中基于回调的事件处理. 一. ...
- Android的事件处理机制之基于回调的事件处理
回调机制 如果说事件监听机制是一种委托式的事件处理,那么回调机制则与之相反,对于基于回调的事件处理模型来说,事件源与事件监听器是统一的,换种方法说事件监听器完全消失了,当用户在GUI组件上激发某个事件 ...
- 基于回调的事件处理——重写onTouchEvent方法响应触摸屏事件
对于Android提供的事件处理模型,不难发现基于监听的事件处理模型具有更大的优势: 基于监听的事件模型分工更加明确,事件源.事件监听有两个类分开实现,因此具有更好的维护性. Android的事件处理 ...
- Android学习笔记(36):Android的两种事件处理方式
Android提供了两种事件处理的方式:基于回调的事件处理 和 基于监听的事件处理. 我们来说的easy理解一点: (1)基于回调的事件处理就是继承GUI组件,并重写该组件的事件处理方法.除了一些特定 ...
- Android基于XMPP的即时通讯3-表情发送
这篇博文主要讲表情发送的一些东西. 参考:Android基于XMPP的即时通讯1-基本对话 1.准备好资源文件 采用的是emoji的表情,我打包好了,下载地址:http://files.cnblogs ...
- Android基于XMPP的即时通讯2-文件传输
本文是在上一篇博文Android基于XMPP的即时通讯1-基本对话的基础上,添加新的功能,文件传输 1.初始化文件传输管理类 public static FileTransferManager get ...
随机推荐
- C-从源文件到可执行文件的详细编译链接过程
一直用windows一键搞定, 没有去了解详细的编译链接过程, 今天看了一篇文章, 顺便实验和记录在Linux下逐步生成的步骤. 预处理: 执行#include, #define, #if, #ifd ...
- HDUOJ---2642Stars(二维树状数组)
Stars Time Limit: 5000/2000 MS (Java/Others) Memory Limit: 32768/65536 K (Java/Others)Total Submi ...
- HDUOJ----2489 Minimal Ratio Tree
Minimal Ratio Tree Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Other ...
- Python 各种库的安装
在Win7 系统安装的Python 各种库,如:pandas.numpy.scipy等 因为平时使用的是IDE-PyCharm,这里可以直接 [File-Setting-Project:XXX-“+” ...
- java打包成window service服务[转]
1 解释 java project 我说的是main方法作为程序入口的java工程,有别于 web project. 这样的工程 一般都是web project的附属扫描程序或一些独立的执行程序,如 ...
- OAF_OAF Framework常用函数汇总(概念)
2014-12-31 Created By BaoXinjian
- ActiveReports 报表控件官方中文新手教程 (1)-安装、激活以及产品资源
本系列文章主要是面向初次接触 ActiveReports 产品的用户,能够帮助您在三天之内轻松的掌握ActiveReports控件的基本用法,包含安装.激活.创建报表.绑定数据源以及公布等内容. ...
- 什么是BGP线路?什么是BGP机房?
BGP(Border Gateway Protocol,边界网关协议)主要用于互联网AS(自治系统)之间的互联.BGP的最主要功能在于控制路由的传播和选择最好的路由.BGP是Internetproje ...
- STM32以太网ETH
注:stm32F1系列中F103片上不含MAC控制器,所以不支持以太网,只有F105和F107才支持
- WebService 闲聊
在http://www.2cto.com/ 中搜:WebServices学习笔记(一) WebService三要素 SOAP.WSDL(WebServicesDescriptionLanguage). ...