Main.java Source code

Java tutorial

Introduction

Here is the source code for Main.java

Source

//package com.java2s;
import java.awt.BorderLayout;

import java.awt.Component;
import java.awt.Container;
import java.awt.Dialog;
import java.awt.Dimension;

import java.awt.Frame;

import java.awt.HeadlessException;

import java.awt.Window;

import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;

import java.awt.event.WindowAdapter;
import java.awt.event.WindowEvent;

import javax.swing.AbstractAction;

import javax.swing.Action;

import javax.swing.BorderFactory;
import javax.swing.Box;
import javax.swing.BoxLayout;

import javax.swing.JButton;

import javax.swing.JComponent;
import javax.swing.JDialog;

import javax.swing.JOptionPane;
import javax.swing.JPanel;
import javax.swing.JRootPane;

import javax.swing.SwingUtilities;
import javax.swing.UIManager;

public class Main {
    /**
     * A utility method for displaying a dialog.
     *
     * @param parentComponent
     * @param message
     * @param title
     * @return
     */
    public static int showDialog(Component parentComponent, Object message, String title) {
        JOptionPane.showMessageDialog(parentComponent, message, title, JOptionPane.PLAIN_MESSAGE);

        return -1;
    }

    /**
     * Displays an {@link JDialog}.
     *
     * @param parentComponent
     * @param title
     * @return
     */
    public static void showDialog(Component parentComponent, JComponent component, String title) {
        final JDialog dialog;
        final Window window = getWindowForComponent(parentComponent);
        if (window instanceof Frame) {
            dialog = new JDialog((Frame) window, title, true);
        } else {
            dialog = new JDialog((Dialog) window, title, true);
        }
        initDialog(dialog, component, parentComponent);

        dialog.setLocationRelativeTo(parentComponent);
        dialog.setVisible(true);
    }

    /**
     * Returns the parent window for the component by navigating up the
     * component hierarchy. 
     *
     * @param comp the component to test.
     * @return the parent {@link Window} if one is found.
     * @throws HeadlessException
     */
    public static Window getWindowForComponent(Component comp) throws HeadlessException {
        if (comp instanceof Frame || comp instanceof Dialog) {
            return (Window) comp;
        }
        return getWindowForComponent(comp.getParent());
    }

    /**
     * Initialises the {@link JDialog} for the {@link JComponent}.
     * 
     * @param dialog
     * @param component
     * @param parentComponent
     */
    private static void initDialog(final JDialog dialog, final JComponent component,
            final Component parentComponent) {
        dialog.setResizable(true);
        dialog.setComponentOrientation(component.getComponentOrientation());
        Container contentPane = dialog.getContentPane();

        contentPane.setLayout(new BorderLayout());
        contentPane.add(component, BorderLayout.CENTER);

        final int buttonWidth = 75;

        final JPanel buttonPanel = new JPanel();
        buttonPanel.setLayout(new BoxLayout(buttonPanel, BoxLayout.X_AXIS));
        buttonPanel.setBorder(BorderFactory.createEmptyBorder(2, 4, 4, 4));

        buttonPanel.add(Box.createHorizontalGlue());

        @SuppressWarnings("serial")
        final Action closeAction = new AbstractAction("Close") {
            @Override
            public void actionPerformed(ActionEvent e) {
                dialog.dispose();
            }
        };

        final JButton button = new JButton(closeAction);
        fixWidth(button, buttonWidth);
        buttonPanel.add(button);

        contentPane.add(buttonPanel, BorderLayout.SOUTH);

        if (JDialog.isDefaultLookAndFeelDecorated()) {
            boolean supportsWindowDecorations = UIManager.getLookAndFeel().getSupportsWindowDecorations();
            if (supportsWindowDecorations) {
                dialog.setUndecorated(true);
                component.getRootPane().setWindowDecorationStyle(JRootPane.PLAIN_DIALOG);
            }
        }
        dialog.pack();
        dialog.setLocationRelativeTo(parentComponent);
        WindowAdapter adapter = new WindowAdapter() {
            //         private boolean gotFocus = false;
            public void windowClosing(WindowEvent we) {
                fireAction(we.getSource(), closeAction, "close");
            }
        };
        dialog.addWindowListener(adapter);
        dialog.addWindowFocusListener(adapter);
    }

    /**
     * Fixes the width of the component but maintaining it old height.
     *
     * @param comp
     * @param width
     */
    public static void fixWidth(JComponent comp, int width) {
        comp.setPreferredSize(new Dimension(width, comp.getPreferredSize().height));
        comp.setMaximumSize(comp.getPreferredSize());
    }

    /**
     * Fires a {@link ActionListener} using zero modifiers. This is useful for
     * firing {@link ApplicationAction}s to show blocking dialog.
     *
     * @param source the source of the event.
     * @param listener the listener to fire.
     * @param command a string that may specify a command (possibly one 
     * of several) associated with the event.
     * @see #fireAction(Object, ActionListener, String, int)
     */
    public static void fireAction(Object source, ActionListener listener, String command) {
        fireAction(source, listener, command, 0);
    }

    /**
     * Fires a {@link ActionListener}. This is useful for firing 
     * {@link ApplicationAction}s to show blocking dialog.
     *
     * @param source the source of the event.
     * @param listener the listener to fire.
     * @param command a string that may specify a command (possibly one 
     * of several) associated with the event.
     * @param modifiers the modifier keys held down during this action.
     * @see ActionEvent#ActionEvent(Object, int, String, long, int)
     */
    public static void fireAction(final Object source, final ActionListener listener, final String command,
            final int modifiers) {
        fireAction(listener, new ActionEvent(source, ActionEvent.ACTION_PERFORMED, command,
                System.currentTimeMillis(), modifiers));
    }

    /**
     * Fires a {@link ActionListener}. This is useful for firing 
     * {@link ApplicationAction}s to show blocking dialog. This can be called
     * on and off the EDT.
     *
     * @param listener the listener to fire.
     * @param evt the action event to fire.
     * @param modifiers the modifier keys held down during this action.
     * @see ActionEvent#ActionEvent(Object, int, String, long, int)
     */
    public static void fireAction(final ActionListener listener, final ActionEvent evt) {
        if (!SwingUtilities.isEventDispatchThread()) {
            SwingUtilities.invokeLater(new Runnable() {
                @Override
                public void run() {
                    fireAction(listener, evt);
                }
            });
            return;
        }
        listener.actionPerformed(evt);
    }
}