文章转自:http://blog.youkuaiyun.com/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;
}

本文介绍如何在多字节字符集的项目中使用CEF3,并提供了一个用于字符转码的函数,使得能够顺利地处理中文字符。
2227

被折叠的 条评论
为什么被折叠?



