还真是百思不得其解,无奈只能去看 cximage 库的 DrawStringEx 函数源码,还真发现了点问题。
该函数中源码中有这么一段:
复制代码
调用 _tcsclen 函数计算字符串的长度,英文情况下没问题,如果为中文字符串,且定义了 _MBCS宏 的多字节的情况下,tcsclen 会被定义成 _mbslen,也就是计算字符的个数,所以,就会认为“中华人民”四个汉字为4个字符,所以就被截取了一半,这块我把你的这个代码拿到 cximage 的demo中测试,貌似还没有问题,所以这块不一定是Bug,也有可能是作者故意这样写的,修改方法也不难,直接把 len=(long)_tcsclen(pTextType->text) 改成: len=(long)_tcslen(pTextType->text) 就能得到正常的 8 个字符的长度了,之后重新编译 cximage,生成库之后供你的程序调用就可以了。
该函数中源码中有这么一段:
- // get text length and number of lines
- long i=0, numlines=1, len=(long)_tcsclen(pTextType->text);
调用 _tcsclen 函数计算字符串的长度,英文情况下没问题,如果为中文字符串,且定义了 _MBCS宏 的多字节的情况下,tcsclen 会被定义成 _mbslen,也就是计算字符的个数,所以,就会认为“中华人民”四个汉字为4个字符,所以就被截取了一半,这块我把你的这个代码拿到 cximage 的demo中测试,貌似还没有问题,所以这块不一定是Bug,也有可能是作者故意这样写的,修改方法也不难,直接把 len=(long)_tcsclen(pTextType->text) 改成: len=(long)_tcslen(pTextType->text) 就能得到正常的 8 个字符的长度了,之后重新编译 cximage,生成库之后供你的程序调用就可以了。
初步先分析到这里吧,究其真正的原因还有待深入研究。
原文地址
http://www.cctry.com/thread-255744-1-1.html