Unit 2: Event Handling
This unit covers the following
o Two event handling mechanism
o The delegation event model: events, event sources, event listeners
o The KeyEvent class: MouseEvent Class, TextEvent Class, WindowEvent Class
o Source of Events
o Event Listener Interfaces
ActionListener, KeyListener, MouseListener, WindowListener, ContainerListener
o Using Delegation event Model
Handling mouse events, handling keyboard events
o Adapter classes, Inner classes
Event Handling in Java
There are fundamental differences between the console program and a window based java program. With a
console program, the program codes determine the sequence of events. Generally everything is predetermined. At
any time specific code to be executed next is generally known. A window based application is quite different. The
operation of the program is driven by what is done with the GUI. Selecting menus or buttons using mouse or
keyboard causes particular action within the program. At any given moment the whole range of possible
interactions available will result in the different program action. Until something is done the specific program code
that is to be executed next is not known.
Event
In Java, events represent the activities that occur between the application and user. Event handling is an essential
to GUI programming. A GUI application waits for the user to perform some action. When the user performs the
action, the application executes appropriate code, which handles the action in a predefined manner. In general,
the signal that a program received from the operating system as a result of the actions is called events. Window
based program is called an event driven program, because the sequence of events are executed as a result of the
interaction with the GUI drives and determines what happens in the program.
Event Handling Mechanism in Java
There are two fundamental events handling mechanism in java, which are:
Handling the Events by extending AWT components.
Handling the Events using the Delegation Event model
Handling the events by extending AWT components
A self-contained component is one that handles events that it generates. None of the standard AWT
components are self-contained, so to handle events subclasses need to be created. It is a model for
event processing of AWT is based on inheritance. However, this technique is not used but java supports
it. To handle events of AWT components using this technique we extend the AWT components like
button, Checkbox etc.
The event mask defined in this class AWTEvent are needed by Component subclasses which are using
Component.enableEvents () to select for event types not selected by registered listeners. If a listener is
registered on a component, the appropriate event mask is already set internally by the component.
ACTION_EVENT_MASK: The event mask for selection adjustment events.
ADJUSTMENT_EVENT_MASK: The event mask for selecting container events.
CONTAINER_EVENT_MASK : The event mask for selecting container events.
1
KEY_EVENT_MASK : The event mask for selecting key events
WINDOW_EVENT_MASK: The event mask for selecting window events
MOUSE_EVENT_MASK: The event mask for selecting mouse events
The process method is overridden inorder to process of an event
Button() processActionEvent()
Checkbox processItemEvent (); etc.
The following example demonstrates handling an action event by extending button. To create an action
event we simply extedn Button class.
Consider the following program.
import java.awt.*;
import java.awt.event.*;
import java.applet.*;
public class ButtonDemmo extends Applet{
MyButton myButton;
static int i=0;
public void init(){
myButton = new MyButton ("Test Button");
add(myButton);
}
class MyButton extends Button{
public MyButton(String label){
super(label);
enableEvents(AWTEvent.ACTION_EVENT_MASK);
}
protected void processActionEvent(ActionEvent ae){
showStatus("Action event:"+i++);
super.processActionEvent(ae);
}
}
}
The above program creates an applet that displays a button labeled with "Test Button". When the
button is pressed, the string "action event" is displayed on the status line of the applet viewer or
browser, flowed by a count of the number of buttons pressed.
The program has one top level class named ButtonDemmo that extends Applet. A static integer variable
named I is defined and initialized to zero. This records the number of buttons pushes. The init() method
instantiates MYButton and adds it to the applet.
MyButton is an inner class that extends Button. Its constructor uses super to pass the label of the button
to the superclass constructor. It is calls enableEvents() so that action events may be received by this
object. When an action event is generated, processActionEvent () is called. That method displays a string
on the status line and calls processActionEvent() for the superclass. Because MyButton is an Inner class,
it has direct access to the showStatus () method of ButtonDemmo
2
The Delegation Event Model
The modern approach for handling events is based on the delegation event model, which defines standard and
consistent mechanism to generate and process events. In this model, an Event source generates and event and
sends it to one or more listeners. The listener simply waits until it receives an event. The listener receives the
events and processes it. The advantage of this design is that the application logic that processes events is cleanly
separated from user interface logic that generates those events.
A user interface element is able to “delegate” the processing of an event to separate piece of code. In the
delegation event model, listeners must register with a source in order to receive an event notification. This
provides an important benefit: notifications are sent to only to listeners that want to receive them.
The following elements are necessary to understand event handling
Event Sources
A source is an object that generates an event. This occurs when the internal state of that object changes in some
way. Sources may generate more than one type of event.
A source must register listeners in order for the listeners to receive notifications about a specific type of event.
Each type of event has its own registration method. Here is the general form:
public void addTypeListener (TypeListener el)
Here, Type is the name of the event, and el is a reference to the event listener. For example, the method that
registers a keyboard event listener is called addKeyListener ().
Some source may allow only one listener to register. When such an event occurs, the registered listener is notified.
This is known as unicasting the event.
Event Listeners
A listener is an object that is notified when an event occurs. It has two major requirements. First, it must have
been registered with one or more sources to receive notifications about specific types of events. Second, it must
implement methods to receive and process these notifications.
The methods that receive and process events are defined in a set of interfaces in java.awt.event. For example, the
MouseMotionListener interface defines two methods to receive notifications when the mouse is dragged or
moved. An object may receive and process one or both of these events if it provides an implementation of this
interface
Event Classes
The classes that represent events are at the core of Java’s event handling mechanism. At the root of the Java event
class hierarchy is EventObject, which is in java.util. It is the superclass for all events. Its one constructor is shown
here:
EventObject (Object src)
Here, src is the object that generates this event.
EventObject contains two methods: getSource () and toString (). The getSource () method returns the source of
the event. Its general form is shown here:
Object getSource ();
The toString () returns the string equivalent of the event.
The class AWTEvent, defined within the java.awt package is a subclass of EventObject. It is the superclass of all of
all AWT based events used by the delegation event model. Its getID() method can be used to determine the type of
the event. The signature of this method is shown here:
3
The ActionEvent Class
An ActionEvent is generated when a button is pressed, a list item is doubled clicked or a menu item is selected. The
other main event classes in java.awt.event are as follows
Event Class Description
ActionEvent Generates when a button is pressed, a list of item is double clicked or a menu item is
selected.
AdjustmentEvent Generates an event when a scroll bar is manipulated
ComponentEvent Generated when a component is hidden, moved, resized, or becomes available
ContainerEvent Generated when a component is added to or removed from a container
FocusEvent Generated when a component gains or loses keyboard focus
InputEvent Abstract superclass for all component input event classes
ItemEvent Generated when a check box or list item is clicked. Also occurs when a choice selection is
made or a checkable menu item is selected or deselected.
KeyEvent Generated when a input is received from the keyboard
MouseEvent Generated when the mouse is dragged, moved, clicked, pressed or released. Also
generated when the mouse enters or exists a components
MouseWheelEvent Generated when the mouse wheel is moved
TextEvent Generated when the value of a text area or text field is changed
WindowEvent Generated when a window is activated, closed, deactivated, deiconified, icoified, opened
or quit
The MouseEventClass
There are eight types of mouse events. The MouseEvent class defines the following integer constants that can be
used to identify them.
MOUSE_CLICKED The use clicked the mouse
MOUSE_DRAGGED The user dragged the mouse
MOUSE_ENTERED The mouse entered a component
MOUSE_EXITED The mouse exited from a component
MOUSE_MOVED The mouse moved
MOUSE_PRESSED The mouse was pressed
MOUSE_WHEEL The mouse wheel was moved
MOUSE_RELEASED The mouse was released
The most commonly used methods in this class are getX () and getY(). These returns the X and Y coordinate of the
mouse when the event occurred. Their forms are shown are here:
int getX();
int getY();
The MouseWheelEvent Class:
The MouseWheelEventClass encapsulates a mouse wheel event. It is a subclass of MouseEvent. Not all mice have
wheels. It a mouse has a wheel; it is located between the left and right buttons. Mouse wheels are used for
scrolling. MouseWheelEvent defines these two integer constants.
WHEEL_BLOCK_SCROL A page up or page down scroll event occurred
L
WHEEL_UNIT_SCROLL A line up or line down scroll event occurred
4
The MouseWheelEvent defines methods that give access to the wheel event. To obtain the number of rotational
units, call getWheelRotation (), shown below.
Int getWheelRotation ()
It returns the number of rotational units. If the value is positive, the wheel moved counterclockwise. If the value is
negative, the wheel moved clockwise.
The KeyEvent Class
The KeyEvent is generated when keyboard input occurs. There are three types of key events, which are identified
by these integer constants: KEY_PRESSED, KEY_RELEASED, and KEY_TYPED. The first two events are generated
when the key is pressed or released. The last event occurs only when a character is generated.
There are many other integer constants that are defined by KeyEvent. For example, VK_0 through VK_9 and VK_A
through VK_Z define the ASCII equivalents of the numbers and letters. Here are some others:
VK_ALT VK_DOWN VK_LEFT VK_RIGHT
VK_CANCEL VK_ENTER VK_PAGE_DOWN VK_SHIFT
VK_CONTROL VK_ESCAPE VK_PAGE_UP VK_UP
The VK constants specify virtual key code and are independent of any modifiers, such as control, shift, or alt.
KeyEvent is a subclass of InputEvent. Here is one of its constructors:
KeyEvent (Component src, int type, long when, int modifiers, int code, char ch)
Here, src is a reference to the component that generated the event. The type of the event is specified by type. The
system time at which the key was pressed is passed in when. The virtual key code, such as VK_UP, VK_A, and so
forth, is passed in code. The character equivalent is passed in ch. If no valid character exists, then ch contains
CHAR_UNDEFINED. For KEY_TYPED events, code will contain VK_DEFINED.
The KeyEvent class defines several methods, but the most commonly used ones are getKeyChar (), which returns
the character that was entered, and getKeyCode (), which returns the key code. Their general forms are shown
here:
char charKeyChar()
int getKeyCode()
if no valid character is available, then getKeyChar() returns CHAR_UNDEFINED. When a KEY_TYPED event occurs,
getKeyCode () returns VK_UNDEFINED.
The TextEventClass
Instances of this class describe text events. These are generated by text fields and text areas when characters are
entered by a user or program. TextEvent defines the integer constant TEXT_VALUE_CHANGED.
The one constructor for the class is shown here:
TextEvent (Object src, int type)
Here, src is a reference to the object that generated this event. The type of the event is specified by type.
The TextEvent object does not include the characters currently in the text component that generated the event.
5
The WindowEvent Classes
There are ten window events. The WindowEvent class defines integer constants that can be used to identify them.
The constants and their meanings are shown here:
WINDOW_ACTIVATED The window was activated
WINDOW_CLOSED The window has been closed
WINDOW_CLOSING The user requested that the window be closed
WINDOW_DEACTIVATED The window was deactivated
WINDOW_DEICONIFIED The window was deiconified
WINDOW_GAINED_FOCUS The window gained input focus
WINDOW_ICONIFIED The window was iconified
WINDOW_LOST_FOCUS The window lost input focus
WINDOW_OPENNED The window was opened
WINDOW_STATE_CHANGE The state of the window changed
D
Sources of Events
Event Source Description
Button Generates action events when the button is pressed
Checkbox Generates item events when the check box is selected or deselected.
Choice Generates item events when the choice is changed
List Generates action events when an item is double clicked; generates item events when an
item is selected or deselected.
Menu Item Generates action events when an item double clicked; generates item events when a
checkable menu item is selected or deselected
Scrollbar Generates adjustment events when the scroll bar is manipulated
Text Components Generates text events when the user enters a character.
Window Generates window events when a window is activated, closed, deactivated, deiconified,
iconified, opened or quit
Event Listener Interfaces
The delegation event model has two parts: source and listeners. Listeners are created by implementing one or
more of the interfaces defined by the java.awt.event package. When an event occurs, the event source invokes the
appropriate method defined by the listener and provides an event object as its arguments. The following table lists
commonly used listener interfaces and provides a brief description of the methods that they define.
Interface Description
ActionListener Defines one method to receive action events
AdjustmentListener Defines one method to receive adjustment events.
ComponentListener Defines four methods to recognize when a component is hidden, moved, resized, or
shown
ContainerListener Define two methods to recognize when a component is added to or removed from a
container
FocusListener Defines two methods to recognize when a component gains or loses keyboard focus
ItemListener Defines one method to recognize when the state of an item is changed
KeyListener Defines three methods to recognize when a key is pressed, released or typed
MouseListener Defines five methods to recognize when the mouse is clicked, enters a component,
6
exists a component, is pressed or is released.
MouseMotionListener Defines two methods to recognize when the mouse is dragged or moved
MouseWheelListener Defines one method to recognize when a text value changes
TextListener Defines two methods to recognize when a window gains or losses input focus
WindowFocusListener Defines two methods to recognize when a window gains or loses input focus
WindowListener Defines seven methods to recognize when a window is activated, closed, deactivated ,
deiconified, opened, or quit
The ItemListener Interface
This interface defines the itemStateChanged() method that invoked that is invoked when the state of an item
changes. Its general form is shown here:
void itemStateChanged (ItemEvent ie)
The KeyListener Interface
This interface defines three methods. The KeyPressed () and keyreleased () methods are invoked when a key is
pressed and released respectively. The keyTyped () method is in invoked when a character has been entered.
When a user presses a key and releases the key, three events are generated in sequence: key pressed, typed and
released. The general forms of these three methods are:
void KeyPressed (KeyEvent ke)
void keyreleased (KeyEvent ke)
void keyTyped (KeyEvent ke)
The MouseListener Interface
The interface defines five methods. If the mouse is pressed and released at the same point, mouseClicked ()
method is invoked. When the mouse enters a component, the mouseEntered () method is called. When a mouse
leaves, mouseExited () is called. The mousePressed () and mouseReleased () methods are invoked when the
mouse is pressed and released, respectively. The general forms of these methods are shown here:
void mouseClicked (MouseEvent me)
void mouseEntered (MouseEvent me)
void mouseExited (MouseEvent me)
void mousePressed (MouseEvent me)
void mouseReleased (MouseEvent me)
MouseMotionListener Interface
This interface defines two methods. The mouseDragged () method is called multiple times as the mouse is dragged.
The mouseMoved () method is called multiple times as the mouse is moved. Their general form are as shown here:
void mouseDragged (MouseEvent me)
void mouseMoved (MouseEvent me)
The MouseWheelListener Interface
This interface defines the mouseWheelMoved () method that is invoked when the mouse wheel is moved. Its
general from is shown here:
void mouseWheelMoved (MouseWheelEvent mwe)
7
The WindowFocusListener Interface
This interface defines two methods: windowGainedFocus () and windowLostFocus (). These are called when a
window gains or loses input focus. Their general forms are shown here:
void windowGainedFocus (WindowEvent we)
void windowLostFocus (WindowEvent we)
The WindowListener Interface
This interface defines seven methods. The windowActivated () and window Deactivated () methods are invoked
when a window is activated or deactivated, respectively. If a window is iconified, the windowIconified () method is
called. When a window is deiconified, the windowDeiconified () method is called. When a window is opened or
closed, the windowOpened () or windowClosed () methods are called respectively. The windowClosing () method
is called when a window is being closed. The general forms of these methods are:
void windowActivated (WindowEvent we)
void windowClosed (WindowEvent we)
void windowClosing (WindowEvent we)
void windowDeactivated (WindowEvent we)
void windowDeiconified (WindowEvent we)
void windowIconified (WindowEvent we)
void windowOpened (WindowEvent we)
Using the Delegation Event Model
Applet programming using the delegation event model is actually quite easy. We just follow these two steps
1. Implement the appropriate interface in the listener so that it will receive the type of event desired
2. Implement code to register and unregister (if necessary) the listener as a recipient for the event
notifications.
A source may generate several types of events. Each event must be registered separately. Also, an object may
register to receive several types of events, but it must implement all of the interfaces that are required to receive
these events.
Handling Mouse Event
The MouseEvent is used to indicate an event that is generated when there is user interaction with mouse. A mouse
event is generated when a user clicks the mouse button or moves the mouse. To handle mouse event, you need to
implement the MouseListener and the MouseMotionListener interface.
The following program shows mouse events
import java.awt.*;
import java.awt.event.*;
import java.applet.*;
public class MouseEventHandling extends Applet implements MouseMotionListener, MouseListener{
String msg = " ";
int mouseX = 0;
int mouseY = 0;
public void init(){
addMouseListener(this);
8
addMouseMotionListener(this);
}
public void mouseClicked(MouseEvent me){
mouseX = 0;
mouseY = 0;
msg = "Mouse Clicked";
repaint();
}
public void mouseEntered(MouseEvent me){
mouseX = 0;
mouseY = 0;
msg = "Mouse Entered";
repaint();
}
public void mouseExited(MouseEvent me){
mouseX = 0;
mouseY = 0;
msg = "Mouse Exited";
repaint();
}
public void mousePressed(MouseEvent me){
mouseX = me.getX();
mouseY = me.getY();
msg = "Mouse Down";
repaint();
}
public void mouseReleased(MouseEvent me){
mouseX = me.getX();
mouseY = me.getY();
msg = "Mouse Up";
repaint();
}
public void mouseDragged(MouseEvent me){
mouseX = me.getX();
mouseY = me.getY();
msg = "*";
showStatus("Draging mouse at"+mouseX+ " ,"+mouseY);
repaint();
}
public void mouseMoved(MouseEvent me){
mouseX = me.getX();
mouseY = me.getY();
msg = "Mouse Down";
showStatus("Mouse moved at "+mouseX+ " ,"+mouseY);
repaint();
9
}
public void paint(Graphics g){
g.drawString(msg, mouseX, mouseY);
}
}
Handling Key Events
The KeyEvent class is used to indicate an event that is generated during user interaction with the keyboard. This
class is used to handle events such as key press, key released, or both. To handle key release events, you need to
implement the KeyListener interface. Some methods which are in the KeyEvent are:
public int getkeycode():retrieve the key code for a given character
public int getkeychar() : Retrieve the character equivalent of a given key code
Consider the following code:
import java.awt.*;
import java.awt.event.*;
import java.applet.*;
public class SimpleKey extends Applet implements KeyListener{
String msg = " ";
int X = 10;
int Y = 20;
public void init(){
addKeyListener(this);
requestFocus();
}
public void keyPressed(KeyEvent ke){
showStatus("Key Down");
}
public void keyReleased(KeyEvent ke){
showStatus("Key up");
}
public void keyTyped(KeyEvent ke){
msg+=ke.getKeyChar();
repaint();
}
public void paint(Graphics g){
g.drawString(msg, X, Y);
}
}
Adapter Classes
Java provides special features, called an adapter class, which can simplify the creation of event handlers in certain
situations. An adapter class provides an empty implementation of all methods in an event listener interface.
Adapter classes useful when we want to receive and process only some of the events that are handled by a
particular event listener interface. We define a new class to act as an event listener by extending one of the
adapter classes and implementing only those events in which we are interested.
For example, the MouseMotionAdapter class has two methods, mouseDragged () and mouseMoved ().The
signature of these empty methods are exactly as defined in the MouseMotionListener interface. If we are only
10
interested in only mouse drag events, then we could simply extend MouseMotionAdapter and implement
mouseDragged ().
The commonly used Listener Interfaces implemented by Adapter Classes are shown in table below
Adapter Class Listener Interface
ComponentAdapter ComponentListener
ContainerAdapter ContainerListener
FocusAdapter FocusListener
KeyAdapter KeyListener
MouseAdapter MouseListener
MouseMotionAdapter MouseMotionListener
WindowAdapter WindowListener
The following example demonstrates an adapter. It displays a message in the status bar of an applet viewer or
browser when the mouse is clicked or dragged. However, all other mouse events are silently ignored. The program
has three classes. AdapterDemo extends Applet. Its init () method creates an instance of MyMouseAdapter and
registers that object to receive notifications of mouse events. It also creates an instance of MyMouseAdapter and
registers that object to receive notifications of mouse motion events. Both of the constructors take a reference to
the applet as an argument.
MyMouseAdapter implements the mouseClicked () method. The other mouse events are silently ignored by code
inherited from the MouseAdapter class. MouseMotionAdapter implements the mouseDragged () method. The
other mouse event is silently ignored by code inherited from the MouseMotionAdapter class.
import java.awt.*;
import java.awt.event.*;
import java.applet.*;
/*
<applet code="AdapterDemo" width=300 height=100>
</applet>
*/
public class AdapterDemo extends Applet {
public void init() {
addMouseListener (new MyMouseAdapter(this));
addMouseMotionListener (new MyMouseMotionAdapter(this));
}
}
class MyMouseAdapter extends MouseAdapter {
AdapterDemo adapterDemo;
public MyMouseAdapter(AdapterDemo adapterDemo) {
this.adapterDemo = adapterDemo;
}
// Handle mouse clicked.
public void mouseClicked(MouseEvent me) {
adapterDemo.showStatus ("Mouse clicked");
}
}
11
class MyMouseMotionAdapter extends MouseMotionAdapter {
AdapterDemo adapterDemo;
public MyMouseMotionAdapter(AdapterDemo adapterDemo) {
this.adapterDemo = adapterDemo;
}
public void mouseDragged(MouseEvent me) {
adapterDemo.showStatus ("Mouse dragged");
}
}
Inner Classes
The inner class is a class defined within another class or even within an expression. Here it is used to simplify code
when using the event adapter classes.
To understand the benefits provided by inner classes, consider the applet. It does not use an inner class. Its goal is
to display the string “Mouse Pressed” in the status bar of the applet viewer or browser when the mouse is pressed.
There are two top level classes in this program. MousePressedDemo extends Applet, and MyMouseAdapter
extends MouseAdapter. The init () method of MousePressedDemo instantiates MyMouseAdapter and provides
this object as an argument to the addMouseListener.
It can be noticed that a reference to the applet is supplied as an argument to the MyMouseAdapter constructor.
This reference is stored in an instance variable for later use by the mousePressed () method. When the mouse is
pressed, it invokes the showStatus () method of the applet through the stored applet reference.
package randomfile;
import java.applet.*;
import java.awt.event.*;
public class InnerClassDemo extends Applet{
public void init(){
addMouseListener(new MyMouseAdapter());
}
class MyMouseAdapter extends MouseAdapter {
public void mousePressed(java.awt.event.MouseEvent me){
showStatus("Mouse pressed");
}
}
} Anonymous Inner Classes
An anonymous inner class is one that is not assigned a name. This section illustrates how anonymous inner class
can facilitate the writing of event handlers. Consider the applet shown in the following listing. Its goal is to display
the string “Mouse Pressed “in the status bar of the applet viewer when the mouse is pressed.
import java.applet.*;
import java.awt.event.*;
public class AnonymousInnerClassDemo extends Applet {
public void init(){
addMouseListener(new MouseAdapter(){
public void mousePressed(MouseEvent me){
showStatus("Mouse Pressed");
12
}
});
}
}
There is one top level class in this program: AnonymousInnerClass. The init() method calls the addMouseListener ()
method. Its argument is an expression that defines and instantiates an anonymous inner class.
The syntax new MouseAdapter() {…..} indicates to the compiler that the code between the braces defines an
anonymous inner class. Furthermore, that class extends MouseAdapter. This new class is not named, but it is
automatically instantiated when this expression is executed.
Because the anonymous inner class is defined within the scope of AnonymousClassDemo, it has access to all of the
variables and methods within the scopes of that class. Therefore, it can call the showStatus () method directly.
13