Click here to Skip to main content
65,938 articles
CodeProject is changing. Read more.
Articles
(untagged)

Adding filters to the Open File dialog

0.00/5 (No votes)
24 Nov 1999 2  
Adding filters to the Open File dialog.

Sample Image

Introduction

The MFC CFileDialog class only has provision for one default file extension, which is added to a filename if no extension is given. A file export functionality deals with possibly many different file extensions, that have to be added depending on the filetype chosen. The CFileExportDialog class does this. Moreover, when the user selects another filetype from the combobox, the extension in the filename editcontrol is automatically changed.

The usage of the dialog is simple because it mimics the usage of the parent class CFileDialog. Apart from the constructor and destructor, there is only one extra public function, GetFilterIndex(), which returns the index of the selected filetype. This is useful if one extension is shared by two or more filetypes, so the filetype cannot be determined from the resulting filename. In keeping with standard Windows practice, this index starts at 1.

One thing to note is the format of the filter string. This string MUST be of the form "Word File (*.doc)|Text File (*.txt)". I.e. one extension per format, and the formats separated by pipes. Every extension must be put between parentheses and be of the form *.ext.

The initial file type is determined from the default filename, if it is given. This filename may also be "*.ext". If no default filename is given, the first filetype in the filter string is used.

The CFileExportDialog class is typically used like this:

CFileExportDialog dialog("Save As Type", // title

  "Windows Bitmap (*.bmp)|JPEG Compressed Image (*.jpg)|"\  // filter string..

  "Windows Meta File (*.wmf)|Windows Enhanced Meta File (*.emf)", // with file types

  "visualization.jpg"); // default filename (may be omitted)


if (dialog.DoModal() == IDOK) {
  CString filename = dialog.GetPathName();
  int filetype = dialog.GetFilterIndex();
  SaveFile(filename, filetype); // defined somewhere in the application

}

License

This article has no explicit license attached to it but may contain usage terms in the article text or the download files themselves. If in doubt please contact the author via the discussion board below.

A list of licenses authors might use can be found here