Java by Example - flicker free graphics, GIF and JPEG display

back 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 next

You will have observed the flicker whenever we have changed the content of the applet before. To avoid this, you need to implement a technique called double buffering. We have to create a Graphics object inside the memory to which we do all our drawing now. Inside the paint() method we copy the memory bitmap to the screen then. Just follow the code of this applet, you don't have to understand everything yet to use this technique.
This applet uses a boolean variable (moveRight) to keep track of the direction, the pink square is going. With if and else it is determined whether the condition is true to continue movement in the previous direction, or whether it is time to change the direction.

//Sourcecode

import java.awt.*;
import java.applet.*;

//a flicker free animation!

public class Project9 extends Applet implements Runnable
{
    Thread runner;
    private Image Buffer;
    private Graphics gBuffer;
    int x, x1, x2=100;
    boolean moveRight=true;

    //Init is called first, do any initialisation here
    public void init()
    {
        //create graphics buffer, the size of the applet
        Buffer=createImage(size().width,size().height);
        gBuffer=Buffer.getGraphics();
    }

    public void start()
    {
        if (runner == null)
        {
            runner = new Thread (this);
            runner.start();
        }
    }

    public void stop()
    {
        if (runner != null)
        {
            runner.stop();
            runner = null;
        }
    }

    public void run()
    {
        while(true)
        {
            //Thread sleeps for 15 milliseconds here
            try {runner.sleep(15);}
            catch (Exception e) { }

            //paint background blue
            gBuffer.setColor(Color.blue);
            gBuffer.fillRect(0,0,size().width,size().height);

            //move circle (slowly) right until it leaves applet
            //then let it appear again on the left side
            x++;
            if(x>size().width)
                x=-50;

            //move square left (with double speed) until it
            //leaves applet then let it reappear right side
            x1-=2;
            if(x1<-50)
                x1=size().width;

            //move the pink square right until it touches
            //border, then set flag "moveRight" to false
            if(moveRight==true)
            {
                if(x2<size().width-50)
                    x2+=2;
                else
                    moveRight=false;
            }

            //if flag "moveRight" is false, the pink square moves left
            //until it touches left border, then switch direction
            if(moveRight==false)
            {
                if(x2>0)
                    x2-=2;
                else
                    moveRight=true;
            }

            //the red circle
            gBuffer.setColor(Color.red);
            gBuffer.fillOval(x,30,50,50);

            //the green square
            gBuffer.setColor(Color.green);
            gBuffer.fillRect(x1,110,50,50);

            //the pink square
            gBuffer.setColor(Color.pink);
            gBuffer.fillRoundRect(x2,200,50,50,16,16);

            repaint();
        }
    }

    //is needed to avoid erasing the background by Java
    public void update(Graphics g)
    {
        paint(g);
    }

    public void paint(Graphics g)
    {
        g.drawImage (Buffer,0,0, this);
    }
}

Java makes it very easy to use graphics in JPEG and GIF format, even GIFs with transparency index, so it is no problem to display sprites for a game. The duck in this applet uses a transparent background color, the rose is a JPEG. For pictures with a large color palette (photos) you should always take JPEGs, for graphics that don't need many colors or need to be very sharp, you should prefer GIFs.

//Sourcecode

import java.awt.*;
import java.applet.*;

//you can easily load and display graphics in GIF and JPEG format
//GIFs with transparent colors are also supported!

public class Project10 extends Applet
{
    Image pic1, pic2, pic3;

    public void init()
    {
        pic1=getImage(getCodeBase(),"rose.jpg");
        pic2=getImage(getCodeBase(),"boat.gif");
        pic3=getImage(getCodeBase(),"duck.gif");
    }

    public void paint (Graphics g)
    {
        g.drawImage(pic1, 90,10,this);
        g.drawImage(pic2, 30,70,this);
        g.drawImage(pic3, 140,130,this);
    }
}

back 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 next

0 - setup - getting your tools ready
1 - basic graphics functions
2 - simple methods and basic data types
3 - IF, ELSE and SWITCH: basic control structures
4 - introducing the operators
5 - methods with and without a return value
6 - using methods and basic mouse functions
7 - fonts, random numbers and timers
8 - flicker free graphics, GIF and JPEG display
9 - animation with GIF pictures, sprite animation
10 - loops, advanced color functions
11 - random colors and arrays
12 - digital clocks, HTML page parameters
13 - introducing classes and objects
14 - using the Vector class
15 - using mouseMove and mouseDrag
16 - keyboard commands and playing sound
17 - detecting collisions and intersections
18 - a Bouncing Balls applet
19 - fun with letters and words
20 - rotating lines and polygons
21 - sorting and shuffling


© 2000 by Johannes Wallroth
www.programming.de

watson@programming.de