• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            作者:Northtibet

            下載源代碼

              最近有位讀者來信指出:《在線雜志》第26期中有一篇文章:“再談 CFileDialog 對話框的定制”,其例子程序有一個bug。如果多選時選中的文件過多,那么后面選中的文件將無效,也就是說即使也白選,點擊“確定”后沒有任何操作 。本文將提供解決此問題的辦法,并說明問題的來由。
              一般我們都是象下面這樣來設置具備多選能力的 CFileDialog:

                 // 首先創建一個 CFIleDialog 類實例,并設置多選標志
            1     CFileDialog mFileDlg(TRUE, NULL,NULL, 
            2                          OFN_ALLOWMULTISELECT,
            3                          	_T("Text Files (*.txt)|*.txt|All Files (*.*)|*.*||"), 
            4                          AfxGetMainWnd()); 
            5     CString pathName; 
            6     If(mFileDlg.DoModal ()==IDOK)
            7     { 
            8         POSITION mPos=mFileDlg.GetStartPosition(); 
            9         while(mPos!=NULL) 
            10         { 
            11              pathName=mFileDlg.GetNextPathName(mPos); 
            12              TRACE("%s\n",pathName);
            13	} 
            14     }
            15     else
            16         TRACE(“IDCANCLE\n”);
              在大多數情況下,這段代碼都能正常運行,但如果你選中的文件過多,那么后面選中的文件將不會被影響,選中無反應,點擊“確定”也無操作。這是為什么呢?在上述代碼段的第五行添加如下語句:
            	TRACE("nMaxFile :%d\n",mFileDlg.m_ofn.nMaxFile);
              編譯并運行上述代碼(具體細節參見本文例子程序),并用 TraceWin 跟蹤 TRACE 輸出,你會發現 nMaxFile 的輸出是 260。如圖所示:



              問題就出在這里,nMaxFile 是 OPENFILENAME 結構的成員之一,MSDN 對之是這樣解釋的:
            nMaxFile:說明 lpstrFile 緩沖指針的大小,以 TCHARs 為單位。對于 ANSI 版本,它指的是字節數。對于 Unicode 版本,它指的是字符數,該緩沖必須足夠大才能存儲文件的路徑字符串,包括結尾空字符。如果 該緩存太小以至于無法包含文件信息,那么 GetOpenFileName 和 GetSaveFileName 函數將返回 FALSE。該緩沖至少要求容納 256 個字符。
              現在明白了吧,多選時,由于文件路徑和名稱的長度超過了限制,造成程序出現上述問題。解決辦法是重新設置 nMaxFile 大小。
            	#define  NAMEBUF   1024
            	...
                     mFileDlg.m_ofn.lpstrFile=new TCHAR[NAMEBUF];   // 重新定義 lpstrFile 緩沖大小
                     memset(mFileDlg.m_ofn.lpstrFile,0,NAMEBUF);  // 初始化定義的緩沖 
            		 mFileDlg.m_ofn.nMaxFile = NAMEBUF;           // 重定義 nMaxFile 
            	...
                     delete [] mFileDlg.m_ofn.lpstrFile;             // 切記使用完后釋放資源		
            詳細代碼請參考本文例子代碼。

            Posted on 2006-09-05 23:58 艾凡赫 閱讀(603) 評論(0)  編輯 收藏 引用 所屬分類: MFC技術
            久久精品夜色噜噜亚洲A∨| 精品久久久久久久久免费影院| 三级三级久久三级久久| 欧美亚洲国产精品久久高清| 亚洲精品国产字幕久久不卡| 精品久久777| 国产精品久久久久久久久久影院| 麻豆一区二区99久久久久| 国产综合免费精品久久久| 中文字幕人妻色偷偷久久| 99久久国产综合精品五月天喷水 | 99久久无码一区人妻| 国产精品久久久久久久app| 国产99久久久久久免费看| 亚洲精品无码专区久久久| 久久伊人色| 国产精品一区二区久久精品无码 | 亚洲欧美伊人久久综合一区二区| 一本伊大人香蕉久久网手机| 伊人久久久AV老熟妇色| 亚洲国产成人精品91久久久 | 99久久这里只精品国产免费 | 亚洲色欲久久久综合网| 婷婷久久综合九色综合九七| 国产精品热久久毛片| 久久久久夜夜夜精品国产| 国产∨亚洲V天堂无码久久久| 久久妇女高潮几次MBA| 久久久久人妻一区二区三区| 日韩十八禁一区二区久久| 久久99精品国产99久久6| 99久久婷婷国产综合精品草原 | 精品久久久久久亚洲| 日本道色综合久久影院| 青青青青久久精品国产h| 久久777国产线看观看精品| 日本精品久久久久中文字幕| www亚洲欲色成人久久精品| 91性高湖久久久久| 久久精品二区| 久久久国产99久久国产一|