Aprende Java Aprende Php Aprende C++ Aprende HTML 5 Aprende JavaScript Aprende JSON Aprende MySQL Aprende SQLServer Aprende Visual Basic 6 Aprende PostgreSQL Aprende SQLite Aprende Redis Aprende Kotlin Aprende XML Aprende Linux VSC Aprende Wordpress Aprende Laravel Aprende VueJS Aprende JQuery Aprende Bootstrap Aprende Netbeans Aprende Android
Sigueme en Facebook Sigueme en Twitter Sigueme en Instagram Sigueme en Youtube Sigueme en TikTok Sigueme en Whatsapp
Home / Java / Rompecabezas con forma irregular

Rompecabezas con forma irregular

Por jc mouse miércoles, mayo 15, 2013

En este post vemos una manera de como crear un juego de rompecabezas en java sin el uso de java2d, ademas, las piezas del puzzle no serán las típicas rectangulares sino tendrán una forma irregular, para esto lo mejor es utilizar imágenes con el fondo transparente, ademas para poder mover fácilmente las piezas, emplearemos Absolute Layout, es un ejemplo sencillo, no habrá nivel de complejidad, no habrá score ni nada parecido, es un simple juego de rompecabezas.

Herramientas

– Netbeans 7.3

– Editor de imágenes Photoshop, Gimp , etc

– Liberia AbsoluteLayout.jar

Las piezas del puzzle

Para crear el rompecabezas partiremos de una imagen *.PNG de 500×450 pixeles el cual utilizando un editor de imágenes, dividiremos en 9 partes con forma irregular (las dimensiones de cada pieza no nos interesa),  guardaremos las 9 piezas en  disco con formato *.PNG y fondo transparente, por ejemplo «asuka1.png, asuka2.png, etc».

A mi me quedaron las 9 piezas de la siguiente manera:

Asuka evangelion

El rompecabezas en netbeans

1. Crea un nuevo proyecto (nombre: puzzle) con la siguiente estructura:

estructura rompecabezas

Podemos ver que las 9 imágenes que creamos más arriba, las añadimos al paquete RESOURCES, ademas añadimos la librería Absolute Layout, tenemos PrincipalView que es un JFrame, y dos clases más que son Pieza y Tablero.

El funcionamiento del juego es muy simple, tenemos una clase Pieza que se extiende de un JLabel la cual, sera implementada en la clase Tablero donde crearemos una matriz 3×3, la clase Tablero se extiende de un JPanel. Se hará uso de la librería Absolute Layout para poder posicionar las piezas en cualquier lugar del tablero, inclusive una encima de otra.

Todas las clases están debidamente comentadas, ademas que el proyecto es pequeño y sera fácilmente entendible 🙂

2. Clase Pieza.java .

import java.awt.Dimension;
import java.awt.Point;
import java.awt.event.MouseEvent;
import java.awt.event.MouseListener;
import java.awt.event.MouseMotionListener;
import javax.swing.ImageIcon;
import javax.swing.JLabel;
/**
 * @web https://www.jc-mouse.net/
 * @author Mouse
 */
public class Pieza extends JLabel implements MouseListener, MouseMotionListener {

    //para el movimiento de la pieza
    private Point start_drag;
    private Point start_loc;

    /**
 * Constructor de clase
 * @param pieza numero de pieza
 * @param location Point coordenas de la pieza sobre su contenedor
 */
    public Pieza( int pieza, Point location ){    

        this.setText("");
        this.setVisible(true);        
        ImageIcon icon = new ImageIcon( getClass().getResource("/org/game/resources/asuka"+pieza+".png"));
        this.setIcon( icon );
        Dimension d = new Dimension( icon.getIconWidth(), icon.getIconHeight() );        
        this.setPreferredSize( d );
        this.setSize( d ); 
        this.setLocation( location );
        //Listener
        this.addMouseListener(this);
        this.addMouseMotionListener(this);        
    }

    @Override
    public void mouseClicked(MouseEvent e) {        
    }

    @Override
    public void mousePressed(MouseEvent e) {
       this.start_drag = getScreenLocation(e);
       this.start_loc = this.getLocation();
    }

    @Override
    public void mouseReleased(MouseEvent e) {
    }

    @Override
    public void mouseEntered(MouseEvent e) {
    }

    @Override
    public void mouseExited(MouseEvent e) {
    }

    @Override
    public void mouseDragged(MouseEvent e) {
        Point current = this.getScreenLocation(e);      
        Point offset = new Point((int) current.getX() - (int) start_drag.getX(),(int) current.getY() - (int) start_drag.getY());        
        Point new_location = new Point((int) (this.start_loc.getX() + offset.getX()), (int) (this.start_loc.getY() + offset.getY()));      
        this.setLocation(new_location);    
        this.repaint();
    }

    @Override
    public void mouseMoved(MouseEvent e) {        
    }

    /**
 * metodo para obtener la posicion del frame en la pantalla
 * @param evt Evento del raton
 * @return Point obtiene las coordenadas del objeto sobre el tablero
 */
    public Point getScreenLocation( MouseEvent evt ) {
        Point cursor = evt.getPoint();
        Point target_location = this.getLocationOnScreen();
        return new Point((int) (target_location.getX() + cursor.getX()),
            (int) (target_location.getY() + cursor.getY()));
    }

}//--> end class

Nota: el código para mover la pieza no es mio :), es un código ya bastante conocido por internet así que no se quien es el autor 🙂

3. Clase Tablero.java .

import java.awt.Dimension;
import java.awt.Point;
import java.util.Random;
import javax.swing.JPanel;
import org.netbeans.lib.awtextra.AbsoluteLayout;
/**
 * @web https://www.jc-mouse.net/
 * @author Mouse
 */
public class Tablero extends JPanel{

    private int fila = 3;
    private int columna = 3;
    Pieza [][] matriz = new Pieza[fila][columna];        

    /** 
 * COnstructor de clase
 */
    public Tablero(){

        Dimension dt = new Dimension(500,450);
        this.setPreferredSize(dt);
        this.setSize(dt);
        this.setVisible(true);
        this.setBorder( javax.swing.BorderFactory.createLineBorder( new java.awt.Color(0, 0, 0) ) );        

        //Se añaden las piezas al tablero
        int p = 1;
        for( int i=0 ; i< fila; i++)
        {
            for( int j=0 ; j<columna; j++)
            {
                //coordenas aleatorias de pieza
                int x = 50 + ( new Random()).nextInt(400-10);
                int y = 50 + ( new Random()).nextInt(300-10);                
                Point location = new Point(x,y);
                matriz[i][j] = new Pieza( p , location );
                this.add( matriz[i][j] );
                p++;
            }
        }
        //se asigna Layout
        this.setLayout( new AbsoluteLayout() );
    }

}//--> end class

4. JFrame PrincipalView. La interfaz se reduce a un JPanel de dimensión 500×450

jpuzzle

Debemos implementar la clase Tablero de la siguiente forma:

package org.game.gui;
import org.game.models.Tablero;
/**
 * @web https://www.jc-mouse.net/
 * @author Mouse
 */
public class PrincipalView extends javax.swing.JFrame {

    //instancia de tablero
    private Tablero tablero = new Tablero();

    /**
 * Creates new form principal
 */
    public PrincipalView() {
        initComponents();
        this.setLocationRelativeTo(null);
        this.setTitle("Puzzle Kawaii - https://www.jc-mouse.net/");
        this.jPanel1.add( tablero );
    }

Y ejecutando tenemos:

evangelion game

Actualizado 04/01/2026

Descargate el ejemplo del post en este LINK pobre

Tags

Artículos similares

Pruebas Unitarias con PHPUnit

PHPUnit es un framework que se utiliza para escribir tests en PHP, Netbeans nos permite configurarlo y usarlo fácilmente[...]

Introducción a MariaDB con Java

Maria DB  es un sistema de gestión de bases de datos derivado de MySQL con licencia GPL, pero con un rendimiento similar[...]

Capturar foto desde una webcam con Java Media Framework

Como se vio en un post anterior (Capturar video de una webcam con JMF) la captura de un video desde una webcam utilizand[...]

Convertir imágenes JPG a PDF

En este post vemos un ejemplo de como convertir un archivo de imagen JPG en un archivo PDF utilizando para ellos la libr[...]

Personalización de Componentes Swing Java I

Hace tiempo pidieron un video tutorial sobre como crear sus propios componentes swing java, lamentablemente debo decir q[...]

Desarrollo web creativo en 3D con ThreeJS

Three.js es el motor de facto que que permite la creación de gráficos 3D interactivos directamente en el navegador web,[...]