【求助】关于Java中的双缓冲技术

问题描述

我尝试写一个人物行走的动画。我使用了双缓冲技术,但是屏幕仍然会闪烁,希望大家能够帮我找到其中的错误。代码如下:(1)精灵类packagesprite;importjava.awt.*;importjava.awt.image.*;importjavax.swing.*;publicclassSprite{publicintm_posX=0,m_posY=0;privateImagepic[]=null;privateintmPlayID=0;booleanmFacus=true;publicSprite(){pic=newImage[4];for(inti=0;i<4;i++){pic[i]=Toolkit.getDefaultToolkit().getImage("images\f"+i+".png");}}publicvoidinit(intx,inty){m_posX=x;m_posY=y;}publicvoidset(intx,inty){m_posX=x;m_posY=y;}publicvoidDrawSprite(Graphicsg,JPaneli){g.drawImage(pic[mPlayID],m_posX,m_posY,(ImageObserver)i);mPlayID++;if(mPlayID==4)mPlayID=0;}publicvoidUpdateSprite(){if(mFacus==true)m_posX+=15;if(m_posX==300)m_posX=0;}}(2)面板类packagesprite;importjava.awt.*;importjavax.swing.*;publicclassSpritePanelextendsJPanelimplementsRunnable{privateSpriteplayer;privateImageiBuffer;privateGraphicsgBuffer;publicSpritePanel(){player=newSprite();Threadt=newThread(this);t.start();}publicvoidrun(){while(true){player.UpdateSprite();try{Thread.sleep(300);}catch(InterruptedExceptione){}repaint();}}publicvoidpaint(Graphicsg){if(iBuffer==null){iBuffer=createImage(this.getSize().width,this.getSize().height);gBuffer=iBuffer.getGraphics();}gBuffer.setColor(getBackground());gBuffer.fillRect(0,0,this.getSize().width,this.getSize().height);player.DrawSprite(gBuffer,this);g.drawImage(iBuffer,0,0,this);}publicvoidupdate(Graphicsg){paint(g);}}

解决方案

解决方案二:
自己改了很久了,始终不知道错误所在,希望大家帮忙找一下错误。万分感谢!
解决方案三:
我前面也遇到过有个网上的双缓冲部分是错的我给你个新的你把原来双缓冲的部分去掉换成我这个/***增加双缓冲来缓解图片的闪烁*/privateImageiBuffer;privateGraphicsgBuffer;publicvoidupdate(Graphicsscr){if(iBuffer==null){iBuffer=createImage(this.getSize().width,this.getSize().height);gBuffer=iBuffer.getGraphics();}gBuffer.setColor(getBackground());gBuffer.fillRect(0,0,this.getSize().width,this.getSize().height);paint(gBuffer);scr.drawImage(iBuffer,0,0,this);}你把这段代码放在窗口类中就行了
解决方案四:
我按照你的方法尝试了一下,但是不知道为什么屏幕不能清除之前的图像了(就是人物行走的时候出现重影,并且一直留在那里)。我的update方法是按照你的改的。paint方法我是这样写的publicvoidpaint(Graphicsg){player.DrawSprite(g,this);}能再帮我看一看吗?非常感谢!
解决方案五:
引用2楼EndlessGhost的回复:

我前面也遇到过有个网上的双缓冲部分是错的我给你个新的你把原来双缓冲的部分去掉换成我这个/***增加双缓冲来缓解图片的闪烁*/privateImageiBuffer;privateGraphicsgBuffer;publicvoidupdate(Graphicsscr){if(iBuffer==null){iBuffer=createImage(this.getSize().width,this.getSize().height);gBuffer=iBuffer.getGraphics();}gBuffer.setColor(getBackground());gBuffer.fillRect(0,0,this.getSize().width,this.getSize().height);paint(gBuffer);scr.drawImage(iBuffer,0,0,this);}你把这段代码放在窗口类中就行了

能帮我再看一下吗?非常感谢!
解决方案六:
packagePlaneGameUtil;importjava.awt.Frame;importjava.awt.Graphics;importjava.awt.Image;importjava.awt.event.WindowAdapter;importjava.awt.event.WindowEvent;/***将一些公用的代码组成一个父类*@authorAdministrator**/publicclassMyFrameextendsFrame{/***游戏窗口*/publicvoidlaunchFrame(){setSize(Constant.GAME_HIGHT,Constant.GAME_WIDTH);setLocation(100,100);setVisible(true);//默认的的窗口为隐藏的要将值设置为true才能变成可视化。newPaintThread().start();//启动重画窗口的线程addWindowListener(newWindowAdapter(){//增加窗口监听内部类@OverridepublicvoidwindowClosing(WindowEvente){//重写windowClosing方法。System.exit(0);}});}/***增加双缓冲来缓解图片的闪烁*/privateImageiBuffer;privateGraphicsgBuffer;publicvoidupdate(Graphicsscr){if(iBuffer==null){iBuffer=createImage(this.getSize().width,this.getSize().height);gBuffer=iBuffer.getGraphics();}gBuffer.setColor(getBackground());gBuffer.fillRect(0,0,this.getSize().width,this.getSize().height);paint(gBuffer);scr.drawImage(iBuffer,0,0,this);}/***定义一个重画窗口的类它是一个内部类*@authorAdministrator**/classPaintThreadextendsThread{publicvoidrun(){while(true){repaint();try{Thread.sleep(30);}catch(InterruptedExceptione){e.printStackTrace();}//1s=1000ms}}}}你把你原来的面板类直接换成我的这个吧你的呢个我看着好乱我的这个我已经成功用过了你直接换掉看看效果
解决方案七:
引用5楼EndlessGhost的回复:

packagePlaneGameUtil;importjava.awt.Frame;importjava.awt.Graphics;importjava.awt.Image;importjava.awt.event.WindowAdapter;importjava.awt.event.WindowEvent;/***将一些公用的代码组成一个父类*@authorAdministrator**/publicclassMyFrameextendsFrame{/***游戏窗口*/publicvoidlaunchFrame(){setSize(Constant.GAME_HIGHT,Constant.GAME_WIDTH);setLocation(100,100);setVisible(true);//默认的的窗口为隐藏的要将值设置为true才能变成可视化。newPaintThread().start();//启动重画窗口的线程addWindowListener(newWindowAdapter(){//增加窗口监听内部类@OverridepublicvoidwindowClosing(WindowEvente){//重写windowClosing方法。System.exit(0);}});}/***增加双缓冲来缓解图片的闪烁*/privateImageiBuffer;privateGraphicsgBuffer;publicvoidupdate(Graphicsscr){if(iBuffer==null){iBuffer=createImage(this.getSize().width,this.getSize().height);gBuffer=iBuffer.getGraphics();}gBuffer.setColor(getBackground());gBuffer.fillRect(0,0,this.getSize().width,this.getSize().height);paint(gBuffer);scr.drawImage(iBuffer,0,0,this);}/***定义一个重画窗口的类它是一个内部类*@authorAdministrator**/classPaintThreadextendsThread{publicvoidrun(){while(true){repaint();try{Thread.sleep(30);}catch(InterruptedExceptione){e.printStackTrace();}//1s=1000ms}}}}你把你原来的面板类直接换成我的这个吧你的呢个我看着好乱我的这个我已经成功用过了你直接换掉看看效果

不知道是不是我的电脑有问题。。。我改了之后还是闪。。你能把你的那个类似的程序发给我,我到我的电脑上试一试,然后再仔细研究研究。。可以吗。。。谢谢。。

时间: 2024-09-21 07:11:39

【求助】关于Java中的双缓冲技术的相关文章

java中的双缓冲技术

毕业设计有个远程协助功能,得到对方的屏幕后,老是会闪,很是不爽,今天用java的双缓冲技术解决了.代码如下,本类重写了Swing中的JLabel,当Label重绘时,会默认的调用它的update方法,主要用于清除界面,然后update方法会调用paint方法,再把界面画上去,所以我现在update方法中创建了一个Image和Graphics对象Image off_screen_buf和off_screen_gc同时设置其大小和MyLabel对象的大小一样,用于把要画的东东先绘制到后台内存中,然后

JAVA中的双缓冲问题

/** *//** *双缓冲 *什么是重量级,轻量级 *轻量级在这里指用纯java实现的.重量级指和其他语言混合编程,这样耗用的资源多系统触发的绘画操作 *绘画操作的分类 *系统触发的和程序触发的绘画操作 *AWT的绘制与界面更新使用了一个单独的线程,称为AWT线程.这个线程可以在两种情形下更新显示. *一种情况是界面"显露",这可能会发生在界面首次显示时,或者界面某一部分由于被其它窗口遮盖后重新显示时.界面显露的处理是AWT自动进行的,. *第二种情况是程序在显示内容有所改变时进行界

java的双缓冲技术

Java的强大特性让其在游戏编程和多媒体动画处理方面也毫不逊色.在Java游戏编程和动画编程中最常见的就是对于屏幕闪烁的处理.本文从J2SE的一个再现了屏幕闪烁的Java Appilication简单动画实例展开,对屏幕闪烁的原因进行了分析,找出了闪烁成因的关键:update(Graphics g)函数对于前端屏幕的清屏.由此引出消除闪烁的方法--双缓冲.双缓冲是计算机动画处理中的传统技术,在用其他语言编程时也可以实现.本文从实例出发,着重介绍了用双缓冲消除闪烁的原理以及双缓冲在Java中的两种

java-关于JAVA绘图双缓冲技术

问题描述 关于JAVA绘图双缓冲技术 package two; import java.awt.Color; import java.awt.Graphics; import java.awt.Image; import java.awt.Rectangle; import javax.swing.JFrame; public class G1P2 extends JFrame{ final int WIDTH = 900,HEIGHT = 650; double p1Speed = 0.5,p

Android采用双缓冲技术实现画板_Android

本文实例为大家分享了Android实现画板的具体代码,采用的技术是双缓冲技术,供大家参考,具体内容如下 1.双缓冲技术的概念 所谓的双缓冲技术其实很简单,当程序需要在指定的View上进行绘制时,程序并不需要直接绘制到该View组件,而是先绘制到一个内存中的Bitmap图片上(就是缓冲),等内存中的Bitmap绘制好之后,再一次性将Bitmap绘制到View组件上. 2.Android采用双缓冲实现画板  实现的思路: 1).定义一个内存中图片,将他作为缓冲区Bitmap cacheBitmap

使用双缓冲技术绘制曲线图

当数据量很大时,绘图可能需要几秒钟甚至更长的时间,而且有时还会出现闪烁现象,为了解决这些问题,可采用双缓冲技术来绘制曲线图. 双缓冲即在内存中创建一个与屏幕绘图区域一致的对象,先将图形绘制到内存中的这个对象上,再一次性将这个对象上的图形拷贝到屏幕上,这样能大大加快绘图的速度.双缓冲实现过程如下: 1.在内存中创建与画布一致的缓冲区 BufferBmp=new Graphics::TBitmap(); BufferBmp->Canvas->Handle=CreateCompatibleDC(Ca

MFC小游戏,使用双缓冲技术但是有些位图无法释放,导致GDI泄露

问题描述 MFC小游戏,使用双缓冲技术但是有些位图无法释放,导致GDI泄露 用MFC写了一个类似于魔塔的小游戏,但是发现会产生GDI泄露,运行一段时间就会崩掉,但是有些位图文件不能通过deleteObject释放,自己搞不太明白,请教一下各位. 解决方案 hero等对象应该是成员变量吧.从代码来看,hero中的picture载入的图片是固定的,那么完全没有必要在OnPaint函数中进行重复调用,完全是浪费,应该将这些代码放到hero对象初始化的地方,一次性完成就可以了. 另外,cDC指针最好也R

双缓冲技术实现Android 画板应用_Android

什么是双缓冲技术?双缓冲技术就是当用户操作界面完成后,会有一个缓冲区保存用户操作的结果. 为什么要使用双缓冲技术?拿Android 游戏开发来说,界面贞每次都是全部重画的,也就说画了新的,旧的就没了,所以需要使用双缓冲技术保存之前的内容. 如何实现双缓冲?使用一个Bitmap对象保留之前的画布即可. package com.example.phonegaptest; import android.content.Context; import android.graphics.Bitmap; i

android双缓冲技术实例详解

Android中的SurfaceView类就是双缓冲机制.因此,在进行Android游戏开发时应尽量使用SurfaceView而不要使用View,这样的话效率较高,并且SurfaceView的功能也更加完善.为了更容易的了解双缓冲技术,下面介绍用View实现双缓冲的方法. 在此需要说明一下,双缓冲的核心技术就是先通过setBitmap方法将要绘制的所有的图形绘制到一个Bitmap上,然后再来调用drawBitmap方法绘制出这个Bitmap,显示在屏幕上.其具体的实现代码如下: 先贴出View类