该死的Unicode
<p>请教如何将一 ads_real类型实数转化为ACHAR*类型,以便在图形中输出。</p><p>例如,我要在图形中插入“壁厚Xmm”说明语句。其中X为ads_real型实数的值。请教高手如何实现。</p><p>说明:俺的程序没有基于MFC,CString类不能用。</p> <p>acutprintf(_T("壁厚%lfmm"),X);</p><p></p><p></p><p>是不是?</p> <p> 多谢,如果要acedAlert()函数,或者用acdbText的setTextString函数呢</p> <p class="signature">extern "C" int</p><p class="signature">acedAlert(</p><p class="signatureInEnd">const ACHAR * str);</p><table class="argumentList"><tbody><tr valign="baseline"><td class="argumentName">str</td><td class="argumentDescription">Message to display (maximum of 132 characters with the 133rd slot reserved as the end-of-string character)</td></tr></tbody></table><p class="signature">__________________________________________________________</p><p class="signature">Acad::ErrorStatus</p><p class="signature">setTextString(</p><p class="signatureInEnd">const ACHAR* unnamed);</p><table class="argumentList"><tbody><tr valign="baseline"><td class="argumentName">unnamed</td><td class="argumentDescription">Input null-terminated text string (256 byte max)</td></tr></tbody></table><p>__________________________________________________________</p><p>两个应该和上面那个一样。只要加个_T("")就行了吧。</p><p></p><p>我也是菜鸟,自己想的,呵呵。</p> <div class="tit">“MultiByteToWideChar和WideCharToMultiByte用法详解”</div><div class="date">2006-12-27 14:50</div><table style="TABLE-LAYOUT: fixed;"><tbody><tr><td><div class="cnt"><div class="postTitle"><a href="http://blog.csdn.net/norains/archive/2006/12/25/1461174.aspx"><font color="#800080"> MultiByteToWideChar和WideCharToMultiByte用法详解</font></a> </div><div class="postTitle"></div><div class="postText">//========================================================================<br/>//TITLE:<br/>// MultiByteToWideChar和WideCharToMultiByte用法详解<br/>//AUTHOR:<br/>// norains<br/>//DATE:<br/>// Thursday 25-December -2006<br/>//Environment:<br/>// EVC4.0 + Standard SDK<br/>//========================================================================<br/> 在本文开始之处,先简要地说一下何为短字符和宽字符.<br/> 所谓的短字符,就是用8bit来表示的字符,典型的应用是ASCII码.而宽字符,顾名思义,就是用16bit表示的字符,典型的有UNICODE.关于windows下的ASCII和UNICODE的更多信息,可以参考这两本经典著作:《windows 程序设计》,《windows 核心编程》.这两本书关于这两种字符都有比较详细的解说.<br/> <br/> 宽字符转换为多个短字符是一个难点,不过我们只要掌握到其中的要领,便可如鱼得水.<br/> 好吧,那就让我们开始吧.<br/> <br/> 这个是我们需要转化的宽字符串: <br/> wchar_t wText = {L"宽字符转换实例!OK!"};<br/> <br/> 我们需要知道转化后的短字符需要多少个数组空间.虽然在这个里程里面,我们可以直接定义一个20*2短字符的数组,并且事实上将运行得非常轻松愉快.但假如宽字符串更多,达到上千个乃至上万个,我们将会发现其中浪费的内存将会越来越多.所以以宽字符的个数的两倍作为短字符数组下标的声明绝对不是一个好主意.<br/> 所幸,我们能够确知所需要的数组空间.<br/> 我们只需要将MultiByteToWideChar()的第四个形参设为-1,即可返回所需的短字符数组空间的个数:<br/> DWORD dwNum = MultiByteToWideChar (CP_ACP, 0, wText, -1, NULL, 0);<br/> <br/> 接下来,我们只需要分配响应的数组空间:<br/> char *psText;<br/> psText = new char;<br/> if(!psText)<br/> {<br/> delete []psText;<br/> }<br/> <br/> 接着,我们就可以着手进行转换了.在这里以转换成ASCII码做为例子:<br/> MultiByteToWideChar (CP_ACP, 0, psText, -1, wText, dwSize);<br/> <br/> 最后,使用完毕当然要记得释放占用的内存:<br/> delete []psText;<br/> <br/> <br/> 同理,多个短字符转为宽字符的代码如下: <br/> char sText = {L"宽字符转换实例!OK!"};<br/> DWORD dwNum = WideCharToMultiByte (CP_ACP, 0, sText, -1, NULL, 0);<br/> wchar_t *pwText;<br/> pwText = new wchar_t;<br/> if(!psText)<br/> {<br/> delete []psText;<br/> }<br/> WideCharToMultiByte (CP_ACP, 0, pwText, -1, sText, dwSize);<br/> delete []pwText;<br/> <br/> 如果之前我们已经分配好空间,并且由于字符串较短,可以不理会浪费的空间,仅仅只是想简单地将短字符和宽字符相互转换,那有没有什么简便的方法呢?<br/> WIN32 API里没有符合这种要求的函数,但我们可以自己进行封装:<br/> <br/> //-------------------------------------------------------------------------------------<br/> //Description:<br/> // This function maps a character string to a wide-character (Unicode) string<br/> //<br/> //Parameters:<br/> // lpcszStr: Pointer to the character string to be converted <br/> // lpwszStr: Pointer to a buffer that receives the translated string. <br/> // dwSize: Size of the buffer<br/> //<br/> //Return Values:<br/> // TRUE: Succeed<br/> // FALSE: Failed<br/> // <br/> //Example:<br/> // MByteToWChar(szA,szW,sizeof(szW)/sizeof(szW));<br/> //---------------------------------------------------------------------------------------<br/> BOOL MByteToWChar(LPCSTR lpcszStr, LPWSTR lpwszStr, DWORD dwSize)<br/> {<br/> // Get the required size of the buffer that receives the Unicode <br/> // string. <br/> DWORD dwMinSize;<br/> dwMinSize = MultiByteToWideChar (CP_ACP, 0, lpcszStr, -1, NULL, 0);<br/> <br/> if(dwSize < dwMinSize)<br/> {<br/> return FALSE;<br/> }<br/> <br/> <br/> // Convert headers from ASCII to Unicode.<br/> MultiByteToWideChar (CP_ACP, 0, lpcszStr, -1, lpwszStr, dwMinSize); <br/> return TRUE;<br/> }<br/> <br/> //-------------------------------------------------------------------------------------<br/> //Description:<br/> // This function maps a wide-character string to a new character string<br/> //<br/> //Parameters:<br/> // lpcwszStr: Pointer to the character string to be converted <br/> // lpszStr: Pointer to a buffer that receives the translated string. <br/> // dwSize: Size of the buffer<br/> //<br/> //Return Values:<br/> // TRUE: Succeed<br/> // FALSE: Failed<br/> // <br/> //Example:<br/> // MByteToWChar(szW,szA,sizeof(szA)/sizeof(szA));<br/> //---------------------------------------------------------------------------------------<br/> BOOL WCharToMByte(LPCWSTR lpcwszStr, LPSTR lpszStr, DWORD dwSize)<br/> {<br/> DWORD dwMinSize;<br/> dwMinSize = WideCharToMultiByte(CP_OEMCP,NULL,lpcwszStr,-1,NULL,0,NULL,FALSE);<br/> if(dwSize < dwMinSize)<br/> {<br/> return FALSE;<br/> }<br/> WideCharToMultiByte(CP_OEMCP,NULL,lpcwszStr,-1,lpszStr,dwSize,NULL,FALSE);<br/> return TRUE;<br/> }<br/> <br/> <br/> 使用方法也很简单,示例如下:<br/> wchar_t wText = {L"函数示例"};<br/> char sText= {0};<br/> WCharToMByte(wText,sText,sizeof(sText)/sizeof(sText));<br/> MByteToWChar(sText,wText,sizeof(wText)/sizeof(wText));<br/> <br/> 这两个函数的缺点在于无法动态分配内存,在转换很长的字符串时可能会浪费较多内存空间;优点是,在不考虑浪费空间的情况下转换较短字符串非常方便.<br/></div></div></td></tr></tbody></table> <p>将实数转化为字符的方法用标准的C语言函数,sprintf(sTemp,"%0.2f",val);</p><p>然后在需要输入文字的地方用sTemp代替即可.</p><p></p>
页:
[1]