文章转自:http://blog.csdn.net/cyloser/article/details/49786401 (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;
}