java用applet畫圖用到的方法(涉及雙緩沖)
準備學(xué)習(xí)java2游戲編程。(其實這是一本書啦)
然后作為基礎(chǔ)的基礎(chǔ)的基礎(chǔ),必須學(xué)習(xí)如何讓鍵盤與界面進行交互。下面就是對一個基礎(chǔ)得不能再基礎(chǔ)的applet程序。
雖然這是個小程序,但其中關(guān)于雙緩沖概念的介紹是很重要的,要深入理解。(高級噢)
首先先看代碼:
package bear.game.keyevent;
import java.applet.Applet;
import java.awt.Color;
import java.awt.Graphics;
import java.awt.Image;
import java.awt.Rectangle;
import java.awt.event.KeyEvent;
import java.awt.event.KeyListener;
public class Game extends Applet implements KeyListener{
private Image bufImage = null;
Graphics bufG = null;
@Override
public void paint(Graphics g) {
setBackground(backColor);
g.fillRect(r.x, r.y, r.width, r.height);
}
@Override
public void update(Graphics g) {
bufImage = createImage(getSize().width, getSize().height);
bufG = bufImage.getGraphics();
paint(bufG);
g.drawImage(bufImage, 0, 0, null);
}
private static final long serialVersionUID = 1L;
private Rectangle r;
private Color backColor;
public void init()
{
r = new Rectangle(0, 0, 20, 10);
backColor = Color.WHITE;
addKeyListener(this);
}
@Override
public void keyPressed(KeyEvent e) {
int kc = e.getKeyCode();
if(kc == KeyEvent.VK_LEFT)
{
r.x -= 5;
if(r.x < 0)
r.x = 0;
repaint();
}
else if(kc == KeyEvent.VK_RIGHT)
{
r.x += 5;
if(r.x > getSize().width - r.width)
r.x = getSize().width - r.width;
repaint();
}
else if(kc == KeyEvent.VK_UP)
{
r.y -= 5;
if(r.y < 0)
r.y = 0;
repaint();
}
else if(kc == KeyEvent.VK_DOWN)
{
r.y += 5;
if(r.y > getSize().height - r.height)
r.y = getSize().height - r.height;
repaint();
}
}
@Override
public void keyReleased(KeyEvent e) {
// TODO Auto-generated method stub
}
@Override
public void keyTyped(KeyEvent e) {
// TODO Auto-generated method stub
char kc = e.getKeyChar();
switch(kc)
{
case 'r':
{
backColor = Color.RED;
repaint();
break;
}
case 'g':
{
backColor = Color.GREEN;
repaint();
break;
}
case 'b':
{
backColor = Color.BLUE;
repaint();
break;
}
case 'w':
{
backColor = Color.WHITE;
repaint();
break;
}
}
}
}
程序比較簡單明了,該類繼承于Applet并且實現(xiàn)了KeyListener接口。
其成員變量主要包括:一個由我們控制的Rectangle,一個Image和一個Graphics用來實現(xiàn)雙緩沖。
我們在init()中將Rectangle初始化,在keyPressed中處理鍵盤移動事件,在keyTyped中處理鍵盤修改顏色的事件。
下面重點看的是雙緩沖的實現(xiàn)(位于update重載函數(shù)中),代碼如下:
@Override
public void update(Graphics g) {
bufImage = createImage(getSize().width, getSize().height);
bufG = bufImage.getGraphics();
paint(bufG);
g.drawImage(bufImage, 0, 0, null);
}
比方說看動漫的時候,一般一個星期才出一次。所以感覺不是很給力。所以我們可以等它出了很多集之后再一次看完。(好拙的比方)
所以說,雙緩沖就是在內(nèi)存空間中先畫好圖像,再一次性顯示到屏幕上,這與之前先用背景色覆蓋,然后再重繪是不同的。
那么為什么之前不重載update會閃爍呢?回答這個問題之前要對awt的重繪的過程有一定的了解。
在awt中對于窗體畫布的重繪其條用順序是repaint() --> update() --> paint()。
所以我們在調(diào)用repaint()的時候要進行update,然后呢,我們來看一看update()的源碼。(這里指的是super.update)
/**
* Updates the container. This forwards the update to any lightweight
* components that are children of this container. If this method is
* reimplemented, super.update(g) should be called so that lightweight
* components are properly rendered. If a child component is entirely
* clipped by the current clipping setting in g, update() will not be
* forwarded to that child.
*
* @param g the specified Graphics window
* @see
Component#update(Graphics)
*/
public void update(Graphics g){
if(isShowing()) {
if(!(peer instanceof LightweightPeer)){
g.clearRect(0, 0, width, height);
}
paint(g);
}
}
可以看出super.update()有一個清屏的作用:g.clearRect方法。之后重繪,然后就會出現(xiàn)閃爍。
所以我們利用雙緩沖技術(shù)可以減緩閃爍的效果。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
SpringMVC利用dropzone組件實現(xiàn)圖片上傳
這篇文章主要介紹了SpringMVC利用dropzone組件實現(xiàn)圖片上傳,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-02-02
Java實現(xiàn)數(shù)據(jù)脫敏的方法詳細講解
這篇文章主要給大家介紹了關(guān)于Java實現(xiàn)數(shù)據(jù)脫敏的相關(guān)資料,數(shù)據(jù)脫敏是指對某些敏感信息通過脫敏規(guī)則進行數(shù)據(jù)的變形,實現(xiàn)敏感隱私數(shù)據(jù)的可靠保護,需要的朋友可以參考下2023-06-06
Java的方法和this關(guān)鍵字如何理解與應(yīng)用
Java語言中的“方法”(Method)在其他語言當(dāng)中也可能被稱為“函數(shù)”(Function)。對于一些復(fù)雜的代碼邏輯,如果希望重復(fù)使用這些代碼,并且做到“隨時任意使用”,那么就可以將這些代碼放在一個大括號{}當(dāng)中,并且起一個名字。使用代碼的時候,直接找到名字調(diào)用即可2021-10-10

