CEF3自研究笔记 四、CEF3关于多字节字符集和UNICODE字符集

      网上很多资料都要求我们把嵌入CEF3的工程属性改为支持UNICODE字符集。当然如果条件允许无疑是比较好的,因为CEF3的DLL应该就是Unicode字符集的。但是如果我们已经完成的工程是建立在多字节字符集上的,要把它改为UNICODE字符集无疑非常麻烦。

      如果我们的工程是支持多字节字符集,同样可以直接嵌入CEF3,不过在向CEF3传入中文字符的时候要先将字符转码,下面提供一个转码函数。

static char* MBSCToCEF(const char* mbcsStr)
{
 wchar_t*  wideStr;
 char*   utf8Str;
 int   charLen;

 charLen = MultiByteToWideChar(CP_UTF8, 0, mbcsStr, -1, NULL, 0);
 charLen=strlen(mbcsStr)+1;
 wideStr = (wchar_t*) malloc(sizeof(wchar_t)*charLen);
 MultiByteToWideChar(CP_ACP, 0, mbcsStr, -1, wideStr, charLen);

 charLen = WideCharToMultiByte(CP_UTF8, 0, wideStr, -1, NULL, 0, NULL, NULL);

 utf8Str = (char*) malloc(charLen);

 WideCharToMultiByte(CP_UTF8, 0, wideStr, -1, utf8Str, charLen, NULL, NULL);

 free(wideStr);
 return utf8Str;

} 




你可能感兴趣的:(CEF3学习研究)