版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/BYH371256/article/details/83374705
本章讲述:字节数限制
限制输入字符(中文)的字节个数,超过后,截取多余的字节
引用实例:
int nLength = GetBytesOfString(OsdText.Text);
if (nLength > 30)
{
OsdText.Text = GetSubStringByLength(OsdText.Text, 30);
}
//获取输入数据字节大小 返回大小
public int GetBytesOfString(string Text)
{
int nByte = 0;
byte[] bytes = Encoding.Unicode.GetBytes(Text);
for (int i = 0; i < bytes.GetLength(0); i++)
{
// 偶数位置,如0、2、4等,为UCS2编码中两个字节的第一个字节
if (i % 2 == 0)
{
nByte++; // 在UCS2第一个字节时n加1
}
else
{
// 当UCS2编码的第二个字节大于0时,该UCS2字符为汉字,一个汉字算两个字节
if (bytes[i] > 0)
{
nByte++;
}
}
}
return nByte;
}
//截取字符串指定字节数的内容,并返回实际截取的字节数
private string GetSubStringByLength(string Text, int LimitSize)
{
byte[] bytes = Encoding.Unicode.GetBytes(Text);
int nByte = 0; // 表示当前的字节数
int i = 0; // 要截取的字节数
for (; i < bytes.GetLength(0) && nByte < LimitSize; i++)
{
if (i % 2 == 0) // 偶数位置,如0、2、4等,为UCS2编码中两个字节的第一个字节
{
nByte++; // 在UCS2第一个字节时n加1
}
else
{
if (bytes[i] > 0) // 当UCS2编码的第二个字节大于0时,该UCS2字符为汉字,一个汉字算两个字节
{
nByte++;
}
}
}
// 如果i为奇数时,处理成偶数
if (i % 2 == 1)
{
if (bytes[i] > 0) // 该UCS2字符是汉字时,去掉这个截一半的汉字
i = i - 1;
else
i = i + 1; // 该UCS2字符是字母或数字,则保留该字符
}
LimitSize = i;
return Encoding.Unicode.GetString(bytes, 0, i);
}