解决:wxString s = wxT("中文");
参考:http://blog.youkuaiyun.com/eyefamily/article/details/7516793
1. windows下
wxWidgets 2.9.1 , VC2005编译, Unicode
和
wxWidgets 2.9.1 , mingw32编译, Unicode
事实证明用这两个编译器产生的代码对中文乱码没有影响,因此合并讨论。
程序1:
文件使用ANSI编码
const char* a = "你好";
wxMessageBox(wsString(a), wxT("完整"));
结果:弹出窗体显示正常。
解释:此时由于文件是ANSI编码,所以使用是windows的代码页,wxString自动进行转码,a的长度是5.每个汉字2个字节。
程序2:
文件使用UTF-8编码:
const char* a = "你好";
wxString b = wxString::FromUTF8(a);
wxMessageBox(b, wxString::FromUTF8("万qua "));
结果:弹出窗体显示正常。
解释:此时由于文件是UTF-8编码,a的长度是7.每个汉字3个字节。
程序3:
文件使用UTF-8编码:
const char* a = "你好";
wxMessageBox(wxString(a), wxString("万qua "));
结果:弹出窗体显示乱码。
解释:此时由于文件是UTF-8编码,wxString由windows默认码页自动转码,引起混乱。并且,更为严重的是,所有菜单里定义的中文都变成乱码,只有通过wxString::FromUTF8("中文")才能使中文正常显示。
总结:windows下只能对文件使用ANSI编码,此时才能最大限度的保证wxString可以正常使用,否则程序中的所有字符都需要经过FromUTF8处理,基本上不太可能这样编程。