打印机打印字符串转字节数组截取半个中文导致的乱码问题

时间:2022-02-15 22:45:02

    打印机打印的时候  要求:打印一行文字,但这行文字实际长度 len(单位是:px)是固定的 

  这时候我们的思路是  :GBK编码下汉字占用两个字节,而且这两个字节都是负数,char型字符占用一个字节,

       每个汉字占用的宽度是24px   每个char型占用的宽度是12px    换言之每个字节占用的打印宽度是12px

                             本行所容纳的字节个数 num=len / 12

   这时候我们将字符串转为字节数组  截取num个字节放到字节数组,然后转为字符串就是该行打印的字符串

但是有个问题就是 当我们截取的最后一个字节是汉字的一半(汉字由2个字节组成) 这个时候就会出现乱码,怎么破?

其实很简单  统计这num个字节中值为负数 的个数 如果是偶数说明没有截取半个汉字的情况出现,

    如果是奇数说明有半个汉字的情况出现

 这里有个重点  将字符串转换为字节数组时要转为GBK编码 的字节数组   因为 在GBK编码下汉字占用两个字节,而且都是负数,方便统计

            String str="双节棍爱好友h为太原";
  
            byte[]source=str.getBytes("GBK");                    

 

  public boolean isHasHalfChiness(byte[] source){
        int count=0;
        for (int i = 0; i < source.length; i++) {
            if(source[i]<0){
                count++;
            }
        }
        return count%2 == 0 ? false : true;
    }

遇到有半个汉字的情况就不截取最后一个字节就OK了  然后其他的另起一行打印什么的就不用说了

大家遇到打印机这方面问题的可以找我交流,共同学习进步!

          严禁盗版    

   转载请注明出处:https://www.cnblogs.com/bimingcong/p/9185587.html