[Tips][OpenFileDialog] まとめ

これまでに紹介した「OpenFileDialogコントロール」Tipsは下記の通りです。

  1. ダイアログの表示と選択されたファイルの取得
  2. ダイアログに表示される起動ディレクトリを取得/設定する
  3. [ファイルの種類] ボックスに表示される選択肢を設定する
  4. ダイアログタイトルを設定する
  5. 複数のファイルを選択できるようにする
  6. [読み取り専用]チェックボックスを表示する

[Tips][OpenFileDialog] [読み取り専用]チェックボックスを表示する

OpenFileDialogは、ShowReadOnlyプロパティにTrueを設定すると[読み取り専用]チェックボックスを表示させることができます(既定ではShowReadOnlyプロパティはFalseです)。

表示されたダイアログで、ユーザーが[読み取り専用]チェックボックスにチェックを付けたかどうかを調べるにはReadOnlyCheckedプロパティを参照します。

ReadOnlyCheckedプロパティがTrueであれば[読み取り専用]チェックボックスにチェックが付けられたことになります。

下記はOpenFileDialogに[読み取り専用]チェックボックスを表示する例です。

サンプルの画面は下記のようにデザインしました。

[読み取り専用]チェックボックスにチェックを付けて[ファイルの選択]ボタンを押すと、[読み取り専用]チェックボックスがあるダイアログが表示されます。

VBの例

' [ファイルの選択]ボタンクリック時の処理
Private Sub btnOpenDialog_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles btnOpenDialog.Click
    '★★★[読み取り専用]チェックボックス設定★★★
    OpenFileDialog1.ShowReadOnly = chkReadonly.Checked

    'フィルターの設定
    OpenFileDialog1.Filter = "画像ファイル|*.bmp;*.gif;*.png"

    'ダイアログボックスの表示
    If OpenFileDialog1.ShowDialog() = Windows.Forms.DialogResult.OK Then
        '選択されたファイルをテキストボックスに表示する
        txtSelectedFile.Text = OpenFileDialog1.FileName

        '★★★[読み取り専用]にチェックが付けられたか確認★★★
        If OpenFileDialog1.ReadOnlyChecked Then
            MessageBox.Show("[読み取り専用]がチェックされました")
        End If
    End If
End Sub

C#の例

// [ファイルの選択]ボタンクリック時の処理
Private void btnOpenDialog_Click(object sender, EventArgs e)
{
    // ★★★[読み取り専用]チェックボックス設定★★★
    openFileDialog1.ShowReadOnly = chkReadonly.Checked;

    // フィルターの設定
    openFileDialog1.Filter = "画像ファイル|*.bmp;*.gif;*.png";

    // ダイアログボックスの表示
    if (openFileDialog1.ShowDialog() == System.Windows.Forms.DialogResult.OK)
    {
        // 選択されたファイルをテキストボックスに表示する
        txtSelectedFile.Text = openFileDialog1.FileName;

        // ★★★[読み取り専用]にチェックが付けられたか確認★★★
        if ( openFileDialog1.ReadOnlyChecked )
        {
            MessageBox.Show("[読み取り専用]がチェックされました");
        }
    }
}

実行例

[Tips][OpenFileDialog] 複数のファイルを選択できる

既定ではOpenFileDialogは1つのファイルしか選択することができません。

一度に複数のファイルを選択できるようにするにはMultiselectプロパティにTrueを設定します(既定ではFalse)。

ダイアログで選択されたファイルはFileNamesプロパティで参照することができます。

FileNamesプロパティはString型の配列なので、サンプルに示すようにFor Each(C#ではforeach)などで取り出して使用します。

下記は複数のファイルを選択できるようにする例です。

フォーム内にある[複数ファイル選択可]チェックボックスにチェックを付けると、複数ファイルを選択できるダイアログが開きます。

サンプルの画面は下記のようにデザインしました。

VBの例

' [ファイルの選択]ボタンクリック時の処理
Private Sub btnOpenDialog_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles btnOpenDialog.Click
    '★★★複数のファイルを選択できるようにするかどうかの設定★★★
    OpenFileDialog1.Multiselect = chkMultiSelect.Checked

    'フィルターの設定
    OpenFileDialog1.Filter = "画像ファイル|*.bmp;*.gif;*.png"

    'ダイアログボックスの表示
    If OpenFileDialog1.ShowDialog() = Windows.Forms.DialogResult.OK Then
        'リストボックスの初期化
        lstFiles.Items.Clear()

        '選択されたファイルをテキストボックスに表示する
        For Each strFilePath As String In OpenFileDialog1.FileNames
            'ファイルパスからファイル名を取得
            Dim strFileName As String = IO.Path.GetFileName(strFilePath)

            'リストボックスにファイル名を表示
            lstFiles.Items.Add(strFileName)
        Next
    End If
End Sub

C#の例

// [ファイルの選択]ボタンクリック時の処理
private void btnOpenDialog_Click(object sender, EventArgs e)
{
    // ★★★複数のファイルを選択できるようにするかどうかの設定★★★
    openFileDialog1.Multiselect = chkMultiSelect.Checked;

    // フィルターの設定
    openFileDialog1.Filter = "画像ファイル|*.bmp;*.gif;*.png";

    // ダイアログボックスの表示
    if (openFileDialog1.ShowDialog() == System.Windows.Forms.DialogResult.OK)
    {
        // リストボックスの初期化
        lstFiles.Items.Clear();

        // 選択されたファイルをテキストボックスに表示する
        foreach (string strFilePath in openFileDialog1.FileNames)
        {
            // ファイルパスからファイル名を取得
            string strFileName = System.IO.Path.GetFileName(strFilePath);

            // リストボックスにファイル名を表示
            lstFiles.Items.Add(strFileName);
        }
    }
}

実行例