Chapter 7 (Book Chapter 14)

Slides:



Advertisements
Similar presentations
Chapter 6 Graphical User Interface (GUI) and Object-Oriented Design (OOD)
Advertisements

©TheMcGraw-Hill Companies, Inc. Permission required for reproduction or display. Chapter 7 Event-Driven Programming and Basic GUI Objects.
COMPSCI 125 Spring 2005 ©TheMcGraw-Hill Companies, Inc. Permission required for reproduction or display. Chapter 7 : Event-Driven Programming and GUI Objects.
1 Event Driven Programming with Graphical User Interfaces (GUIs) A Crash Course © Rick Mercer.
Chapter 7 Event-Driven Programming and Basic GUI Objects.
©The McGraw-Hill Companies, Inc. Permission required for reproduction or display. 4 th Ed Chapter Chapter 14 GUI and Event-Driven Programming.
©The McGraw-Hill Companies, Inc. Permission required for reproduction or display. 4 th Ed Chapter Chapter 14 GUI and Event-Driven Programming.
©The McGraw-Hill Companies, Inc. Permission required for reproduction or display. 4 th Ed Chapter Chapter 14 GUI and Event-Driven Programming.
Unit 111 Java GUI Components and Events  Learning Outcomes oDistinguish between GUI components and containers. oIdentify and distinguish top-level containers.
©The McGraw-Hill Companies, Inc. Permission required for reproduction or display. Chapter Chapter 14 GUI and Event-Driven Programming.
GUI and Event-Driven Programming Part 2. Event Handling An action involving a GUI object, such as clicking a button, is called an event. The mechanism.
GUI and event-driven programming An introduction.
Java Programming Chapter 10 Graphical User Interfaces.
1 Event Driven Programming wirh Graphical User Interfaces (GUIs) A Crash Course © Rick Mercer.
Java Programming: From Problem Analysis to Program Design, Second Edition1  Learn about basic GUI components.  Explore how the GUI components JFrame,
Applets and Frames CS 21a: Introduction to Computing I First Semester,
Introduction to GUI in Java 1. Graphical User Interface Java is equipped with many powerful,easy to use GUI component such as input and output dialog.
GUI programming Graphical user interface-based programming.
Graphical User Interface in Java
Graphic User Interface. Graphic User Interface (GUI) Most of us interact with computers using GUIs. GUIs are visual representations of the actions you.
GUI Clients 1 Enterprise Applications CE00465-M Clients with Graphical User Interfaces.
Graphics and Event-Driven Programming in Java John C. Ramirez Department of Computer Science University of Pittsburgh.
Even-Driven Programming and basic Graphical User Interface.
Applets and Frames. Copyright 2005, by the authors of these slides, and Ateneo de Manila University. All rights reserved L14: GUI Slide 2 Applets Usually.
© Copyright by Deitel & Associates, Inc. and Pearson Education Inc. All Rights Reserved. 1 Outline 21.1 Test-Driving the Painter Application.
Java GUI. Graphical User Interface (GUI) a list a button a text field a label combo box checkbox.
DCS2133 Object Oriented Programming Graphical User Interface & Event-Driven Programming.
Introduction to GUI in 1 Graphical User Interface 2 Nouf Almunyif.
©The McGraw-Hill Companies, Inc. Permission required for reproduction or display. Chapter Chapter 7-2 ( Book Chapter 14) GUI and Event-Driven Programming.
Basics of GUI Programming Chapter 11 and Chapter 22.
© Copyright by Deitel & Associates, Inc. and Pearson Education Inc. All Rights Reserved. 1 Tutorial 4 – Completing the Inventory Application.
Sadegh Aliakbary Sharif University of Technology Fall 2011.
1 Event Driven Programs with a Graphical User Interface Rick Mercer.
JAVA: An Introduction to Problem Solving & Programming, 6 th Ed. By Walter Savitch ISBN © 2012 Pearson Education, Inc., Upper Saddle River,
Event-Driven Programming F Procedural programming is executed in procedural order. F In event-driven programming, code is executed upon activation of events.
Chapter 10 - Writing Graphical User Interfaces1 Chapter 10 Writing Graphical User Interfaces.
Swing GUI Components So far, we have written GUI applications which can ‘ draw ’. These applications are simple, yet typical of all Java GUI applications.
Lesson 28: More on the GUI button, frame and actions.
5-1 GUIs and Events Rick Mercer. 5-2 Event-Driven Programming with Graphical user Interfaces  Most applications have graphical user interfaces to respond.
CIS 270—Application Development II Chapter 11—GUI Components: Part I.
1 A Quick Java Swing Tutorial. 2 Introduction Swing – A set of GUI classes –Part of the Java's standard library –Much better than the previous library:
1 Event Driven Programming with Graphical User Interfaces (GUIs) A Crash Course © Rick Mercer.
©The McGraw-Hill Companies, Inc. Permission required for reproduction or display. Chapter Chapter 7 ( Book Chapter 14) GUI and Event-Driven Programming.
©TheMcGraw-Hill Companies, Inc. Permission required for reproduction or display. Chapter 7 Event-Driven Programming and Basic GUI Objects.
Lecture 15 Basic GUI programming
GUIs and Events Rick Mercer.
CSC 205 Programming II Lecture 5 AWT - I.
Chapter 8 Event Handling.
A First Look at GUI Applications
“Form Ever Follows Function” Louis Henri Sullivan
Graphical User Interface (pronounced "gooey")
Java Programming: From Problem Analysis to Program Design,
A Quick Java Swing Tutorial
Ellen Walker Hiram College
Chapter 13: Advanced GUIs and Graphics
Course Outcomes of Advanced Java Programming AJP (17625, C603)
Timer class and inner classes
Graphical user interface-based programming
Chapter 7-3 (Book Chapter 14)
Chapter 7-2 (Book Chapter 14)
A Quick Java Swing Tutorial
Advanced Programming in Java
Constructors, GUI’s(Using Swing) and ActionListner
Chapter 7-2 (Book Chapter 14)
Chapter 5 Processing Input with Applets
CiS 260: App Dev I Chapter 6: GUI and OOD.
GUI and Event-Driven Programming
Advanced GUIs and Graphics
Graphical User Interface
Presentation transcript:

Chapter 7 (Book Chapter 14) Introduction to OOP with Java 4th Ed, C. Thomas Wu Chapter 7 (Book Chapter 14) GUI and Event-Driven Programming ©The McGraw-Hill Companies, Inc. Permission required for reproduction or display. © The McGraw-Hill Companies, Inc.

Intro to OOP with Java, C. Thomas Wu Objectives After you have read and studied this chapter, you should be able to Define a subclass of JFrame to implement a customized frame window. Write event-driven programs using Java's delegation-based event model Write GUI application programs using JButton, JLabel, ImageIcon, JTextField, and JTextArea. Understand GUI application programs with menus Understand GUI application programs that process mouse events We will learn how to create a customized frame window by defining a subclass of the JFrame class. Among the many different types of GUI objects, arguably the buttons are most common. We will learn how to create and place buttons on a frame in this lesson. ©The McGraw-Hill Companies, Inc.

Graphical User Interface Intro to OOP with Java, C. Thomas Wu Graphical User Interface In Java, GUI-based programs are implemented by using classes from the javax.swing and java.awt packages. The Swing classes provide greater compatibility across different operating systems. They are fully implemented in Java, and behave the same on different operating systems. The Swing classes are called lightweight classes and the AWT classes heavy- weight classes. As a general rule, because they are implemented differently, it is best not to mix Classes we use to develop GUI-based programs are located in two packages javax.swing and java.awt. Many of the classes in the java.awt package are replaced by Swing counterparts, and for the most part, using the Swing classes over the AWT classes is the preferred approach because the newer Swing classes are better implementation. We still have to refer to java.awt package because there are some classes that are defined only in the java.awt package. ©The McGraw-Hill Companies, Inc. Permission required for reproduction or display. ©The McGraw-Hill Companies, Inc.

Intro to OOP with Java, C. Thomas Wu Sample GUI Objects Various GUI objects from the javax.swing package. Here's a sample frame that includes a number of common Swing components. We will see examples using JFrame and JButton in this lesson. We will see other components in the later lessons of this module. ©The McGraw-Hill Companies, Inc. Permission required for reproduction or display. ©The McGraw-Hill Companies, Inc.

Intro to OOP with Java, C. Thomas Wu JOptionPane Using the JOptionPane class is a simple way to display the result of a computation to the user or receive an input from the user. We use the showMessageDialog class method for output. If we pass null as the first argument, the dialog appears on the center of the screen. If we pass a frame object as the first argument, the dialog is positioned at the center of the frame. ©The McGraw-Hill Companies, Inc. Permission required for reproduction or display. ©The McGraw-Hill Companies, Inc.

Using JOptionPane for Output Intro to OOP with Java, C. Thomas Wu Using JOptionPane for Output import javax.swing.*; . . . JOptionPane.showMessageDialog( null, “I Love Java” ); ©The McGraw-Hill Companies, Inc. Permission required for reproduction or display. ©The McGraw-Hill Companies, Inc.

Using JOptionPane for Output - 2 Intro to OOP with Java, C. Thomas Wu Using JOptionPane for Output - 2 import javax.swing.*; . . . JOptionPane.showMessageDialog( null, “one\ntwo\nthree” ); //place newline \n to display multiple lines of output ©The McGraw-Hill Companies, Inc. Permission required for reproduction or display. ©The McGraw-Hill Companies, Inc.

Using JOptionPane for Output - 3 import javax.swing.*; class Ch14ShowMessageDialog { public static void main(String[] args) { JFrame jFrame; jFrame = new JFrame( ); jFrame.setSize(400,300); jFrame.setVisible(true); JOptionPane.showMessageDialog(jFrame, "How are you?"); JOptionPane.showMessageDialog(null, "Good Bye"); } } ©The McGraw-Hill Companies, Inc. Permission required for reproduction or display.

Using JOptionPane for Output - 3 After Pressing OK or closing the “How are you?” dialog, the “Good Bye” dialog appears Notice that: we are not creating an instance of the JDialog class directly by ourselves. However, when we call the showMessageDialog method, the JOptionPane class is actually creating an instance of JDialog internally. If we need a more complex dialog, then we create an instance of JDialog. But for simple text display, enough. ©The McGraw-Hill Companies, Inc. Permission required for reproduction or display.

JOptionPane for Input-1 Intro to OOP with Java, C. Thomas Wu JOptionPane for Input-1 We use the showInputDialog class method for input. This method returns the input as a String value so we need to perform type conversion for input of other data types import javax.swing.*; . . . String inputstr = JOptionPane.showInputDialog( null, “What is your name?” ); ©The McGraw-Hill Companies, Inc. Permission required for reproduction or display. ©The McGraw-Hill Companies, Inc.

JOptionPane for Input-2 import javax.swing.*; . . . String inputstr = JOptionPane.showInputDialog( null, “Enter Age:” ); int age= Integer.parseInt(inputstr); ©The McGraw-Hill Companies, Inc. Permission required for reproduction or display.

Creating a Plain JFrame Intro to OOP with Java, C. Thomas Wu Creating a Plain JFrame import javax.swing.*; class Ch7DefaultJFrame { public static void main( String[] args ) { JFrame defaultJFrame; defaultJFrame = new JFrame(); defaultJFrame.setVisible(true); } Before we start to explore how to customize a frame window, let's see the behavior of a plain standard JFrame object. This sample program creates a default JFrame object. When you run this program, a very tiny window appears at the top left corner of the screen. ©The McGraw-Hill Companies, Inc. Permission required for reproduction or display. ©The McGraw-Hill Companies, Inc.

Intro to OOP with Java, C. Thomas Wu Subclassing JFrame To create a customized frame window, we define a subclass of the JFrame class. The JFrame class contains rudimentary functionalities to support features found in any frame window. The standard JFrame class includes only most basic functionalities. When we need a frame window in our application, it is typical for us to define a subclass of JFrame to create a frame window that is customized to our needs. We will study the basics of this customization. ©The McGraw-Hill Companies, Inc. Permission required for reproduction or display. ©The McGraw-Hill Companies, Inc.

Creating a Subclass of JFrame Intro to OOP with Java, C. Thomas Wu Creating a Subclass of JFrame To define a subclass of another class, we declare the subclass with the reserved word extends. import javax.swing.*; class Ch7JFrameSubclass1 extends JFrame { . . . } A subclass of any class is declared by including the keyword 'extends' the class definition header. The example here defines a subclass of JFrame named Ch7JFrameSubclass1. ©The McGraw-Hill Companies, Inc. Permission required for reproduction or display. ©The McGraw-Hill Companies, Inc.

Creating a Subclass of JFrame Intro to OOP with Java, C. Thomas Wu Creating a Subclass of JFrame An instance of Ch14JFrameSubclass1 will have the following default characteristics: The title is set to My First Subclass. The program terminates when the close box is clicked. The size of the frame is 300 pixels wide by 200 pixels high. The frame is positioned at screen coordinate (150, 250). These properties are set inside the default constructor. Open the sample Ch7JFrameSubclass1 class and see how the constructor includes a number of statements such as setTitle and setLocation to set the properties. These methods are all inherited from the superclass JFrame. The last statement is setDefaultCloseOperation that defines the frame's behavior when the close box of the frame is clicked. Passing the class constant EXIT_ON_CLOSE specifies to stop the application when the close box of a frame is clicked. Remove this statement and see what happens. ©The McGraw-Hill Companies, Inc.

Displaying Ch14JFrameSubclass1 Intro to OOP with Java, C. Thomas Wu Displaying Ch14JFrameSubclass1 Here's how a Ch14JFrameSubclass1 frame window will appear on the screen. This diagram illustrates how the arguments to the setSize and setLocation methods affect the frame window appearance on the screen. The top left corner of the screen has coordinate (0,0). The value of x increases as you move toward right and the value of y increases as you move down. Notice that the screen coordinate is different from the coordinate system of a mathematical 2-D graph. ©The McGraw-Hill Companies, Inc. Permission required for reproduction or display. ©The McGraw-Hill Companies, Inc.

Creating a Subclass of JFrame import javax.swing.*; class Ch14JFrameSubclass1 extends JFrame { private static final int FRAME_WIDTH = 300; private static final int FRAME_HEIGHT = 200; private static final int FRAME_X_ORIGIN = 150; private static final int FRAME_Y_ORIGIN = 250; public Ch14JFrameSubclass1( ) { //set the frame default properties setTitle ( "My First Subclass" ); setSize ( FRAME_WIDTH, FRAME_HEIGHT ); setLocation ( FRAME_X_ORIGIN, FRAME_Y_ORIGIN ); //register 'Exit upon closing' as a default close operation setDefaultCloseOperation( EXIT_ON_CLOSE ); } ©The McGraw-Hill Companies, Inc. Permission required for reproduction or display.

Creating a Subclass of JFrame /* Displays a default Ch14JFrameSubclass window */ class Ch14TestJFrameSubclass { public static void main(String[] args) { Ch14JFrameSubclass1 myFrame; myFrame = new Ch14JFrameSubclass1(); myFrame.setVisible(true); } Notice this main class is identical to Ch7DefaultJFrame except for the creation of a Ch14JFrameSubclass1 instance instead of a JFrame instance. There’s no need to import the javax.swing package because the main class does not make any direct reference to the classes in this package. ©The McGraw-Hill Companies, Inc. Permission required for reproduction or display.

The Content Pane of a Frame Intro to OOP with Java, C. Thomas Wu The Content Pane of a Frame The content pane is where we put GUI objects such as buttons, labels, scroll bars, and others. We access the content pane by calling the frame’s getContentPane method. This gray area is the content pane of this frame. A frame window is composed of four borders, a title bar, and a content area. The content area is called a content pane in Java, and this is the area we can use to place GUI components. ©The McGraw-Hill Companies, Inc. Permission required for reproduction or display. ©The McGraw-Hill Companies, Inc.

Changing the Background Color Intro to OOP with Java, C. Thomas Wu Changing the Background Color Here's how we can change the background color of a content pane to blue: Container contentPane = getContentPane(); contentPane.setBackground(Color.BLUE); Source File: Ch14JFrameSubclass2.java We access the content pane of a frame by calling the JFrame method called getContentPane. We declare the data type for the object returned by the getContentPane method to Container. Once we get the content pane object, we can call its methods. The example here calls the setBackground method to change the default background color of gray to white. The complete sample code can be found in the file Ch7JFrameSubclass2.java. ©The McGraw-Hill Companies, Inc. Permission required for reproduction or display. ©The McGraw-Hill Companies, Inc.

import javax. swing. ; import java. awt import javax.swing.*; import java.awt.*; class Ch14JFrameSubclass2 extends JFrame { private static final int FRAME_WIDTH private static final int FRAME_HEIGHT private static final int FRAME_X_ORIGIN = 150; private static final int FRAME_Y_ORIGIN = 250; public static void main(String[] args) { Ch14JFrameSubclass2 frame = new Ch14JFrameSubclass2(); frame.setVisible(true); } public Ch14JFrameSubclass2() { //set the frame default properties setTitle ("Blue Background JFrame Subclass"); setSize (FRAME_WIDTH, FRAME_HEIGHT); setLocation (FRAME_X_ORIGIN, FRAME_Y_ORIGIN); //register 'Exit upon closing' as a default close operation setDefaultCloseOperation(EXIT_ON_CLOSE); changeBkColor(); } private void changeBkColor() { Container contentPane = getContentPane(); contentPane.setBackground(Color.BLUE); ©The McGraw-Hill Companies, Inc. Permission required for reproduction or display.

Placing GUI Objects on a Frame Intro to OOP with Java, C. Thomas Wu Placing GUI Objects on a Frame There are two ways to put GUI objects on the content pane of a frame: Use a layout manager FlowLayout BorderLayout GridLayout Use absolute positioning null layout manager The content pane of a frame is where we can place GUI components. Among the approaches available to us to place components, we will study the easier one here. The easier absolute positioning is not a recommended approach for practical applications, but our objective here is to learn the basic handling of events and placement of GUI objects, we will use the easier approach. Chapter 12 of the textbook discusses different layout managers. ©The McGraw-Hill Companies, Inc. Permission required for reproduction or display. ©The McGraw-Hill Companies, Inc.

Intro to OOP with Java, C. Thomas Wu Placing a Button-1 A JButton object a GUI component that represents a pushbutton. import javax.swing.*; ... JButton cancelButton, okButton; cancelButton = new JButton("CANCEL"); okButton = new JButton("OK"); The key point to remember in using absolute positioning: Set the layout manager of the content pane to null as conentPane.setLayout(null) Set the bounds to a GUI object. For example okButton.setBounds(70, 125, 80, 20); Add a GUI object to the content pane by calling the add method as contentPane.add(okButton); ©The McGraw-Hill Companies, Inc. Permission required for reproduction or display. How to place them? ©The McGraw-Hill Companies, Inc.

Intro to OOP with Java, C. Thomas Wu Placing a Button-1 Here's an example of how we place a button with FlowLayout. FlowLayout places objects in the top-to-bottom, left-to right order. Container contentPane = getContentPane(); contentPane.setLayout(new FlowLayout()); contentPane.add(okButton); contentPane.add(cancelButton); // you cannot change component size when // layout is used The key point to remember in using absolute positioning: Set the layout manager of the content pane to null as conentPane.setLayout(null) Set the bounds to a GUI object. For example okButton.setBounds(70, 125, 80, 20); Add a GUI object to the content pane by calling the add method as contentPane.add(okButton); ©The McGraw-Hill Companies, Inc. Permission required for reproduction or display. ©The McGraw-Hill Companies, Inc.

Placing a Button-2 import javax.swing.*; import java.awt.*; class Ch14JButtonFrame extends JFrame { private static final int FRAME_WIDTH = 300; private static final int FRAME_HEIGHT = 200; private static final int FRAME_X_ORIGIN = 150; private static final int FRAME_Y_ORIGIN = 250; private JButton cancelButton; private JButton okButton; public static void main(String[] args) { Ch14JButtonFrame frame = new Ch14JButtonFrame(); frame.setVisible(true); } ©The McGraw-Hill Companies, Inc. Permission required for reproduction or display.

Placing a Button-3 public Ch14JButtonFrame() { Container contentPane = getContentPane( ); contentPane.setLayout(new FlowLayout()); setSize ( FRAME_WIDTH, FRAME_HEIGHT ); setResizable ( false ); setTitle ( "Program Ch14JButtonFrame" ); setLocation ( FRAME_X_ORIGIN, FRAME_Y_ORIGIN ); //create and place two buttons on the frame's content pane okButton = new JButton("OK"); contentPane.add(okButton); cancelButton = new JButton("CANCEL"); contentPane.add(cancelButton); //register 'Exit upon closing' as a default close operation setDefaultCloseOperation( EXIT_ON_CLOSE ); } } When we run the program, we see two buttons appear on the frame. We can click the buttons, but nothing happens, of course, because the code to handle the button clicks is not yet added to the class. Event Handling ©The McGraw-Hill Companies, Inc. Permission required for reproduction or display.

Intro to OOP with Java, C. Thomas Wu Event Handling An action involving a GUI object, such as clicking a button, is called an event. The mechanism to process events is called event handling. Event handling is implemented by two types of objects: event source objects event listener objects JButton and other GUI objects are event source objects. Any object can be designated as event listener objects. ©The McGraw-Hill Companies, Inc. Permission required for reproduction or display. ©The McGraw-Hill Companies, Inc.

Intro to OOP with Java, C. Thomas Wu Event Types There are different event types and event listeners Mouse events are handled by mouse listeners Item selection events are handled by Item listeners and so forth Among the different types of events, the action event is the most common. Clicking on a button generates an action event Selecting a menu item generates an action event Action events are generated by action event sources and handled by action event listeners. There are different types of events. Some event sources generate only one type of events, while others generate three or four different types of events. For example, a button can generate an action event, a change event, and a item event. The most common type of event we are interested in processing for various types of GUI components is the action event. ©The McGraw-Hill Companies, Inc. Permission required for reproduction or display. ©The McGraw-Hill Companies, Inc.

Event Source and Event Listeners Objects Intro to OOP with Java, C. Thomas Wu Event Source and Event Listeners Objects An event source is a GUI object where an event occurs. We say an event source generates events. Buttons, text boxes, list boxes, and menus are common event sources in GUI-based applications. An event listener object is an object that includes a method that gets executed in response to the generated events. A listener must be associated, or registered, to a source, so it can be notified when the source generates events. It is possible a single object to be both. A single event source can generate more than one type of events. When an event is generated, a corresponding event listener is notified. Whether there is a designated listener or not, event sources generates events. If there's a no matching listeners, generated events are simply ignored. ©The McGraw-Hill Companies, Inc. Permission required for reproduction or display. ©The McGraw-Hill Companies, Inc.

Connecting Source and Listener Intro to OOP with Java, C. Thomas Wu Connecting Source and Listener event source event listener notify JButton Handler register A listener must be registered to a event source. Once registered, it will get notified when the event source generates events. If the event source has no registered listeners, then generated events are ignored. This diagram shows the relationship between the event source and listener. First we register a listener to an event source. Once registered, whenever an event is generated, the event source will notify the listener. ©The McGraw-Hill Companies, Inc. Permission required for reproduction or display. ©The McGraw-Hill Companies, Inc.

Handling Action Events Intro to OOP with Java, C. Thomas Wu Handling Action Events action event source actionPerformed action event listener JButton Button Handler addActionListener ButtonHandler handler = new ButtonHandler( ); // A single listener can be associated with multiple sources okButton.addActionListener(handler); cancelButton.addActionListener(handler); This code shows how we register an action event listener to a button. The object we register as an action listener must be an instance of a class that implements the ActionListener interface. The class must define a method named actionPerformed. This is the method executed in response to the generated action events. ©The McGraw-Hill Companies, Inc. Permission required for reproduction or display. ©The McGraw-Hill Companies, Inc.

Handling Action Events Intro to OOP with Java, C. Thomas Wu Handling Action Events The class ButtonHandler is a user-defined event listener (event handler). It must implement the Interface ActionListener It must include the method actionPerformed The method actionPerformed includes the code we want to be executed in response to the generated events import javax.swing.*; import java.awt.*; import java.awt.event.* class ButtonHandler implements ActionListener { //data members and constructors come here public void actionPerformed(ActionEvent evt) { //event-handling statements come here . . . . . } This code shows how we register an action event listener to a button. The object we register as an action listener must be an instance of a class that implements the ActionListener interface. The class must define a method named actionPerformed. This is the method executed in response to the generated action events. ©The McGraw-Hill Companies, Inc. Permission required for reproduction or display. ©The McGraw-Hill Companies, Inc.

Intro to OOP with Java, C. Thomas Wu Example We want to change the title of a frame to You clicked OK or You clicked CANCEL depending on which button is clicked. This is done inside the actionPerformed: The general idea of the method is as follows: Public void actionPerformed(ActionEvent evt) { String buttonText = get the text of the event source; JFrame frame = the frame that contains this event source; frame.setTitle("You clicked " + buttonText); } ©The McGraw-Hill Companies, Inc. Permission required for reproduction or display. ©The McGraw-Hill Companies, Inc.

Intro to OOP with Java, C. Thomas Wu Example We want to change the title of a frame to You clicked OK or You clicked CANCEL depending on which button is clicked. This is done inside the actionPerformed: // to get the text of the event source String buttonText = evt.getActionCommand(); // Or JButton clickedButton = (JButton) evt.getSource(); String buttonText = clickedButton.getText(); ©The McGraw-Hill Companies, Inc. Permission required for reproduction or display. ©The McGraw-Hill Companies, Inc.

Intro to OOP with Java, C. Thomas Wu Example We want to change the title of a frame to You clicked OK or You clicked CANCEL depending on which button is clicked. This is done inside the actionPerformed: /*A frame window contains nested layers of panes (the content pane in which we place GUI objects is one of them). The topmost pane is called the root pane (an instance of JRootPane). */ // to find the frame that contains the event source JRootPane rootPane = clickedButton.getRootPane( ); Frame frame = (JFrame) rootPane.getParent(); ©The McGraw-Hill Companies, Inc. Permission required for reproduction or display. ©The McGraw-Hill Companies, Inc.

Example: All together - 1 Intro to OOP with Java, C. Thomas Wu Example: All together - 1 import javax.swing.*; import java.awt.*; import java.awt.event.*; class ButtonHandler implements ActionListener { public ButtonHandler() { } public void actionPerformed(ActionEvent event) { JButton clickedButton = (JButton) event.getSource(); JRootPane rootPane = clickedButton.getRootPane(); JFrame frame = (JFrame) rootPane.getParent(); String buttonText = clickedButton.getText(); frame.setTitle("You clicked " + buttonText); } ©The McGraw-Hill Companies, Inc. Permission required for reproduction or display. ©The McGraw-Hill Companies, Inc.

Example: All together - 2 Intro to OOP with Java, C. Thomas Wu Example: All together - 2 import javax.swing.*; import java.awt.*; class Ch14JButtonEvents extends JFrame { private static final int FRAME_WIDTH = 300; private static final int FRAME_HEIGHT = 200; private static final int FRAME_X_ORIGIN = 150; private static final int FRAME_Y_ORIGIN = 250; private JButton cancelButton; private JButton okButton; public static void main(String[] args){ Ch14JButtonEvents frame = new Ch14JButtonEvents(); frame.setVisible(true); } ©The McGraw-Hill Companies, Inc. Permission required for reproduction or display. ©The McGraw-Hill Companies, Inc.

Example: All together - 3 Intro to OOP with Java, C. Thomas Wu Example: All together - 3 public Ch14JButtonEvents() { Container contentPane = getContentPane( ); //set the frame properties setSize (FRAME_WIDTH, FRAME_HEIGHT); setResizable (false); setTitle ("Program Ch14JButtonFrame"); setLocation (FRAME_X_ORIGIN, FRAME_Y_ORIGIN); //set the layout manager contentPane.setLayout(new FlowLayout()); //create and place two buttons on the frame's content pane okButton = new JButton("OK"); contentPane.add(okButton); cancelButton = new JButton("CANCEL"); contentPane.add(cancelButton); //registering a ButtonHandler as an action listener of the //two buttons ButtonHandler handler = new ButtonHandler(); cancelButton.addActionListener(handler); okButton.addActionListener(handler); //register 'Exit upon closing' as a default close operation setDefaultCloseOperation(EXIT_ON_CLOSE); } } ©The McGraw-Hill Companies, Inc. Permission required for reproduction or display. ©The McGraw-Hill Companies, Inc.

Container as Event Listener Intro to OOP with Java, C. Thomas Wu Container as Event Listener Instead of defining a separate event listener such as ButtonHandler, it is much more common to have an object that contains the event sources be a listener. Example: We make this frame a listener of the action events of the buttons it contains. event listener Because ActionListener is a Java interface and not a class, action event listener objects are not limited to instances of fixed classes. Any class can implement the ActionListener interface, so any object from a class that implements this interface can be an action event listener. This adds flexibility as this example illustrates. Instead of using a ButtonHandler object, we can make the frame object itself to be an action event listener. event source ©The McGraw-Hill Companies, Inc. Permission required for reproduction or display. ©The McGraw-Hill Companies, Inc.

Ch14JButtonFrameHandler Intro to OOP with Java, C. Thomas Wu Ch14JButtonFrameHandler . . . class Ch14JButtonFrameHandler extends JFrame implements ActionListener { public void actionPerformed(ActionEvent event) { JButton clickedButton = (JButton) event.getSource(); String buttonText = clickedButton.getText(); setTitle("You clicked " + buttonText); } This is how a frame that contains the buttons can be made to be their event listeners. Notice that because the actionPerformed method is defined in the frame class, setting the title is matter of calling its setTitle method. ©The McGraw-Hill Companies, Inc. Permission required for reproduction or display. ©The McGraw-Hill Companies, Inc.

Ch14JButtonFrameHandler (complete program-1) import javax.swing.*; import java.awt.*; import java.awt.event.*; class Ch14JButtonFrameHandler extends JFrame implements ActionListener { private static final int FRAME_WIDTH = 300; private static final int FRAME_HEIGHT = 200; private static final int FRAME_X_ORIGIN = 150; private static final int FRAME_Y_ORIGIN = 250; private JButton cancelButton; private JButton okButton; public static void main(String[] args) { Ch14JButtonFrameHandler frame = new Ch14JButtonFrameHandler(); frame.setVisible(true); } ©The McGraw-Hill Companies, Inc. Permission required for reproduction or display.

Ch14JButtonFrameHandler (complete program-2) public Ch14JButtonFrameHandler() { Container contentPane = getContentPane( ); setSize (FRAME_WIDTH, FRAME_HEIGHT); setResizable (false); setTitle ("Program Ch14JButtonFrameHandler"); setLocation (FRAME_X_ORIGIN, FRAME_Y_ORIGIN); contentPane.setLayout(new FlowLayout()); okButton = new JButton("OK"); contentPane.add(okButton); cancelButton = new JButton("CANCEL"); contentPane.add(cancelButton); //registering this frame as an action listener of the two buttons cancelButton.addActionListener(this); okButton.addActionListener(this); setDefaultCloseOperation( EXIT_ON_CLOSE ); } ©The McGraw-Hill Companies, Inc. Permission required for reproduction or display.

Ch14JButtonFrameHandler (complete program-3) // The handler is added in the same class public void actionPerformed(ActionEvent event) { JButton clickedButton = (JButton) event.getSource(); String buttonText = clickedButton.getText(); this.setTitle("You clicked " + buttonText); } } ©The McGraw-Hill Companies, Inc. Permission required for reproduction or display.