カスタムダイアログを表示する

広告

任意の文字列が表示されたボタンを持つダイアログを表示する方法を確認します。JFileChooserクラスで用意されている「showDialog」メソッドを使います

カスタムアプルーブボタンとともにカスタムファイルチューザを表示します。た
とえば、次のコードは、通常の [Save] または [Open] ボタンではなく [Run 
Application] ボタンの付いたファイルチューザを表示します。

 filechooser.showDialog(parentFrame, "Run Application");
 
また、次のコードでも同じことができます。 

    JFileChooser chooser = new JFileChooser(null);
    chooser.setApproveButtonText("Run Application");
    chooser.showDialog(parentFrame, null);

parent 引数は、ファイルを開くダイアログが依存するフレーム、およびダイア
ログを配置するときに Look & Feel がその位置を考慮する必要があるコンポー
ネントを設定します。親が JFrame などの Frame オブジェクトの場合、ダイア
ログはフレームに依存し Look & Feel は、たとえばフレームの上の中央という
ようにフレームを基準にダイアログを配置します。親がコンポーネントの場合
は、ダイアログはコンポーネントを含むフレームに依存し、たとえばコンポー
ネントの上の中央というようにコンポーネントを基準に配置されます。親が 
null の場合は、ダイアログは不可視状態のウィンドウに依存し、画面の中央の
ように Look & Feel 依存の位置に配置されます。 

パラメータ:
  parent - ダイアログの親のコンポーネント。 null も可
  approveButtonText - ApproveButton のテキスト 
戻り値:
  ポップダウン時に返されるファイルチューザの状態。 
    JFileChooser.CANCEL_OPTION 
    JFileChooser.APPROVE_OPTION 
  エラーが発生した場合、またはダイアログが取り消された場合は、
    JFileCHooser.ERROR_OPTION 
例外: 
  HeadlessException - GraphicsEnvironment.isHeadless() が true を返す場合

1番目の引数にダイアログを表示するための親フレームを指定します。例えばJFrameクラスのオブジェクトを指定して下さい。

2番目の引数にダイアログのボタンに表示される文字列をString型の値で指定します。ここで指定する文字列は2つ表示されるボタンの中で「JFileChooser.APPROVE_OPTION」を返す為のボタンに表示される文字列です。

戻り値としてダイアログでクリックされたボタンの種類を取得できます。取得できる値は次の通りです。

定義値実際の値ボタンの種類
JFileChooser.APPROVE_OPTION0引数で指定した文字列が表示されたボタンが選択された場合
JFileChooser.CANCEL_OPTION1「取消し」ボタンが選択された場合
JFileCHooser.ERROR_OPTION-1エラー発生時

なお、ダイアログの右上に表示される「×」ボタンがクリックされてダイアログが閉じた場合は戻り値として「JFileChooser.CANCEL_OPTION」が返されます。

実際の使い方は次のようになります。

JFileChooser filechooser = new JFileChooser();

int selected = filechooser.showDialog(this, "実行する");

サンプルプログラム

では簡単なサンプルを作成して試してみます。

JFileChooserTest4.java

import javax.swing.*;
import java.io.File;
import java.awt.BorderLayout;
import java.awt.event.*;

public class JFileChooserTest4 extends JFrame implements ActionListener{

  JLabel label;

  public static void main(String[] args){
    JFileChooserTest4 frame = new JFileChooserTest4();

    frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
    frame.setBounds(10, 10, 300, 200);
    frame.setTitle("タイトル");
    frame.setVisible(true);
  }

  JFileChooserTest4(){
    JButton button = new JButton("file select");
    button.addActionListener(this);

    JPanel buttonPanel = new JPanel();
    buttonPanel.add(button);

    label = new JLabel();

    JPanel labelPanel = new JPanel();
    labelPanel.add(label);

    getContentPane().add(labelPanel, BorderLayout.CENTER);
    getContentPane().add(buttonPanel, BorderLayout.PAGE_END);
  }

  public void actionPerformed(ActionEvent e){
    JFileChooser filechooser = new JFileChooser();

    int selected = filechooser.showDialog(this, "実行する");
    if (selected == JFileChooser.APPROVE_OPTION){
      File file = filechooser.getSelectedFile();
      label.setText(file.getName());
    }else if (selected == JFileChooser.CANCEL_OPTION){
      label.setText("キャンセルされました");
    }else if (selected == JFileChooser.ERROR_OPTION){
      label.setText("エラー又は取消しがありました");
    }
  }
}

上記をコンパイルした後で実行すると次のように表示されます。

JFileChooserでカスタムダイアログを表示する

ボタンをクリックすると引数で指定した文字列が表示されたダイアログが表示されます。なおダイアログのタイトルにも同じ文字列が表示されます。

JFileChooserでカスタムダイアログを表示する

ファイルを選択して「実行する」ボタンをクリックすると、元のフレーム上に配置されたラベルにファイル名が表示されます。

JFileChooserでカスタムダイアログを表示する

JFileChooserでカスタムダイアログを表示する

( Written by Tatsuo Ikura )

Profile
profile_img

著者 / TATSUO IKURA

プログラミングや開発環境構築の解説サイトを運営しています。