蓝牙点阵之汉字取模


  • 下载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;

推荐阅读更多精彩内容