hzk16的使用与介绍 | 您所在的位置:网站首页 › gb2312每个汉字的字形码都用两个字节存储 › hzk16的使用与介绍 |
HZK16字库里的16×16汉字一共需要256个点来显示,也就是说需要32个字节才能达到显示一个普通汉字的目的。 我们知道一个GB2312汉字是由两个字节编码的,范围为A1A1~FEFE。A1-A9为符号区,B0到F7为汉字区。每一个区有94个字符(注意:这只是编码的许可范围,不一定都有字型对应,比如符号区就有很多编码空白区域)。下面以汉字“我”为例,介绍如何在HZK16文件中找到它对应的32个字节的字模数据。 前面说到一个汉字占两个字节,这两个中前一个字节为该汉字的区号,后一个字节为该字的位号。其中,每个区记录94个汉字,位号为该字在该区中的位置。所以要找到“我”在hzk16库中的位置就必须得到它的区码和位码。(为了区别使用了区码和区号,其实是一个东西,别被我误导了) 区码:区号(汉字的第一个字节)-0xa0 (因为汉字编码是从0xa0区开始的,所以文件最前面就是从0xa0区开始,要算出相对区码) 位码:位号(汉字的第二个字节)-0xa0 这样我们就可以得到汉字在HZK16中的绝对偏移位置: offset=(94*(区码-1)+(位码-1))*32 注解:1、区码减1是因为数组是以0为开始而区号位号是以1为开始的 2、(94*(区号-1)+位号-1)是一个汉字字模占用的字节数 3、最后乘以32是因为汉字库文应从该位置起的32字节信息记录该字的字模信息(前面提到一个汉字要有32个字节显示) 有了偏移地址就可以从HZK16中读取汉字编码了,剩下的就是文件操作了,就不说了。 hzk16汉字库的简单读写程序 :要看代码(汉字)就是下面的:“hzk16汉字库的简单读写程序",是一个最简单的c语言程序。 int i, j, k; unsigned char incode[3]="我"; // 要读出的汉字 unsigned char qh,wh; unsigned long offset; // 占两个字节, 取其区位号 qh = incode[0] - 0xa0; / /获得区码 wh = incode[1] - 0xa0; / /获得位码 offset = ( 94*(qh-1) + (wh-1) ) * 32; /*得到偏移位置*/ FILE *HZK; char mat[32]; if((HZK=fopen("hzk16", "rb")) == NULL) { printf("Can't Open hzk16\n"); exit(0); } fseek(HZK, offset, SEEK_SET); fread(mat, 32, 1, HZK); //显示 for(j=0;j void *void_p;//定义一个空类型指针 int8 *int8_p;//定义一个unsigned char 指针 int8 i; //定义一个循环变量 int16 area_l,area_h;//定义两个整型变量,用于存储区码和位码 int32 pos; //定义一个long型变量,用于存储计算所得字模在字库的位置, int8 chip; //字模所在的芯片,可用74HC138之类的芯片译码。 int16 addr; //在某一芯片64K字节空间内的地址
void_p=&hz; //空指针指向机内码的低字节 int8_p=void_p; //char类型指针指向空指针,即机内码的低字节 area_l=*int8_p-0xa0; //机内码低字节减去0xa0得到区码 area_h=*(int8_p+1)-0xa0; //机内码高字节减去0xa0得到位码 pos=32*((int32)((area_h-1)*94)+area_l-1); //计算在一个完整的字库中的位置(256K) //pos=116672; //这是“请”字在HZK16文件中的位置,单位为字节。用于测试 if(pos chip=1; addr=(int16)pos; } else if( (pos>=128*1024) && (pos chip=3; addr=(int16)pos; } select_chip(chip); //选择第chip片27512芯片 for(i=0;i |
CopyRight 2018-2019 实验室设备网 版权所有 |