TUTORIAL NO 5
Animation with PAUSE, RESUME and EXIT functionality
In this tutorial you will learn:
1.Swing Animations
2.Event handling
3.JAVA awt
4.JAVA swing
5.Adapters
Whenever I am coding a game I faced a problem in making the pause, resume and exit functionality. So today I am going to teach you how to make a simple animation with pause, resume and exit functionality. Which will later help you when you are coding a game.
In this tutorial we will be working in JAVA SWING. The first thing that we are going to do is setting up a JPanel and adding the required Components after that adding that JPanel in the JFrame.
Basic step:
Download and install ECLIPSE and set up a JAVA PROJECT. Then create a new class and name it Animation. Then follow the steps
1.IMPORT STATEMENTS
First of all write these import statements in your .java file
import javax.swing.*;
import java.awt.*;
import java.awt.event.*;
We require event import for mouse click, awt and swing imports for visual design and animation. We will be using separate classes for JPanel and a simple class in which we will make a JFrame and add the mouse listeners. First thing is setting up the panel and after that we will setup a class in which we will setup the frame. Then we will do composition i.e make and object of the panel class and add it to frame.
2. SETTING UP THE PANEL CLASS
class AnimationPanel
extends JPanel {
int x = 0, y = 200, flag = 1; // screen coordinates
static boolean pause = false; // pause is false so that animation starts first time
Image img
= new ImageIcon("image//logo.png").
getImage(); // picking the image icon from folder
We require a variable for x,y for the coordinates and flag for moving the animation vertically or horizontally. Then a Boolean to check whether the animation is paused or not. After that we need a variable to get our image from the image folder.
public void paintComponent
(Graphics g
) {
super.paintComponent(g); //calling paint function of super class
moveLogo(g2d); //calling the move function
try {
Thread.
sleep(5); //sleeping the thread for 5ms
} catch (Exception e
) {} //catching the expeption if any
g2d.drawImage(img, x, y, null);// for drawing the image
repaint(10); // repainting the entire screen for movement
}// paintComponent ends
In the JPanel class we write the paintComponent function which is used to draw the animation. First of all we need to call the base class paintComponent in the function that we are overriding, after that type cast the graphics object to Graphics2D because we want the animation to be of java.swing. Then we call our moveLogo function by passing the g2d reference to it which will move our animation by changing certain coordinates. After that we call the Thread.sleep function to slow down the speed of our animation and then draw the image by passing the image object, x, y coordinates and the fourth argument as null which is the image observer. In the end we called the repaint function with a slight delay to redraw the animation at the new position.
if (pause == false) { //when pause is false animation can play
if (x < 1000 & y == 200 & flag == 1) { //flag is 1 then inc x
x++;
if (x == 1000) {
x = 400; //when x reaches max width set x to 400
y = 10; // y to 10
flag = 2; //for vertical movement
}
}
if (x == 400 & y < 550 & flag == 2) {
y++; //now inc y for horizontal
if (y == 550) { //when y reaches max width
x = 0;
y = 200;
flag = 1; //set flag to 1 for horizontal movement aain
}
}
}// end if
}// end movelogo
}// class AnimationPanel ends
Now we will write the move logo function. We will only move forward in this function if pause the Boolean variable pause is equal to false. After that we write two if statement one for the horizontal movement and the other one for the vertical movement. When our x coordinate is less than the max width of the frame i.e 1000 and y coordinate is 200 and flag = 1 then we increment x coordinate to move the logo horizontally. But when the logo reaches 1000 x coordinate then we change the values of x and y coordinates as well as the flag to the half of the frame. So that we can start the logo movement from the top middle to bottom middle vertically. After reaching the bottom we changed are values back for horizontal movement again.
3. WRITING THE ANIMATION CLASS
We will do everything in a constructor so that the jframe gets setup whenever we create the object of the Animation class. Now writing the constructor
static JFrame frame
= new JFrame("ANIMATION APPLICATION");//frame with title
AnimationPanel ap = new AnimationPanel();
Animation() { // setting the frame listeners and panel in constructor
frame.add(ap); //add animation panel in frame
ap.add(pause); //add pause button
ap.add(resume);//add resume button
ap.add(exit); //add exit button
frame.setSize(1000, 600);
frame.
setDefaultCloseOperation(JFrame.
EXIT_ON_CLOSE);
ap.
setBackground(Color.
WHITE);
frame.setVisible(true);
pause.addMouseListener(this);// mouselistener for pause
resume.addMouseListener(this);// mouselistener for resume
exit.addMouseListener(this);// mouselistener for exit
}
In this animation class what we need to do is to make a JFrame as well as three buttons for pause resume and exit after that we need to add mouselisteners to them. SO inorder to do that we created the 3 JButton objects, the frame object and then the panel object to add in the JFrame. After that we write the animation class constructor. First of all we added the panel in the frame and then we added all the 3 buttons in that panel. After that we set the frame size, background color and visibility. Then we add the mouse listeners for the three buttons.
@Override
if (ae.getSource() == pause) // checking which button is pressed
{
AnimationPanel.pause = true; //set pause to true and it will pause the animation
}
if (ae.getSource() == resume) {
AnimationPanel.pause = false; //set pause to false and it will resume the animation
}
if (ae.getSource() == exit) {
System.
exit(0); // exit the app
}
}//end mouseclicked
Now we override the mouseClicked function of the mouseAdapter class to provide the functionality to the three buttons. First of all we check for the button name in the if statement. If the button pressed is pause then we change the value of our static pause variable of the animationPanel to true otherwise we change it to false on pressing resume to continue the animation. In the end we check for the exit button and call the function system.exit if it is pressed which will close our application instantly.
4. DEFINING THE MAIN FUNCTION
public static void main
(String[] args
){
Animation a = new Animation();
}//end main
}// end class Animation
In the main function we only created the object of the JFrame class and our application is complete.
NOTE: Code file includes the image file and source code
OUPUT: