Cocos 2 d-xプロジェクトはWP 8シリーズの7:中国語表示文字化け
8465 ワード
原文リンク:http://www.cnblogs.com/zouzf/p/3984628.html
C++とC#の相互調整では、最も一般的な文字列のようなパラメータを持つことがよくありますが、文字列に中国語があると、伝達後に文字化けしてしまうことがわかります.これは、両側の符号化方式が異なるためです.C#のデフォルトではUnicodeEncoding(中国語環境ではGBK?)で符号化され、C+(Luaとcocococococos 2 d-xエンジンのデフォルト符号化はUTF-8)ではutf 8で符号化されています.大体の流れは C++の中のstd::string文字列をC+/CXに変換 の中 Platform::string,C#にSystem.String ,C#からC++までは逆です.
Cocosは実はすでに関連コードを持っていて、CCWinRTUtils.hにあります. CCWinRTUtils.cppと
std::string ターン platform^ string
platform^ ストリングス 回転std::string
原文リンク:http://www.cnblogs.com/zouzf/p/3984628.html
C++とC#の相互調整では、最も一般的な文字列のようなパラメータを持つことがよくありますが、文字列に中国語があると、伝達後に文字化けしてしまうことがわかります.これは、両側の符号化方式が異なるためです.C#のデフォルトではUnicodeEncoding(中国語環境ではGBK?)で符号化され、C+(Luaとcocococococos 2 d-xエンジンのデフォルト符号化はUTF-8)ではutf 8で符号化されています.大体の流れは C++の中のstd::string文字列をC+/CXに変換 の中 Platform::string,C#にSystem.String ,C#からC++までは逆です.
Cocosは実はすでに関連コードを持っていて、CCWinRTUtils.hにあります. CCWinRTUtils.cppと
std::string ターン platform^ string
1 std::wstring CCUtf8ToUnicode(const char * pszUtf8Str, unsigned len/* = -1*/)
2 {
3 std::wstring ret;
4 do
5 {
6 if (! pszUtf8Str) break;
7 // get UTF8 string length
8 if (-1 == len)
9 {
10 len = strlen(pszUtf8Str);
11 }
12 if (len <= 0) break;
13
14 // get UTF16 string length
15 int wLen = MultiByteToWideChar(CP_UTF8, 0, pszUtf8Str, len, 0, 0);
16 if (0 == wLen || 0xFFFD == wLen) break;
17
18 // convert string
19 wchar_t * pwszStr = new wchar_t[wLen + 1];
20 if (! pwszStr) break;
21 pwszStr[wLen] = 0;
22 MultiByteToWideChar(CP_UTF8, 0, pszUtf8Str, len, pwszStr, wLen + 1);
23 ret = pwszStr;
24 CC_SAFE_DELETE_ARRAY(pwszStr);
25 } while (0);
26 return ret;
27 }
1 std::string str = " ";
2 Platform::String ^pStr_str = ref new Platform::String(CCUtf8ToUnicode(str.c_str()).c_str());
platform^ ストリングス 回転std::string
1 std::string CCUnicodeToUtf8(const wchar_t* pwszStr)
2 {
3 std::string ret;
4 do
5 {
6 if(! pwszStr) break;
7 size_t len = wcslen(pwszStr);
8 if (len <= 0) break;
9
10 size_t convertedChars = 0;
11 char * pszUtf8Str = new char[len*3 + 1];
12 WideCharToMultiByte(CP_UTF8, 0, pwszStr, len+1, pszUtf8Str, len*3 + 1, 0, 0);
13 ret = pszUtf8Str;
14 CC_SAFE_DELETE_ARRAY(pszUtf8Str);
15 }while(0);
16
17 return ret;
18 }
1 Platform::String^ str = " ";
2 string str1 = CCUnicodeToUtf8(str);
原文リンク:http://www.cnblogs.com/zouzf/p/3984628.html