MFC使用CFile读写Unicode字符集文件

我用MFC写了一个对话框。
在工程属性里使用Unicode字符集。然后加入一个编辑框空间。在文本编辑框内输入汉字。然后给空间关联了一个CString的变量,然后保存到TXT文件里是乱码。
但是如果在工程属性里使用多字节字符集的话。重复上述步骤,没有乱码出现。。。
求解。。。
为什么使用多字节字符集的话,对话框的按钮都变成Win98那种模式的了?而使用Unicode字符集则有立体感。。
这让我很难抉择啊。。。我是个画面党。。那种按钮确实太难看了。。。
有什么两全的办法吗??
望高人给出解答。。。
谢谢。。。
(注:使用两种字符集都能正常的打开一个TXT文件。。)
打开方式的代码是:

[html]  view plain copy
  1. CFileDialog fileDlg(TRUE);  
  2. fileDlg.m_ofn.lpstrTitle=TEXT("打开文件");  
  3. fileDlg.m_ofn.lpstrFilter=TEXT("文本文件(*.txt)\0*.txt\0\0");  
  4. if(IDOK==fileDlg.DoModal())  
  5. {  
  6. CFile file(fileDlg.GetPathName(),CFile::modeRead);  
  7. char* ch=new char[file.GetLength()+1];  
  8. ch[file.GetLength()]=0;  
  9. file.Read(ch,file.GetLength());  
  10. file.Close();  
  11. m_Text=ch;  
  12. }  
  13. UpdateData(FALSE);  



m_Text是控件关联的CString变量,直接使用会出错。。。因为找不出什么原因,我new了一个char数组。然后吧char数组的内容给了m_Text。。。。

 

写入文件的代码是:

[cpp]  view plain copy
  1. UpdateData();  
  2. CFileDialog fileDlg(FALSE);  
  3. fileDlg.m_ofn.lpstrTitle=TEXT("保存文件");  
  4. fileDlg.m_ofn.lpstrFilter=TEXT("文本文件(*.txt)\0*.txt\0\0");  
  5. fileDlg.m_ofn.lpstrDefExt=TEXT("txt");  
  6. if (IDOK==fileDlg.DoModal())  
  7. {  
  8. CFile file(fileDlg.GetPathName(),CFile::modeCreate | CFile::modeWrite);  
  9. file.Write(m_Text,m_Text.GetLength());  
  10. file.Close();  
  11. }  


写入Unicode文本时,要在文件头部加入Unicode文本标志0XFEFF。

[cpp]  view plain copy
  1. #include <stdio.h>  
  2.   
  3. #ifndef _UNICODE  
  4. #define _UNICODE            //使用UNICODE编码  
  5. #endif  
  6.   
  7. #include <Afx.h>           //为了使用CString类  
  8.   
  9. const int UNICODE_TXT_FLG = 0xFEFF;  //UNICODE文本标示  
  10.   
  11. int main()  
  12. {  
  13.     FILE* WriteF;  
  14.       
  15.   
  16.     CString Wstr = _T("一个测试写入文本");  
  17.     WriteF = fopen("d:\\test.txt","w+");  
  18.   
  19.     if(WriteF)  
  20.     {  
  21.         fwrite(&UNICODE_TXT_FLG,2,1,WriteF);  //写入头部  
  22.         fwrite(Wstr.GetBuffer(10),Wstr.GetLength() * 2,1,WriteF);  
  23.         fclose(WriteF);  
  24.     }         
  25.      
  26.     return 0;  
  27. }  


MFC代码如下:

[html]  view plain copy
  1. #include <stdio.h>  
  2.   
  3. #ifndef _UNICODE  
  4. #define _UNICODE  
  5. #endif  
  6.   
  7. #include <Afx.h>  
  8.   
  9.   
  10.   
  11. const int UNICODE_TXT_FLG = 0xFEFF;  
  12.   
  13. // int main()  
  14. // {  
  15. //     FILE* WriteF;  
  16. //      
  17. //  
  18. //     CString Wstr = _T("一个测试写入文本");  
  19. //     WriteF = fopen("d:\\test.txt","w+");  
  20. //  
  21. //     if(WriteF)  
  22. //     {  
  23. //         fwrite(&UNICODE_TXT_FLG,2,1,WriteF);  
  24. //         fwrite(Wstr.GetBuffer(10),Wstr.GetLength() * 2,1,WriteF);  
  25. //         fclose(WriteF);  
  26. //     }         
  27. //      
  28. //     return 0;  
  29. // }  
  30.   
  31. int main()  
  32. {  
  33.     CFile WriteF;  
  34.     CString Wstr = _T("一个测试写入文本");  
  35.   
  36.     WriteF.Open(_T("d:\\test.txt"),CFile::modeCreate | CFile::modeWrite);  
  37.     if(WriteF)  
  38.     {  
  39.         WriteF.Write(&UNICODE_TXT_FLG,2);  
  40.         WriteF.Write(Wstr.GetBuffer(10),Wstr.GetLength()*2);  
  41.         WriteF.Flush();  
  42.         WriteF.Close();         
  43.     }  
  44.     return 0;  
  45.   
  46. }  


读的代码如下:

[html]  view plain copy
  1. m_Text.Empty();  
  2. CFile ReadF(fileDlg.GetPathName(),CFile::modeRead);  
  3. TCHAR* temp=new TCHAR[ReadF.GetLength()/2+1];  
  4. ReadF.Read(temp,ReadF.GetLength());  
  5. temp[ReadF.GetLength()/2]=0;  
  6. ReadF.Close();  
  7. m_Text=temp;  
  8. delete temp;  



这样的话能正常的写入和打开Unicode字符集的TXT文件了。。
可是那些非Unicode的文件就变成乱码了。。。
是不是应该加个判断语句???应该怎么加??



你可能感兴趣的:(unicode,mfc)