Martinus Ady H. BloG

Human Knowledge Belongs To The World

Background Image in JDesktopPane

| Comments

Bingung bagaimana caranya menambahkan background image ke dalam JDesktopPane di NetBeans IDE ? Nah kalau bingung, sekarang buatlah sebuah project dahulu di NetBeans IDE kemudian buatlah 1 buah Java Class dengan nama JImageDesktopPane (nama class terserah keinginan masing-masing :) ) kemudian pastekan kode dibawah ini :

/*
 * To change this template, choose Tools | Templates
 * and open the template in the editor.
 */
package jdesktoppanebackground;

import java.awt.Graphics;
import java.awt.Image;
import javax.swing.JDesktopPane;

/**
 *
 * @author Martinus Ady H <mrt.itnewbies@gmail.com>
 */
public class JImageDesktopPane extends JDesktopPane {

    private Image image;

    public JImageDesktopPane() {
    }

    @Override
    protected void paintComponent(Graphics g) {
        try {
            image = new javax.swing.ImageIcon(getClass().getResource("netbeans6ns0.png")).getImage();

            if (g != null) {
                g.drawImage(image,
                        (this.getSize().width - image.getWidth(null)) / 2,
                        (this.getSize().height - image.getHeight(null)) / 2,
                        null);
            }
        } catch (NullPointerException npe) {
            System.out.println("Can't find images !!");
        }
    }
}

Baris paling penting diatas terdapat pada baris ke 25, karena pada baris ke 25 kita mencoba mengambil gambar yang ingin kita jadikan sebagai Background Image dan sedangkan method paintComponent(Graphics g) pada baris 23-37 ini kita gunakan jika kita ingin mengubah-ubah tampilan dari JComponent di Java Swing :)

Nah jika sudah selesai, sekarang simpan gambar dibawah ini dengan nama netbeans6ns0.png pada direktori project netbeans6ns0
Save Image As Gambar Ini

Jika sudah selesai, maka harusnya tampilan pada pallete Project akan nampak seperti dibawah ini : PalleteProject
Tampilan Pallete Project Setelah Penambahan Image

Sekarang lakukan proses kompilasi dahulu terhadap file yang sudah dibuat, dan jika sudah sekarang tambahkanlah sebuah JFrame dan sebuah JMenuBar hingga tampilan-nya menjadi seperti dibawah ini : JFrame_with_MenuBar
JFrame dengan JMenuBar

Setelah itu, sekarang mari kita tambahkan class JImageDesktopPane ke dalam JFrame dengan cara DRAG and DROP pada class JImageDesktopPane kedalam JFrame dan atur seperti gambar dibawah ini : Drag_N_Drop
Lakukan Proses Drag and Drop Kedalam JFrame

Jika sudah, pada JMenuBar klik kanan Menu Edit kemudian tambahkan-lah JMenuItem kemudian beri Action seperti berikut :

    private void jMenuItem1ActionPerformed(java.awt.event.ActionEvent evt) {
        try {
            JInternalFrame iFrame = new JInternalFrame("Internal Frame");
            jImageDesktopPane1.add(iFrame);
            iFrame.setClosable(true);
            iFrame.setVisible(true);
            iFrame.setSelected(true);
            iFrame.setSize(200, 200);
        } catch (PropertyVetoException ex) {
            Logger.getLogger(MainForm.class.getName()).log(Level.SEVERE, null, ex);
        }
    }

Sekarang coba lakukan proses Clean Build kemudian tekan tombol F6 untuk melihat hasilnya, dan jika tidak ada kesalahan maka kita akan melihat tampilan seperti dibawah ini :

JDesktopPane_With_Background
Tampilann Awal

JDesktopPaneAction_With_iFrame
Tampilan Ketika Menambahkan JInternalFrame

Mudah bukan :)

Link-link terkait : - Java Swing Tutorial - JDesktopPane API - JComponent API - Contoh Project JDesktopPane Background - Source code Project JDesktopPane Background - SubVersion Mudah Dengan RabbitVCS

Beri Komentar Lewat Facebook:

Beri Komentar Lewat Disqus: