JavaA2Z

KAB-studio > プログラミング > JavaA2Z > ダイアログとは

ダイアログ

日本語 対話窓
英語 dialog
ふりがな だいあろぐ
フリガナ ダイアログ

解説

ユーザーに確認する時に使用するウィンドウ。
ウィンドウの一種。基本的には通常のウィンドウと変わらないが、多くの場合、ユーザーに対して確認するためのメッセージを表示し、それに対して「OKボタン」「キャンセルボタン」等を押してもらうために使用する。
ただし、特にJavaでは普通のウィンドウとダイアログの区別があまり明確ではなく、通常のアプリケーションで使用されるダイアログほど明確な違いはない。
 
ダイアログには主に以下の2種類がある。
 
モーダルダイアログ
モードレスダイアログ
 
また、前述の「ユーザーに確認する」ために特化した、簡単に表示できるダイアログを「メッセージボックス」と呼ぶ。
 
ダイアログは、AWTであればDialogクラスを使用して作成する。
ただし、中身はほとんどウィンドウと同じで、表示に「表示元ウィンドウ」が必要なこと、モーダルダイアログモードレスダイアログの区別が付けられること、表示にshow()メソッド、終了にhide()メソッドを使用する、といった違いしかない。

参考サイト


(KAB-studioからのおしらせです)

サンプルプログラム(とか)サンプルを別ウィンドウで表示サンプルをクリップボードへコピー(WindowsでIEの場合のみ)

// Sample.java
import java.awt.Frame;
import java.awt.Dialog;
import java.awt.Label;
import java.awt.Button;
import java.awt.GridLayout;
import java.awt.event.ActionListener;
import java.awt.event.WindowListener;
import java.awt.event.ActionEvent;
import java.awt.event.WindowEvent;

public class Sample
{
    public static void main( String[] args )
    {
        // ウィンドウを作ります。
        NormalWindow normalWindow = new NormalWindow();
        // コンストラクタでウィンドウが作られます。
    }
}

/**
*   普通のウィンドウクラス。
*/
class NormalWindow extends Frame implements WindowListener
{
    /**
    *   コンストラクタ。
    */
    public NormalWindow()
    {
        // ウィンドウを作ります。
        super"テストウィンドウ" );
        addWindowListener( this );
        setSize( 400 , 300 );
        setVisible( true );
    }

    /**
    *   ウィンドウが閉じようとするときに呼ばれるメソッド。
    */
    public void windowClosing( WindowEvent windowEvent )
    {
        System.out.println( "NormalWindow#windowClosing()" );

        // ウィンドウを閉じていいか、ダイアログで確認します。
        // ダイアログそのものはコンストラクタで作られます。
        CloseDialog dialog = new CloseDialog( this );
        if( dialog.isOk )
        {
            // 「OK」ボタンが押されたのでウィンドウの終了処理を行います。
            dispose();
        }
    }

    /**
    *   ウィンドウが閉じるときに呼ばれるメソッド。
    */
    public void windowClosed( WindowEvent windowEvent )
    {
        System.out.println( "NormalWindow#windowClosed()" );
        System.exit( 0 );
    }

    /**
    *   以下、その他イベントハンドラ。
    *   これらのメソッドはWindowListenerインターフェイスの
    *   メソッドなので、全てオーバーライドする必要があるためです。
    */
    public void windowActivated( WindowEvent windowEvent )
    {
        System.out.println( "NormalWindow#windowActivated()" );
    }

    public void windowDeactivated( WindowEvent windowEvent )
    {
        System.out.println( "NormalWindow#windowDeactivated()" );
    }

    public void windowDeiconified( WindowEvent windowEvent )
    {
        System.out.println( "NormalWindow#windowDeiconified()" );
    }

    public void windowIconified( WindowEvent windowEvent )
    {
        System.out.println( "NormalWindow#windowIconified()" );
    }

    public void windowOpened( WindowEvent windowEvent )
    {
        System.out.println( "NormalWindow#windowOpened()" );
    }
}

/**
*   終了確認ダイアログクラス。
*/
class CloseDialog extends Dialog implements ActionListener
{
    /** OKならtrue、キャンセルならfalseのフラグ。 */
    public boolean isOk = false;
    
    /**
    *   コンストラクタ。
    */
    public CloseDialog( Frame frame )
    {
        // 第3引数にtrueをセットすることで、モーダルダイアログにします。
        super( frame, "終了確認", true );
        setSize( 200 , 100 );

        // 縦3段のレイアウトにします。
        setLayout( new GridLayout( 3, 0 ) );

        // ダイアログに表示する文字列を貼り付けます。
        Label lable = new Label( "終了します。よろしいですか?" );
        add( lable );

        // OKボタンを貼り付けます。
        Button buttonOk = new Button( "OK" );
        buttonOk.addActionListener( this );
        add( buttonOk );

        // キャンセルボタンを貼り付けます。
        Button buttonCancel = new Button( "キャンセル" );
        buttonCancel.addActionListener( this );
        add( buttonCancel );

        // ダイアログを表示します。
        show();
    }

    /**
    *   ボタンが押されたときに呼び出されるメソッドです。
    */
    public void actionPerformed( ActionEvent event )
    {
        // OKボタンが押されていたらisOkにtrueをセットします。
        if( event.getActionCommand().equals( "OK" ) )
        {
            isOk = true;
        }
        else
        {
            isOk = false;
        }

        // ダイアログを閉じます。
        hide();
    }
}
// Sample.java
import java.awt.Frame;
import java.awt.Dialog;
import java.awt.Label;
import java.awt.Button;
import java.awt.GridLayout;
import java.awt.event.ActionListener;
import java.awt.event.WindowListener;
import java.awt.event.ActionEvent;
import java.awt.event.WindowEvent;

public class Sample
{
    public static void main( String[] args )
    {
        // ウィンドウを作ります。
        NormalWindow normalWindow = new NormalWindow();
        // コンストラクタでウィンドウが作られます。
    }
}

/**
*   普通のウィンドウクラス。
*/
class NormalWindow extends Frame implements WindowListener
{
    /**
    *   コンストラクタ。
    */
    public NormalWindow()
    {
        // ウィンドウを作ります。
        super( "テストウィンドウ" );
        addWindowListener( this );
        setSize( 400 , 300 );
        setVisible( true );
    }

    /**
    *   ウィンドウが閉じようとするときに呼ばれるメソッド。
    */
    public void windowClosing( WindowEvent windowEvent )
    {
        System.out.println( "NormalWindow#windowClosing()" );

        // ウィンドウを閉じていいか、ダイアログで確認します。
        // ダイアログそのものはコンストラクタで作られます。
        CloseDialog dialog = new CloseDialog( this );
        if( dialog.isOk )
        {
            // 「OK」ボタンが押されたのでウィンドウの終了処理を行います。
            dispose();
        }
    }

    /**
    *   ウィンドウが閉じるときに呼ばれるメソッド。
    */
    public void windowClosed( WindowEvent windowEvent )
    {
        System.out.println( "NormalWindow#windowClosed()" );
        System.exit( 0 );
    }

    /**
    *   以下、その他イベントハンドラ。
    *   これらのメソッドはWindowListenerインターフェイスの
    *   メソッドなので、全てオーバーライドする必要があるためです。
    */
    public void windowActivated( WindowEvent windowEvent )
    {
        System.out.println( "NormalWindow#windowActivated()" );
    }

    public void windowDeactivated( WindowEvent windowEvent )
    {
        System.out.println( "NormalWindow#windowDeactivated()" );
    }

    public void windowDeiconified( WindowEvent windowEvent )
    {
        System.out.println( "NormalWindow#windowDeiconified()" );
    }

    public void windowIconified( WindowEvent windowEvent )
    {
        System.out.println( "NormalWindow#windowIconified()" );
    }

    public void windowOpened( WindowEvent windowEvent )
    {
        System.out.println( "NormalWindow#windowOpened()" );
    }
}

/**
*   終了確認ダイアログクラス。
*/
class CloseDialog extends Dialog implements ActionListener
{
    /** OKならtrue、キャンセルならfalseのフラグ。 */
    public boolean isOk = false;
    
    /**
    *   コンストラクタ。
    */
    public CloseDialog( Frame frame )
    {
        // 第3引数にtrueをセットすることで、モーダルダイアログにします。
        super( frame, "終了確認", true );
        setSize( 200 , 100 );

        // 縦3段のレイアウトにします。
        setLayout( new GridLayout( 3, 0 ) );

        // ダイアログに表示する文字列を貼り付けます。
        Label lable = new Label( "終了します。よろしいですか?" );
        add( lable );

        // OKボタンを貼り付けます。
        Button buttonOk = new Button( "OK" );
        buttonOk.addActionListener( this );
        add( buttonOk );

        // キャンセルボタンを貼り付けます。
        Button buttonCancel = new Button( "キャンセル" );
        buttonCancel.addActionListener( this );
        add( buttonCancel );

        // ダイアログを表示します。
        show();
    }

    /**
    *   ボタンが押されたときに呼び出されるメソッドです。
    */
    public void actionPerformed( ActionEvent event )
    {
        // OKボタンが押されていたらisOkにtrueをセットします。
        if( event.getActionCommand().equals( "OK" ) )
        {
            isOk = true;
        }
        else
        {
            isOk = false;
        }

        // ダイアログを閉じます。
        hide();
    }
}

この単語を含むページ

はてなブックマーク 詳細を表示 はてなブックマーク ブックマーク数
livedoorクリップ 詳細を表示 livedoorクリップ ブックマーク数
Yahoo!ブックマーク 詳細を表示 users
del.icio.us 登録する RSSに登録
サンプルを別ウィンドウで表示
サンプルをクリップボードへコピー(WindowsでIEの場合のみ)
update:2005/06/25
このページは、Javaプログラミング言語についての用語を網羅した辞書「JavaA2Z」の一ページです。
詳しくは「JavaA2Z」表紙の説明をご覧ください。