Al crear el motor de animación hemos visto que al refrescar la pantalla se produce un parpadeo indeseable. Este efecto es consecuencia del tiempo que se necesita para borrar la imagen y generar la nueva actualizada, resultado de animar los objetos.
Una técnica para evitar esto es la denominada doble buffer o “디oublebuffered“, de forma que utilizamos dos imágenes (memorias gráficas) al mismo tiempo. Mientras se dibuja en una, vemos la otra y minimizamos el tiempo de cambio entre las imágenes eliminando el parpadeo.
에 informática, el almacenamiento en búfer múltiples es el uso de más de un buffer para mantener un bloque de datos, de modo que un “lector” verá una completa versión de los datos, en lugar de una versión parcialmente actualizada de la datos que se crean por un “escritor”. También se utiliza para evitar la necesidad de usar la memoria RAM de doble puerto, cuando los lectores y escritores son dispositivos diferentes.(에)
Modificaremos la clase “칠판” que hemos modificado para incorporar el 애니메이션 엔진 para implementar esta técnica. Necesitaremos conocer las dimensiones de la pantalla gráfica para almacenar la suficiente memoria, y definiremos un objeto “영상” que será sobre el que dibujaremos los gráficos.
Dimension d; private Image mImage = null;
El método “페인트” de dibujo obtendrá primero el tamaño de la imagen a generar. La llamada a la función “checkOffScreenImage()” se encargará de asegurarnos un objeto “mImage” sobre el que dibujar.
Para dibujar en este objeto solicitaremos su dirección gráfica con la función “getGraphics“. A continuación lo rellenaremos del color que usemos para el fondo dibujando sobre este elemento un rectángulo relleno.
Llamaremos a las rutinas de dibujado de la imagen, que hemos implementado en la función “paintOffScreen” pasándole este objeto gráfico como parámetro para que lo use como lienzo.
La última función dibujará en pantalla el lienzo o imagen generado.
public synchronized void 페인트(그래픽 g) { d = getSize(); checkOffScreenImage(); Graphics offG = mImage.getGraphics(); offG.setColor(getBackground()); offG.fillRect(0, 0, d.width, d.height); paintOffScreen(mImage.getGraphics()); g.drawImage(mImage, 0, 0, null); }
La función “checkOffScreenImage()” se encargará de supervisar si ha cambiado el tamaño de la ventana utilizada para mostrar la información gráfica y generar un objeto sobre el que dibujar, mediante la función “createImage()“
개인 무효 checkOffScreenImage() { Dimension d = getSize(); 면 (d.width == 0 || d.height == 0) { return; } 면 (mImage == null || mImage.getWidth(null) != d.width || mImage.getHeight(null) != d.height) { mImage = createImage(d.width, d.height); } }
La función “paintOffScree” es la antigua función o método “페인트” que dibuja nuestros objetos gráficos, por lo que no merece comentarios adicionales. Simplemente hemos cambiado su nombre.
공공 무효 paintOffScreen(그래픽 g){ Enumeration enum=bd.elements(); Object ob; while(enum.hasMoreElements()){ ob=enum.nextElement(); 면(ob instanceof SimpleDrawable){ ((SimpleDrawable) ob).페인트(지); } } }
Al ejecutar la aplicación veremos que el parpadeo de la imagen ha desaparecido.
반드시 연결된 댓글을 달다.