CFileExportDialog Class

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 filetype 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
}


Created with MSVC 6, tested under Win95 OSR2.

Download demo project - 20 KB

Download source - 5 KB

Date Last Updated: April 3, 1999



Comments

  • Why different format for filter string?

    Posted by Legacy on 11/17/2003 12:00am

    Originally posted by: _plug

    Why did you make your class use a different format for the filter string than the CFileDialog class? Why not use the same format ("|File Type (*.ext)|*.ext|") and therefore make it compatible with the rest of the worlds code. Also, why not support multiple file extensions per format? When the user selects a format, the first extension would be used.

    Reply
  • How to empty the file name input box initialized filedialog?

    Posted by Legacy on 03/14/2002 12:00am

    Originally posted by: Gempin

    I don't wanna the file name input box has a file name string of the filedialog initialized, that mean there is empty, how to do that? please...
    

    Reply
  • Code Page Error

    Posted by Legacy on 07/27/1999 12:00am

    Originally posted by: Cris Padilla Tagle

    I'm sorry but I could not open your demo program. I am receiving a code page error. It seems to me that the resource needs a Code Page 1252 instead.

    I am thinking if you could send me a copy for English code page.

    Thanks.

    Reply
Leave a Comment
  • Your email address will not be published. All fields are required.

Top White Papers and Webcasts

  • The impact of a data loss event can be significant. Real-time data is essential to remaining competitive. Many companies can no longer afford to rely on a truck arriving each day to take backup tapes offsite. For most companies, a cloud backup and recovery solution will eliminate, or significantly reduce, IT resources related to the mundane task of backup and allow your resources to be redeployed to more strategic projects. The cloud - can now be comfortable for you – with 100% recovery from anywhere all …

  • You probably have several goals for your patient portal of choice. Is "community" one of them? With a bevy of vendors offering portal solutions, it can be challenging for a hospital to know where to start. Fortunately, YourCareCommunity helps ease the decision-making process. Read this white paper to learn more. "3 Ways Clinicians can Leverage a Patient Portal to Craft a Healthcare Community" is a published document owned by www.medhost.com

Most Popular Programming Stories

More for Developers

Latest Developer Headlines

RSS Feeds