What Will I Learn?
- The user will learn the concept of Adapter Class
- The user will learn how to use Adapter Class to override only methods the user wants to use.
Requirements
- A computer System is required for this tutorial.
- Java Software Development Kit(JDK) must be installed on your computer.
- An Integrated Development Environment(IDE) such as Eclipse or NetBeans is required to be installed on your computer.
Get JDK here
Get Eclipse here
Get NetBeans here
Difficulty
The codes in this tutorial are around the same level as other tutorials so difficulty level will be same as others - Intermediate.
Tutorial Contents
In the previous tutorial, we looked at MouseListener
and MouseMotionListener
. We also looked at the five methods in MouseListener and the two methods in MouseMotionlistener; seven methods in total.
A programmer might want to write a program using these two classes, and only wants to use two methods in his program; it is necessary to implement all the methods contained in the class, however, implementing the seven methods from these two classes could be quite tedious and time consuming.
Java comes up with a construct that enables the programmer override only methods that concerns his program. Using this construct, the programmer can only implement the methods he wants saving time and making the program less bulky.
This tutorial follows through from the previous tutorial, creating a panel and status bar that displays messages but instead of implementing five methods, the program uses MouseAdapter
to implement only two methods that suits the program, mouseEntered
and mouseClicked
methods.
Adapter Class
An adapter class provides the default implementation of all methods in an event listener interface. Adapter classes are very useful when you want to process only few of the events that are handled by a particular event listener interface. You can define a new class by extending one of the adapter classes and implement only those events relevant to you.
CODE BLOCK
adapter Class
import java.awt.*;
import java.awt.event.*;
import javax.swing.*;
public class adapter extends JFrame {
private JPanel panel;
private JLabel messageBar;
public adapter() {
super("Adapter Class Demo");
messageBar = new JLabel("Default");
add(messageBar, BorderLayout.SOUTH);
panel = new JPanel();
panel.setBackground(Color.YELLOW);
add(panel, BorderLayout.CENTER);
panel.addMouseListener(new handlerClass());
}
private class handlerClass extends MouseAdapter {
public void mouseEntered (MouseEvent event) {
panel.setBackground(Color.BLUE);
}
public void mouseClicked (MouseEvent event) {
messageBar.setText(String.format("You clicked %d times", event.getClickCount()));
if (event.isMetaDown())
messageBar.setText(String.format("You clicked %d times " + "with right mouse button", event.getClickCount()));
else if (event.isAltDown())
messageBar.setText(String.format("You clicked %d times " + "with center mouse button", event.getClickCount()));
else
messageBar.setText(String.format("You clicked %d times " + "with left mouse button", event.getClickCount()));
}
}
}
adapterMain Class
import javax.swing.JFrame;
public class adapterMain {
public static void main (String args []) {
adapter event = new adapter();
event.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
event.setSize(500, 300);
event.setVisible(true);
}
}
adapter Class
panel = new JPanel();
panel.setBackground(Color.YELLOW);
add(panel, BorderLayout.CENTER);
panel.addMouseListener(new handlerClass());
A JPanel object is created and background color is set to Yellow.
The panel is added to the screen, the
BorderLayout.CENTER
Method is used to place the panel in the center of the screen.
A new handlerClass
is created to hold the listener instructions and is passed to the MouseListener
class.
private class handlerClass extends MouseAdapter {
public void mouseEntered (MouseEvent event) {
panel.setBackground(Color.BLUE);
}
public void mouseClicked (MouseEvent event) {
messageBar.setText(String.format("You clicked %d times", event.getClickCount()));
if (event.isMetaDown())
messageBar.setText(String.format("You clicked %d times " + "with right mouse button", event.getClickCount()));
else if (event.isAltDown())
messageBar.setText(String.format("You clicked %d times " + "with center mouse button", event.getClickCount()));
else
messageBar.setText(String.format("You clicked %d times " + "with left mouse button", event.getClickCount()));
}
}
}
The newly created handlerClass
extends MouseAdapter
. This allows the programmer to implement only the methods he requires.
The mouseEntered
method is implemented and instructions given.
The mouseClicked
method is also implemented and instructions given to return number of clicks.
if (event.isMetaDown())
messageBar.setText(String.format("You clicked %d times " + "with right mouse button", event.getClickCount()));
If statement to determine if a button is clicked with the right mouse button. The .isMetaDown()
method is used to pass instructions if user clicks with right mouse button.
A message is displayed if this is true.
else if (event.isAltDown())
messageBar.setText(String.format("You clicked %d times " + "with center mouse button", event.getClickCount()));
else if statement to determine if a button is clicked with the centre mouse button. The .isAltDown()
method is used to pass instructions if user clicks with the centre mouse button.
A message is displayed if this is true.
else
messageBar.setText(String.format("You clicked %d times " + "with left mouse button", event.getClickCount()));
else statement to display a message if the above statements is false.
mouseMain CLASS
import javax.swing.JFrame;
This is an import statement. This statement is used specifically to import the JFrame class from Application Program Interface (API). This allows the user to use all methods contained in it.
public class adapterMain {
This is just like creating a new file or document and saving it with a name. This is the name of the new class created.
public static void main (String args []) {
The Java main method. Every program must contain this method in order to execute. It is the point from which the program begins execution.
A program without this method will not execute.
adapter event = new adapter();
An Object of the adapter
class is created. This enables the user to call in built GUI methods that will help to properly display the JPanel and JLabel components to the screen.
event.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
This inbuilt method needs to be called before the program is run . This method states the default behavior of the windows when the “close”(x) button is clicked.
Here, it tells the window to close.
event.setSize(500, 300);
This is to set the size of the object to the specified width and height. In this case, the specified dimensions are (500, 300).
Values of width and height are non-negative integers. The constructors that allow you to create a dimension do not prevent you from setting a negative value for these properties. If the value of width or height is negative, the behavior of some methods defined by other objects is undefined.
event.setVisible(true);
This simply determines whether a component is displayed on the screen. It has two states. True and false.
With setVisible( false ), if the Component is not already marked invisible, setVisible calls invalidate() which invalidates the Container’s layout and the chain of parents since there is now more screen real estate in the Container and the positions of the siblings must be adjusted to flow into the freed space.
With setVisible( true ), if the Component is not already marked visible,setVisible calls invalidate() which invalidates the Container’s layout and the chain of parents since there is now less screen real estate in the Container and the positions of the siblings must be adjusted to squeeze in this new Component.
The program is run and color of the panel changes when mouse enters the panel area.
When the user clicks using the left mouse button, a message is displayed in the status bar below.
When the user clicks using the center mouse button, a message is displayed in the status bar below.
When the user clicks using the right mouse button, a message is displayed in the status bar below.
Source Codes from GitHub Account.
You can get the codes here if you want to try it on your own.
REFERENCES
Curriculum
Similar posts already posted on Utopian are:
Java Graphical User Interface(GUI): Mouse Events and Listeners Using Eclipse IDE
Java Graphical User Interface(GUI): JList Multiple Item Selection Using Eclipse IDE
Java Graphical User Interface(GUI): JList Functions and ListSelectionListener Using Eclipse IDE
Posted on Utopian.io - Rewarding Open Source Contributors
Thank you for the contribution. It has been approved.
You can contact us on Discord.
[utopian-moderator]
Downvoting a post can decrease pending rewards and make it less visible. Common reasons:
Submit
Congratulations! This post has been upvoted from the communal account, @minnowsupport, by will-ugo from the Minnow Support Project. It's a witness project run by aggroed, ausbitbank, teamsteem, theprophet0, someguy123, neoxian, followbtcnews, and netuoso. The goal is to help Steemit grow by supporting Minnows. Please find us at the Peace, Abundance, and Liberty Network (PALnet) Discord Channel. It's a completely public and open space to all members of the Steemit community who voluntarily choose to be there.
If you would like to delegate to the Minnow Support Project you can do so by clicking on the following links: 50SP, 100SP, 250SP, 500SP, 1000SP, 5000SP.
Be sure to leave at least 50SP undelegated on your account.
Downvoting a post can decrease pending rewards and make it less visible. Common reasons:
Submit
Hey @will-ugo I am @utopian-io. I have just upvoted you!
Achievements
Suggestions
Get Noticed!
Community-Driven Witness!
I am the first and only Steem Community-Driven Witness. Participate on Discord. Lets GROW TOGETHER!
Up-vote this comment to grow my power and help Open Source contributions like this one. Want to chat? Join me on Discord https://discord.gg/Pc8HG9x
Downvoting a post can decrease pending rewards and make it less visible. Common reasons:
Submit