CString类型中文字符串截取出现乱码的问题/实现中文字符串截取无乱码的方法

原贴地址

我的方法与他类似,先将cstring转成宽字节后再截取字符串

方法原理:cstring下默认字符字母数字等占一个字节,而中文占两个字节,转换成宽字节后每个单字节后面会自动填充一个0x00 ,就能和中文一样保持双字节,截取时保证取得个数为偶数就可以了

代码示例:实现自动换行的功能

            strText = consPos;(cstring类型)
			if (strText.GetLength() > 35)   //字符太长,待解决
			{
				Util::ANSItoUTF8(strText);//将ANSI转成UTF8
				m_Font.CreatePointFont(100, "宋体", pDC);
				pDC->SelectObject(&m_Font);
				nPosX = m_cxLeft + 150;
				size = pDC->GetTextExtent(strText);
				CString strTextLeft = strText.Left(56);
				CString strTextRight = strText.Mid(56);
				Util::UTF8toANSI(strTextLeft);//将UTF8转成ANSI类型
				Util::UTF8toANSI(strTextRight);
				pDC->TextOut(nPosX, nPosY - 5, strTextLeft);
				pDC->TextOut(nPosX, nPosY + 8, strTextRight);
				fontHeader.DeleteObject();
			}
			else
			{
				nPosX = m_cxLeft + 150;
				size = pDC->GetTextExtent(strText);
				pDC->TextOut(nPosX, nPosY, strText);
				fontHeader.DeleteObject();
			}

换行前

换行后

猜你喜欢

转载自blog.csdn.net/Robin_hc/article/details/82965963
今日推荐