hzk16的介绍以及简单的使用方法

来源:互联网 发布:淘宝店铺dsr 编辑:程序博客网 时间:2024/05/21 09:31

hzk16的介绍以及简单的使用方法

    HZK16 字库是符合GB2312标准的16×16点阵字库,HZK16的GB2312-80支持的汉字有6763个,符号682个。其中一级汉字有3755个,按声序排列,二级汉字有3008个,按偏旁部首排列。我们在一些应用场合根本用不到这么多汉字字模,所以在应用时就可以只提取部分字体作为己用。

    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中读取汉字编码了,剩下的就是文件操作了。

C语言实现代码如下:

void lcd_show_gb2312(unsigned int x, unsigned int y, unsigned char *str,unsigned int p_color, unsigned int b_color){unsigned int area = str[0] - 0XA0;// 得到区码unsigned int where = str[1] - 0XA0;// 得到位码unsigned int offset = ( (area - 1)*94 + (where - 1) )*32; //得到在HZK16中的偏移unsigned int i,j,k;unsigned char hz_buf[16][2] = {0};// 获取bitmapFILE *hzk;hzk = fopen(HZK_FILE, "rb");if(hzk == NULL){printf("cant open %s\n",HZK_FILE);exit(0);}fseek(hzk ,offset,SEEK_SET);fread(hz_buf,32,1,hzk);for(i = 0; i < 16; i++){for(j = 0; j < 2; j ++){for(k = 0; k < 8; k ++){if(hz_buf[i][j] & (0x80 >> k)){lcd_draw_point(x+8*j+k,y+i,p_color);}else{lcd_draw_point(x+8*j+k,y+i,b_color);}}}}}
在main.c中调用lcd_show_gb2312函数示例如下:

lcd_show_gb2312(50,50,"中",RED,WHITE);
main.c文件要用记事本打开,另存为ANSI格式,在用gcc编译时要批定输入字符集和可执行文件字符集,编译命令如下:

gcc -finput-charset=GBK -fexec-charset=GBK -o test main.c xxx.c


0 0