- 下载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;
网友评论