Sigueme en Facebook Sigueme en Twitter Sigueme en Instagram Sigueme en Youtube
JC Mouse Bolivia
Index / Java / Java / Proyectos / Efecto de explosión al abrir un JPanel

Efecto de explosión al abrir un JPanel

Autor jc mouse martes, marzo 19, 2013

En este tutorial crearemos un interesante efecto de explosión al momento de abrir un JPanel, este efecto puede extenderse a un JFrame o un jInternalFrame con pequeñas modificaciones al código. En el siguiente video puedes ver el resultado de este post.

Proyecto.

1. Crea un proyecto en netbeans, añade una clase “explode.java”, un JFrame “gui.java”, dos JPanel, “panel_A.java” y “panel_B.java”.

boom nena

2. Los objetos panel_A y panel_B son quienes se verán afectados por el efecto de explosión, puedes añadir algunos  controles para que se pueda apreciar mejor el efecto, el JPanel contenedor (de JFrame gui.java) tiene una dimensión de  600×400 así que estos dos paneles no deben exceder ese tamaño.

baka

3. La interfaz principal, JFrame gui.java, esta formada por dos JButton y un JPanel llamado CONTAINER de tamaño 600×400, se cambio el color de fondo por uno mas oscuro para que pueda apreciarse mucho mejor el efecto de explosión.

php4ever

4. La clase “explode” es quien realizara el efecto de explosión, se utiliza “ScheduledExecutorService” el cual nos permite ejecutar una acción cada “n” tiempo.

En el constructor de clase se pasan dos parámetros de tipo JPanel, containercontent, el primero es el JPanel que contendrá al o los JPanel que tienen el efecto explode, el content, es el JPanel que se vera afectado con el efecto explode.

Tenemos también el método PLAY(), este es el que va incrementando el tamaño del JPanel ademas de que coloca el objeto en el centro del contenedor a medida que este crece. Cuando el JPanel content alcanza el máximo tamaño, se detiene.

import java.awt.Dimension;
import java.util.concurrent.Executors;
import java.util.concurrent.ScheduledExecutorService;
import java.util.concurrent.TimeUnit;
import javax.swing.JPanel;
/**
 * @web http://www.jc-mouse.net/
 * @author Mouse
 */
public class explode {

    private ScheduledExecutorService scheduler = Executors.newSingleThreadScheduledExecutor();    
    private Dimension d;
    private int count = 0;
    //
    private JPanel container;
    private JPanel content;
    //coordenadas del JPanel contenido
    private int px=0;
    private int py=0;
    //
    private int ancho_min = 10;
    private int alto_min = 10;
    private int velocidad = 20;//en milisegundos

    /**
 * Constructor de clase
 */
    public explode( JPanel container , JPanel content )
    {
        this.container = container;
        this.content = content;        
        this.container.removeAll();

        d = new Dimension( 10 ,10 );
        this.content.setSize( d );//tamaño inicial

        //coordenadas iniciales
        px = this.container.getSize().width/2-this.ancho_min/2;
        py = this.container.getSize().height/2-this.alto_min/2;        
        content.setLocation( px, py );
        content.setVisible(true);

        //se agrega al contenedor el JPanel contenido
        this.container.add( content );
        count = 10;
    }

    /**
 * Metodo para ejecutar el efecto EXPLODE
 */
    public void play()
    {       
        scheduler = Executors.newSingleThreadScheduledExecutor();
        scheduler.scheduleAtFixedRate( 
            new Runnable() 
            {

                @Override
                public void run() {                     
                    //nuevo tamaño 
                    d = new Dimension( container.getSize().width * count/100 , container.getSize().height * count/100 );
                    count = count + 10;
                    //se recalcula la posicion mientras el jpanel crece
                    px = container.getSize().width/2-d.width/2;
                    py = container.getSize().height/2-d.height/2;        
                    content.setLocation( px, py );

                   if( count > 100 ) 
                   {                       
                       close();                       
                   }
                   content.setSize( d );
                   container.updateUI();                        
                }
              }, 100, velocidad , TimeUnit.MILLISECONDS );

    }

    /**
 * Metodo para terminar el efecto explode
 */
    public void close() {
        scheduler.shutdownNow();
    }

}//--> fin clase

5. Para acabar debemos implementar todo en el JFrame gui de la siguiente manera:

– Se crean dos instancias de los JPanel

01 public class gui extends javax.swing.JFrame {
02 
03     panel_A panel_a = new panel_A();
04     panel_B panel_b = new panel_B();

– Se añade el código para cada JButton de la siguiente forma

01     private void jButton1ActionPerformed(java.awt.event.ActionEvent evt) {                                         
02         new explode( CONTAINER , panel_a ).play();
03     }                                        
04 
05     private void jButton2ActionPerformed(java.awt.event.ActionEvent evt) {                                         
06         new explode( CONTAINER , panel_b ).play();
07     }

Ejecuta la aplicación y si no tienes errores ya puedes probar el efecto explosión.

exploto

Proyecto: JPanel Explode

Tags

Si te ha gustado podrías compartirlo o dejar un comentario. ¡Muchas gracias!
Autor: JC Mouse

Yo soy yo :) JC Mouse, Soy orgullosamente boliviano soy fundador y CEO de la web jc-Mouse.net uno de las pocas web en emprendimiento y tecnología en Bolivia.

Toda la información que encuentres en este sitio es y sera completamente gratis siempre, puedes copiar, descargar y re-publicar si así lo deseas en otros blogs o sitios web, solo te pido a cambio que dejes una referencia a esta web. Esto nos ayuda a crecer y seguir aportando. Bye

Enjoy! :)

También Te Podría Interesar

Estilos condicionales en iReport

Estilos condicionales en iReport

iReport nos da la posibilidad de dar un formato condicional a los diferentes registros resultado de nuestras consultas S...

Búsqueda binaria (Binary Search)

Búsqueda binaria (Binary Search)

Un algoritmo de búsqueda binaria se emplea para buscar un valor en particular en un arreglo previamente ordenado. Para i...

Material Design: CardView (Tarjetas)

Material Design: CardView (Tarjetas)

Un CardView es parte de los estilos de Material Design y nos permite mostrar información dentro de tarjetas (Card), esta...

No a la ley SOPA

No a la ley SOPA

¿Qué es S.O.P.A y PROTECT-IP? SOPA y PROTECT-IP son proyectos de leyes introducidos en la Cámara de Representantes de lo...

Servicio Web SOAP en Java

Servicio Web SOAP en Java

En este post vamos a construir un Servicio Web bajo el protocolo SOAP (Simple Object Access Protocol) el cual básicament...

ArrayDeque: Cola doblemente terminada

ArrayDeque: Cola doblemente terminada

Una cola doblemente terminada o deque es una estructura de datos lineal que permite insertar y eliminar elementos por am...

8 comentarios en “Efecto de explosión al abrir un JPanel”

  1. Oscar dice:

    Hola, muy bueno tu trabajo. Me gustaría saber como hago para aplicarlo a un JFrame.

  2. Carlos dice:

    Buenisimo tu aporte mouse … como siempre

    Te queria preguntar …. si esto lo puedo usar en un JTABBEDPANEL ??

  3. Hans Cerda Woo dice:

    Hola hermano, q buen aporte, gracias por sus trabjos, eh aprendido muchisimo con ustedes, gracias Hermanos d JCMouse

  4. richar16 dice:

    Muy bueno. Se te agradece JC. ¿Quisiera saber si has usado JAVAFX 2.x para GUI?
    http://www.youtube.com/watch?v=o-iRc9XkgZ0

  5. VIANEY VARGAS dice:

    Excelente eres el mejor

  6. Jaime dice:

    Excelente, muy buena la paguina … 🙂 pasare seguido por aqui

  7. Carlos dice:

    Hola, esta muy padre tu aporte. Me gustaría saber como hacerle para aplicarlo a un formulario JFrame… gracias

Los comentarios estan cerrados

Comparte lo que sabes

Categorias

Últimas entradas

JSON es un formato de texto ligero para el intercambio de datos ampliamente usado en los Servicios Web. En este post uti...

En este post conoceremos algunos de los operadores de comparación que existen en Linux y realizaremos unos ejercicios pa...

En este post conocernos lo que son las Estructuras de Control IF en los script de Bash. Estas estructuras nos ayudan a c...

Todo producto tecnológico tiene un ciclo de vida, algunos bastante corto otros muy largo, podemos mencionar el software...

Android Bolivia

MAUS