MFC中CFileDialog打开和保存文件对话框


    打开/保存文件对话框的程序:
    
    CString   FilePathName;//文件名参数定义
    CFileDialog  Dlg(TRUE,NULL,NULL,OFN_HIDEREADONLY | OFN_OVERWRITEPROMPT,"TXT Files(*.txt)|*.txt|All Files(*.*)|*.*");
     //打开文件
    if(Dlg.DoModal() == IDOK)//是否打开成功
    {
        FilePathName =  Dlg.GetPathName();//取得文件路径及文件名
        SetDlgItemText(IDC_OutPutFile,FilePathName);//在一个地址为IDC_OutPutFile的editbox中显示文件名
    }
    else//打开失败处理
    {
        //打开失败处理
        MessageBox("打开失败",NULL,MB_OK);
    }
    以上的程序就是处理一个"打开/保存文件对话框"的程序,下面我将分析这段程序,详细的说明各个参数的作用!

     构造一个对象并提供相应的参数,构造函数原型如下: 
     CFileDialog Dlg( BOOL bOpenFileDialog, LPCTSTR lpszDefExt = NULL, LPCTSTR lpszFileName = NULL, DWORD dwFlags = OFN_HIDEREADONLY | OFN_OVERWRITEPROMPT, LPCTSTR lpszFilter = NULL, CWnd* pParentWnd = NULL );
    各个参数的意义说明如下:
    bOpenFileDialog 为TRUE则显示 打开文件对话框,为FALSE则显示 保存文件对话框。 
    lpszDefExt 指定默认的文件扩展名。 
    lpszFileName 指定默认的文件名。 
    dwFlags 指明一些特定风格。 
     lpszFilter 是最重要的一个参数,它指明可供选择的文件类型和相应的扩展名。
    参数格式如: 
    "Chart Files (*.xlc)|*.xlc|Worksheet Files (*.xls)|*.xls|Data Files (*.xlc;*.xls)|*.xlc; *.xls|All Files (*.*)|*.*||"
    说明:文件的类型说明和扩展名间用'|'分隔,同种类型的文件扩展名间用';'分隔,每种文件类型间用'|'分隔,末尾用'||'指明。
    
    pParentWnd 为父窗口指针。 
    创建文件对话框可以使用DoModal(),在返回后可以利用下面的函数得到用户选择: 
    CString CFileDialog::GetPathName( ) 得到完整的文件名,包括目录名和扩展名如:c: est est1.txt 
    CString CFileDialog::GetFileName( ) 得到完整的文件名,包括扩展名如:test1.txt 
    CString CFileDialog::GetExtName( ) 得到完整的文件扩展名,如:txt 
    CString CFileDialog::GetFileTitle ( ) 得到完整的文件名,不包括目录名和扩展名如:test1 
    POSITION CFileDialog::GetStartPosition( ) 对于选择了多个文件的情况得到第一个文件位置。 
    CString CFileDialog::GetNextPathName( POSITION& pos ) 对于选择了多个文件的情况得到下一个文件位置,并同时返回当前文件名。但必须已经调用过POSITION CFileDialog::GetStartPosition( )来得到最初的POSITION变量。

你可能感兴趣的:(MFC)