タイトルとオプションタイプを指定して選択ダイアログを表示する
選択ダイアログでダイアログのタイトルとオプションタイプを指定して選択ダイアログを表示する方法を確認します。JOptionPaneクラスで用意されている「showConfirmDialog」メソッドを使います。前頁の同名のメソッドとは引数が異なります。
public static int showConfirmDialog(Component parentComponent, Object message, String title, int optionType) throws HeadlessException
optionType パラメータで選択項目数が決まるダイアログを表示します。 パラメータ: parentComponent - ダイアログを表示する Frame を指定する。null の場合、 または parentComponent に Frame がない場合は、デフォルトの Frame が 使用される message - 表示する Object title - ダイアログのタイトル文字列 optionType - ダイアログで選択可能なオプションを示す int 値。 YES_NO_OPTION、YES_NO_CANCEL_OPTION、または OK_CANCEL_OPTION 戻り値: ユーザーが選択したオプションを示す int 値 例外: HeadlessException - GraphicsEnvironment.isHeadless が true を返す場合
このメソッドを使うと表示されるボタンの種類とタイトルを指定できる選択ダイアログを表示できます。
1番目の引数にダイアログを表示するための親フレームを指定します。例えばJFrameクラスのオブジェクトを指定して下さい。
2番目の引数にはダイアログに表示するオブジェクトを指定します。単に文字列を表示するだけであればString型の値を指定すればいいですし、JLabelクラスなどのオブジェクトを指定しても構いません。
3番目の引数にはダイアログのタイトルをString型の値で指定します。
4番目の引数にはダイアログに表示されるボタンの種類を示すint型の値を設定します。設定できる値は次の通りです。
値 | 実際の値 | 表示されるボタン |
---|---|---|
JOptionPane.YES_NO_OPTION | 0 | YES/NO |
JOptionPane.YES_NO_CANCEL_OPTION | 1 | YES/NO/CANCEL |
JOptionPane.OK_CANCEL_OPTION | 2 | OK/CANCEL |
戻り値としてユーザーがどのボタンをクリックしたかを表すint型の値を取得できます。取得できる値は次の通りです。
値 | 実際の値 |
---|---|
JOptionPane.YES_OPTION | 0 |
JOptionPane.NO_OPTION | 1 |
JOptionPane.CANCEL_OPTION | 2 |
JOptionPane.OK_OPTION | 0 |
実際の使い方は次のようになります。
JFrame frame = new JFrame(); int option = JOptionPane.showConfirmDialog(frame, "Message", "Title", JOptionPane.OK_CANCEL_OPTION);
サンプルプログラム
では簡単なサンプルを作成して試してみます。
import javax.swing.*; import java.awt.BorderLayout; import java.awt.event.*; public class JOptionPaneTest6 extends JFrame implements ActionListener{ JLabel ansLabel; public static void main(String[] args){ JOptionPaneTest6 frame = new JOptionPaneTest6(); frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); frame.setBounds(10, 10, 300, 200); frame.setTitle("タイトル"); frame.setVisible(true); } JOptionPaneTest6(){ JButton infoButton = new JButton("Question"); infoButton.addActionListener(this); JPanel p = new JPanel(); p.add(infoButton); ansLabel = new JLabel("未選択です"); JPanel ansPanel = new JPanel(); ansPanel.add(ansLabel); getContentPane().add(p, BorderLayout.CENTER); getContentPane().add(ansPanel, BorderLayout.PAGE_END); } public void actionPerformed(ActionEvent e){ int option = JOptionPane.showConfirmDialog(this, "購入しますか?", "選択ダイアログ", JOptionPane.YES_NO_OPTION); if (option == JOptionPane.YES_OPTION){ ansLabel.setText("購入しました"); }else if (option == JOptionPane.NO_OPTION){ ansLabel.setText("購入されませんでした"); } } }
上記をコンパイルした後で実行すると次のように表示されます。
ボタンをクリックすると選択ダイアログが表示されます。
選択ダイアログでクリックしたボタンに応じて画面下のラベルが書き換えられます。
( Written by Tatsuo Ikura )
著者 / TATSUO IKURA
プログラミングや開発環境構築の解説サイトを運営しています。