`

java自定义事件

 
阅读更多
摘自http://dev.10086.cn/cmdn/wiki/index.php?doc-view-4230.html
java中的事件机制的参与者有3种角色:

  1.event object:事件状态对象,用于listener的相应的方法之中,作为参数,一般存在与listerner的方法之中

  2.event source:具体的事件源,比如说,你点击一个button,那么button就是event source,要想使button对某些事件进行响应,你就需要注册特定的listener。

  3.event listener:具体的对监听的事件类,当它监听到event object产生的时候,它就调用相应的方法,进行处理。

  先看看jdk提供的event包:

  public interface EventListener:所有事件侦听器接口必须扩展的标记接口。

  public class EventObject extends Object implements Serializable

  所有事件状态对象都将从其派生的根类。 所有 Event 在构造时都引用了对象 "source",在逻辑上认为该对象是最初发生有关 Event 的对象。

  在Java2处理事件时,没有采用dispatchEvent()-postEvent()-handleEvent()方式,采用了监听器类,每个事件类都有相关联的监听器接口。事件从事件源到监听者的传递是通过对目标监听者对象的Java方法调用进行的。

  对每个明确的事件的发生,都相应地定义一个明确的Java方法。这些方法都集中定义在事件监听者(EventListener)接口中,这个接口要继承 java.util.EventListener。 实现了事件监听者接口中一些或全部方法的类就是事件监听者。

  伴随着事件的发生,相应的状态通常都封装在事件状态对象中,该对象必须继承自java.util.EventObject。事件状态对象作为单参传递给应响应该事件的监听者方法中。发出某种特定事件的事件源的标识是:遵从规定的设计格式为事件监听者定义注册方法,并接受对指定事件监听者接口实例的引用。

  首先问个问题:您熟悉java.util.EventObject 和java.util.EventListener两个类以及他们已有的子类吗?

  如果你已经能够熟练使用jdk为我们提供的事件监听器,并且很熟悉MouseEvent, KeyEvent, WindowEvent等等这些jdk为我们准备好的事件,那么想必你对java的事件机制已经有所理解。但是也许你还是觉得虽然用起来没什么问题,但是原理还是有些糊涂,那么下面我们再进一步自己实现这些事件和监听器,即自定义事件。

  其实自定义事件在java中很有用处,我们有的时候想让自己的程序产生一个事件,但有不希望(或者不可能)用鼠标,键盘之类的输入设备进行操作,比如你写一个应用程序,在这个程序中一旦收到邮件就对邮件进行相关处理,对于“收到邮件”这个事件,jdk中就没有定义。对于这样的事件,以及对于这样的事件的监听器,我们只能自己动手完成了。

那么下面就以实例开始我们这个“创新”的过程:首先,类EventObject作为父类用来生成我们自己的事件类,接口EventListener用来实现我们自己的监听器;剩下的事情就是如何注册这些事件以及测试他们了。

  (1)通过DoorEvent.java文件创建DoorEvent类,这个类继承EventObject。

  
/**

  * 定义事件对象,必须继承EventObject

  */

  package test;

  import java.util.EventObject;

  public class DoorEvent extends EventObject {

  private String doorState = "";//表示门的状态,有“开”和“关”两种

  public DoorEvent(Object source, String doorState) {

  super(source);

  this.doorState = doorState;

  }

  public void setDoorState(String doorState) {

  this.doorState = doorState;

  }

  public String getDoorState() {

  return this.doorState;

  }

  }

  (2)定义新的事件监听接口,该接口继承自EventListener;该接口包含对doorEvent事件的处理程序:
  /**

  * 定义监听接口,负责监听DoorEvent事件

  */

  package test;

  import java.util.EventListener;

  public interface DoorListener extends EventListener {

  public void doorEvent(DoorEvent event);

  }

  通过上面的接口我们再定义事件监听类,这些类具体实现了监听功能和事件处理功能。

  
/**

  * 该类为 门1监听接口的实现,做具体的开门,关门动作

  */

  package test;

  public class DoorListener1 implements DoorListener {

  public void doorEvent(DoorEvent event) {

  if(event.getDoorState()!=null&&event.getDoorState().equals("open"))

  {

  System.out.println("门1打开");

  }

  else

  {

  System.out.println("门1关闭");

  }

  }

  }

  
/**

  * 该类为 门2监听接口的实现,做具体的开门,关门,以及开灯,关灯动作

*/

  package test;

  public class DoorListener2 implements DoorListener {

  public void doorEvent(DoorEvent event) {

  if(event.getDoorState()!=null&&event.getDoorState().equals("open"))

  {

  System.out.println("门2打开,同时打开走廊的灯");

  }

  else

  {

  System.out.println("门2关闭,同时关闭走廊的灯");

  }

  }

  }

  (3)通过DoorManager.java创造一个事件源类,它用一个Collection listeners对象来存储所有的事件监听器对象,存储方式是通过addDoorListener(..)这样的方法。 notifyListeners(..)是触发事件的方法,用来通知系统:事件发生了,你调用相应的处理函数吧。

  
/**

  * 事件源对象,在这里你可以把它想象成一个控制开门关门的遥控器,

  * (如果是在swing中,就类似一个button)

  */

  package test;

  import java.util.*;

  public class DoorManager {

  private Collection listeners;

  /**

  * 添加事件

  * @param listener DoorListener

  */

  public void addDoorListener(DoorListener listener) {

  if (listeners == null) {

  listeners = new HashSet();

  }

  listeners.add(listener);

  }

  /**

  * 移除事件

  * @param listener DoorListener

  */

  public void removeDoorListener(DoorListener listener) {

  if (listeners == null)

  return;

  listeners.remove(listener);

  }

  /**

  * 触发开门事件

  */

  protected void fireWorkspaceOpened() {

  if (listeners == null)

  return;

  DoorEvent event = new DoorEvent(this, "open");

  notifyListeners(event);

  }

  /**

  * 触发关门事件

  */

  protected void fireWorkspaceClosed() {

  if (listeners == null)

return;

  DoorEvent event = new DoorEvent(this, "close");

  notifyListeners(event);

  }

  /**

  * 通知所有的DoorListener

  */

  private void notifyListeners(DoorEvent event) {

  Iterator iter = listeners.iterator();

  while (iter.hasNext()) {

  DoorListener listener = (DoorListener) iter.next();

  listener.doorEvent(event);

  }

  }

  }

  (4)好了,最后写一个测试程序测试一下我们自定义的事件吧,这段程序应该不难理解吧:)

 
 /**

  * 主程序,就想象成要开门的哪个人

  */

  package test;

  public class DoorMain {

  public static void main(String []args)

  {

  DoorManager manager = new DoorManager();

  manager.addDoorListener(new DoorListener1());//给门1增加监听器

  manager.addDoorListener(new DoorListener2());//给门2增加监听器

  //开门

  manager.fireWorkspaceOpened();

  System.out.println("我已经进来了");

  //关门

  manager.fireWorkspaceClosed();

  }

  }

  运行DoorMain

  门1打开

  门2打开,同时打开走廊的灯

  我已经进来了

  门1关闭

  门2关闭,同时关闭走廊的灯

  下面我们看一个jdk内部是如何处理事件机制的,你可以和上面的自定义事件做一个比较,你会高兴的发现机制是一样的。

 
 /**

  * java swing的监听器,实现ActionListener接口,注意参数:(事件状态类:ActionEvent)

  *

  */

  package test;

  import java.awt.*;

  import java.awt.event.*;

  import javax.swing.*;

  class SimpleListener implements ActionListener {

  /*

  * 利用该类来监听事件源产生的事件,利用响应机制

  */

  public void actionPerformed(ActionEvent e) {

  String buttonName = e.getActionCommand();

if (buttonName.equals("按钮1"))

  System.out.println("按钮1 被点击");

  }

  }

  public class ActionTest {

  private static JFrame frame; // 定义为静态变量以便main使用

  private static JPanel myPanel; // 该面板用来放置按钮组件

  private JButton button1; // 这里定义按钮组件

  public ActionTest() { // 构造器, 建立图形界面

  // 新建面板

  myPanel = new JPanel();

  // 新建按钮

  button1 = new JButton("按钮1"); // 新建按钮1

  // 建立一个actionlistener让按钮1注册,以便响应事件

  SimpleListener ourListener = new SimpleListener();

  button1.addActionListener(ourListener);

  myPanel.add(button1); // 添加按钮到面板

  }

  public static void main(String s[]) {

  ActionTest gui = new ActionTest(); // 新建Simple1组件

  frame = new JFrame("Simple1"); // 新建JFrame

  // 处理关闭事件的通常方法

  frame.addWindowListener(new WindowAdapter() {

  public void windowClosing(WindowEvent e) {

  System.exit(0);

  }

  });

  frame.getContentPane().add(myPanel);

  frame.pack();

  frame.setVisible(true);

  }

  }


  在这里,我们再看一下java中的事件机制的参与者的3种角色:

  我们定义了一个SimpleListener 实现ActionListener接口,

  1.event object:事件状态对象,用于listener的相应的方法之中。用了jdk提供的ActionEvent,不需要我们自己定义。

  2.event source:具体的事件源,就是哪个button,,注册特定的SimpleListener。

  3.event listener:具体的对监听的事件类,当它监听到event

  object产生的时候,它就调用相应的方法,进行处理。这里是我们自己定义的SimpleListener。

  是不是和上面自定义的事件在机制上完全一致呢?Yes

  ---------------------------------------------------------------------------------------------------------------------------

这里你也许会问,为什么event object不需要我们自己定义呢?你可以想一下,这是一个表示“事件状态变化”的类,你能扑获“鼠标变化”

  吗?这好象和平台有关的低层编码了,所有所不可能扑获,也没有必要去扑获,这些jdk已经给我们实现了。简单的看一下ActionEvent这个类

  ,它继承了java.awt.AWTEvent, 在这个类的构造方法源码如下:

  static {

  /* ensure that the necessary native libraries are loaded */

  Toolkit.loadLibraries();

  if (!GraphicsEnvironment.isHeadless()) {

  initIDs();

  }

  }

  我们在看jdk官方的解释:

  Toolkit是 Abstract Window Toolkit 的所有实际实现的抽象超类。Toolkit 的子类被用于将各种组件绑定到特定本机工具包实现。大多数应

  用程序不应直接调用该类中的任何方法。Toolkit 定义的方法是“胶合剂”,将 java.awt 包中与平台无关的类与 java.awt.peer 中的对应物

  连接起来。Toolkit 定义的一些方法能直接查询本机操作系统。
分享到:
评论

相关推荐

    java自定义事件监听

    Java自定义事件监听允许开发者创建自己的事件类型并相应地处理它们,以满足特定应用的需求。下面我们将深入探讨这一主题。 首先,我们需要理解Java AWT(Abstract Window Toolkit)和Swing库中的基础事件监听机制。...

    JAVA自定义事件详解

    Java自定义事件是指开发人员根据自己的需求创建的特定事件类,以扩展Java内置的事件处理机制。本文将深入讲解如何在Java中创建和处理自定义事件。 首先,我们来看`java.util.EventObject`类,它是所有Java事件类的...

    JAVA自定义事件详解.ppt

    Java 自定义事件是 Java 编程中用于组件间通信的一种机制,它允许对象在特定状态改变时通知其他对象。在给定的文件中,我们看到了一个详细的示例,讲解了如何创建并处理自定义事件。这个例子涉及到 `DemoListener` ...

    自定义事件(java).doc

    在Java编程中,自定义事件(Custom Events)是一种常见的设计模式,用于在对象之间传递信息。自定义事件允许我们创建特定于应用的事件类型,以便更好地处理和响应应用程序中的特定情况。以下是一个简单的自定义事件...

    java里的自定义实现事件

    在Java编程语言中,虽然没有像C#那样的内置委托和事件机制,但开发者可以通过自定义的方式来模拟实现事件处理。这通常涉及到观察者模式(Observer...通过阅读这些文档,你可以更好地理解和应用这些自定义事件处理机制。

    教你如何在java中自定义事件

    在Java编程中,自定义事件是扩展应用程序功能和实现组件间通信的重要手段。当你需要在类之间传递特定信息或触发特定行为时,自定义事件能提供极大的灵活性。本教程将深入探讨如何在Java中创建并使用自定义事件,以...

    java 自定义注解验证

    在本案例中,作者创建了三个自定义注解,具体细节虽未详述,但我们可以深入探讨一下Java自定义注解的基本概念、创建过程以及如何进行验证。 首先,我们需要理解Java注解的基本原理。注解是一种元数据,它提供了一种...

    【java自定义爱心并输出到文件】java自定义爱心并输出到文件

    javajava自定义爱心并输出到文件java自定义爱心并输出到文件java自定义爱心并输出到文件java自定义爱心并输出到文件java自定义爱心并输出到文件java自定义爱心并输出到文件java自定义爱心并输出到文件java自定义爱心...

    FreeSwitch完整的自定义模块定义和改善自定义事件的例子

    本篇文章将深入探讨如何定义和优化自定义模块,以及处理自定义事件。 首先,理解FreeSwitch模块的生命周期是至关重要的。一个模块通常包括加载、初始化、运行和卸载四个阶段。在加载阶段,模块被FreeSwitch核心加载...

    23.java自定义异常.zip

    23.java自定义异常.zip23.java自定义异常.zip23.java自定义异常.zip23.java自定义异常.zip23.java自定义异常.zip23.java自定义异常.zip23.java自定义异常.zip23.java自定义异常.zip23.java自定义异常.zip23.java...

    java自定义注解接口限流demo

    java自定义注解接口限流demo; java自定义注解接口限流demo; java自定义注解接口限流demo; java自定义注解接口限流demo; java自定义注解接口限流demo; java自定义注解接口限流demo; java自定义注解接口限流demo...

    java自定义标签.......java自定义标签

    Java自定义标签是JavaServer Pages (JSP)技术的一个强大特性,它允许开发者扩展JSP的标准标签库,创建自己的定制化标签,以提高代码的可读性和可维护性。自定义标签可以封装复杂的业务逻辑或者视图呈现,使得页面...

    Java自定义注解实例

    Java自定义注解是Java编程语言中的一个重要特性,它允许程序员在代码中插入元数据,这些元数据可以被编译器或运行时环境用来执行特定的任务。自定义注解不仅提高了代码的可读性,还简化了代码处理,特别是在框架和库...

    java自定义标签教程

    首先,Java自定义标签是一个Java类,它可以实现`javax.servlet.jsp.tagext.Tag`接口或者其子接口。这个接口定义了标签的生命周期方法,如`doStartTag()`和`doEndTag()`,这些方法在标签的生命周期中被容器调用来执行...

    Java自定义日志模块实现

    自定义日志模块(接口及代理实现),而不直接使用第三方日志框架接口,避免在日志框架升级或者切换时,代码过多耦合。 这个举例说明一下: 比如,在某一项目开始时使用的是“log4j”框架,后面经过研究发现“sf4j...

    java自定义线程模型处理方法分享

    Java自定义线程模型在软件开发中扮演着重要的角色,特别是在高性能、高并发的应用场景,如游戏服务器。本文将深入探讨如何在Java中构建自定义线程模型,并分享一些实践经验。 首先,我们要明白为什么要自定义线程...

    Java自定义光标程序源码

    Java自定义光标程序源码

    java自定义集合类

    以下是对"java自定义集合类"这一主题的详细解释。 首先,Java集合框架包括接口(如List、Set、Map)和实现这些接口的类(如ArrayList、HashSet、HashMap)。这些类提供了基础的数据结构和方法,如添加元素、删除...

    java快速自定义查询实现

    Java自定义查询的实现旨在简化开发过程中对于复杂查询需求的处理,通过配置化的方式,让开发者能够快速构建查询界面和执行相应的SQL指令。以下是实现这一功能的关键步骤和细节: 1. **模块配置**: - 模块配置是...

Global site tag (gtag.js) - Google Analytics