Animasyon motoru oluşturmak için biz bu yenileme ekran istenmeyen bir titreşim üretir gördük. Bu efekt görüntüyü silme ve güncellenmiş yeni oluşturmak için gereken süreyi bir sonucudur, nesneleri sonucu.
Una técnica para evitar esto es la denominada doble buffer o “doublebuffered“, 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.
Içinde 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.(Içinde)
Modificaremos la clase “Yazı tahtası” que hemos modificado para incorporar el animasyon motoru para implementar esta técnica. Necesitaremos conocer las dimensiones de la pantalla gráfica para almacenar la suficiente memoria, y definiremos un objeto “Görüntü” que será sobre el que dibujaremos los gráficos.
Dimension d; private Image mImage = null;
Yöntemi “paint” 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 paint(Graphics 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); }
İşlevi “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()“
private void checkOffScreenImage() { Dimension d = getSize(); if (d.width == 0 || d.height == 0) { return; } if (mImage == null || mImage.getWidth(null) != d.width || mImage.getHeight(null) != d.height) { mImage = createImage(d.width, d.height); } }
İşlevi “paintOffScree” es la antigua función o método “paint” que dibuja nuestros objetos gráficos, por lo que no merece comentarios adicionales. Simplemente hemos cambiado su nombre.
public void paintOffScreen(Graphics g){ Numaralandırma enum BD. öğeleri =(); Nesne ob; Süre(enum.hasMoreElements()){ OB enum. nextElement =(); if(OB instanceof SimpleDrawable){ ((SimpleDrawable) OB).paint(g); } } }
Al ejecutar la aplicación veremos que el parpadeo de la imagen ha desaparecido.
Olmalıdır bağlı Yorum yazmak için.