蓝牙点阵之汉字取模


  • 下载16*16字库到AndroidStudio的assets目录(需自行创建)下,并在程序中最好定义
    private static void String dotMatrixFont = "HZK16.dat"
  • 创建一个方法用于获取汉字,并转化成取模数据
  • 获取当前汉字的GB2312码(位码和区码),存入数组中备用- 判断位码和区码是否为负,是,则 +256
    byteCode[i] = dataBytes[i] < 0 ? 256 + dataBytes[i] : dataBytes[i];
  • 利用位码和区码,从字库中找到当前汉字的字模信息,并返回
    /*
    * 从字库找到这个汉字的字摸信息
    * areaCode 区码 对应编码的第一个字节
    * posCode 位码 对应编码的第二个字节
    * /
    protected byte[] read(int areaCode,int posCode) {
    byte[] data = null;
    try{//得到汉字在HZK16中的绝对偏移位置
    int area = areaCode - 0xa0;//区码 = 区号 - 0xa0
    int pos = posCode - 0xa0;//位码 = 位号 - 0xa0
    InputStream in = context.getResources().getAssets().open(dotMatrixFont);
    long offset = wordByteByDots * ((area - 1) * 94 + pos -1);//offset=(94
    (区码-1)+(位码-1))*32
    in.skip(offset);//忽略的字节数,返回值为实际忽略的字节数
    data = new byte[wordByteByDots];
    in.read(data,0,wordByteByDots);//从输入流中最多读取wordByteByDots个字节的数据,存放到偏移量为0的data数组中
    in.close();//关闭流
    } catch (IOException e) {
    e.printStackTrace();
    }
    return data;
    }
  • 将读取的单个汉字的数据一起存入一个数组中
    //依次读取到这个汉字对应的32位字摸信息
    byte[] data = read(byteCode[i],byteCode[i+1]);
    //复制单个汉字data数据到dataResult(源数组,源数据开始复制位置,目标数组,目标数组开始复制的位置,复制数据的长度)
    System.arraycopy(data,0,dataResult,numIndex * data.length,data.length);
  • 循环解析汉字,并返回
    for (int num = 0; num < wordNums;num++ ) {//单字循环
    for (int i = 0; i < dots; i++) {//行循环
    for (int j1 = 0; j1 < 2; j1++){
    //对每个字进行解析
    byte tmp = dataResult[num * wordByteByDots + i * 2 + j1];
    System.out.print(tmp);
    for (int j2 = 0; j2 < 8; j2++){
    if (((tmp >> (7-j2)) & 1) == 1)
    {
    matrix [i][num * dots + j1 * 8 + j2] = true;
    System.out.print("●");
    }else {
    matrix[i][num * dots + j1 * 8 +j2] = false;
    System.out.print("○");
    }
    }
    }
    System.out.println(" ");
    }
    }
    return matrix;
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,746评论 18 399
  • 一、 1、请用Java写一个冒泡排序方法 【参考答案】 public static void Bubble(int...
    独云阅读 1,411评论 0 6
  • Java经典问题算法大全 /*【程序1】 题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子...
    赵宇_阿特奇阅读 1,895评论 0 2
  • 一. Java基础部分.................................................
    wy_sure阅读 3,833评论 0 11
  • 不木先生已经过世六年,作为他从小的忠实粉,总想着为他写点什么怀念,怎奈何,每每提笔,便热泪盈眶…… 记不起是什么时...
    冷江road阅读 143评论 0 2