CEGUI学习笔记三-- 如何显示中文
CEGUI使用utf8编码格式。这就意味着我们可以很简单的就显示中文。
1、弄个包含中文的字体,在这里我借用大多数例子里的 “C:/windows/Font/simhei.ttf”文件。把这个文件拷贝到Datafiles文件夹的Font文件夹里。
2、随便照着一个 .Font文件,自己写一个simhei.font文件。可以用TXT写,然后保存,有的朋友说需要保存为utf8编码格式,实际上是不需要的。
3、同时注意修改你加载到程序里的scheme文件,将里面的字体文件设置成simhei.ttf。你也可以继续使用FirstWindow这个例子,这样的话直接修改源代码里的字体为simhei.tff。
4、现在在程序里进行字符编码转换,我拿代码说明问题:
std::wstring aa
=
L
"
123中文abcあいうえお
"
;
char buff[ 128 ] = "" ;
WideCharToMultiByte( CP_UTF8, 0 , aa.c_str(), aa.size(), buff, sizeof (buff), 0 , 0 );
button1 -> setText ( CEGUI::String ( CEGUI::utf8 * )buff );
char buff[ 128 ] = "" ;
WideCharToMultiByte( CP_UTF8, 0 , aa.c_str(), aa.size(), buff, sizeof (buff), 0 , 0 );
button1 -> setText ( CEGUI::String ( CEGUI::utf8 * )buff );
原理是这样的,对于utf8来说,英文字符和ansi编码 在内存布局上没什么区别,都是一个UCHAR。但是对于非英文字符,则是UCHAR+UCHAR+UCHAR。如果我们手工进行编码格式转换,会比较烦琐。
比较偷懒的方法就是,我们先用WCHAR(unicode内存布局,UCHAR+UCHAR+UCHAR+UCHAR)来储存需要显示的字符串,然后调用Win32API来帮我们把宽字符转换成char(多字节字符集内存布局)。
这就是基本方法了,然后我们可以根据这个转换方针,利用Win32API随意的转换字符编码格式,从而满足程序中的各种需求。