在嵌入式显示设备中如果有足够大的flash,我们就可以用数百KB空间来存储一个HZK16字库文件用于显示16*16汉字,免得还要自己提取字模。
HZK16字库是符合GB2312标准的16×16点阵字库,HZK16的GB2312-80支持的汉字有6763个,符号682个.
其中一级汉字有 3755个,按声序排列,二级汉字有3008个,按偏旁部首排列.
我们在一些应用场合根本用不到这么多汉字字模, 所以在应用时就可以只提取部分字体作为己用.
HZK16字库里的16×16汉字一共需要256个点来显示, 也就是说需要32个字节才能达到显示一个普通汉字的目的.
我们知道一个GB2312汉字是由两个字节编码的,范围为0xA1A1~0xFEFE.
A1-A9为符号区, B0到F7为汉字区. 每一个区有94个字符(注意:这只是编码的许可范围,不一定都有字型对应,比如符号区就有很多编码空白区域).
一个汉字占两个字节,这两个中前一个字节为该汉字的区号,后一个字节为该字的位号.
其中, 每个区记录94个汉字, 位号为该字在该区中的位置. 所以要找到"我"在hzk16库中的位置就必须得到它的区码和位码.
区码:汉字的第一个字节-0xA0 (因为汉字编码是从0xA0区开始的, 所以文件最前面就是从0xA0区开始, 要算出相对区码)
位码:汉字的第二个字节-0xA0
这样我们就可以得到汉字在HZK16中的绝对偏移位置:
offset=(94*(区码-0xa1)+(位码-0xa1))*32
如何知道一个汉字的区码和位码呢,可以用一个小程序来计算:
#include <stdio.h> #include <stdlib.h> int main(void) { unsigned char code[2] = {0}; puts("请输入一个汉字:"); gets((char*)code); printf("区码:%d 位码:%d",code[0],code[1]); return EXIT_SUCCESS; }
知道区位码就可以计算出字模数据在字库文件中的绝对偏移地址:
#include <stdio.h> #include <stdlib.h> int main(void) { int posi; unsigned char code[2] = {0}; puts("请输入一个汉字:"); gets((char*)code); printf("区码:%d 位码:%d\n",code[0],code[1]); posi = ((code[0] - 0xa1) * 94 + code[1] - 0xa1)*32; printf("偏移值为: %d\n", posi); return EXIT_SUCCESS; }
有了文件,又有了偏移量,我们就可以对文件进行读取,取出一个汉字所需要的32字节字模数据,并将该字模显示出来了:
#include <stdio.h> #include <stdlib.h> int main(void) { long int offset; unsigned char code[2] = {0}; unsigned char buffer[32]; //存储一个汉字所用的32个字节 unsigned char i,j; FILE *fp = NULL; puts("请输入一个汉字:"); gets((char*)code); printf("区码:%d 位码:%d\n", code[0], code[1]); //显示区位码 offset = ((code[0] - 0xa1) * 94 + code[1] - 0xa1) * 32; //计算绝对偏移地址 printf("偏移值为: %ld\n", offset); fp = fopen("hzk16.dat", "rb"); //二进制只读方式打开,261KB if (fp == NULL ) //如果打开失败 { printf("打开字库失败\n"); return 0; } fseek(fp,offset,0); //根据偏移寻找到该字字模的第一个字节 for (i = 0; i < 32; ++i) { //连续读取32个字节 buffer[i] = fgetc(fp); } for (i = 0; i < 32; ++i) { //将32个字节顺序打印 for (j = 0; j < 8; ++j) { if (buffer[i] & 0x80) { printf("@@"); }else{ printf(" "); } buffer[i] <<= 1; } if (i % 2) { printf("\n"); //如果i%2==1说明该字节是靠后的那个字节,显示完后要换行 } } return EXIT_SUCCESS; }
此时,HZK16通过C代码解析出来了。但是采用这种字库毕竟有局限,如“囧”字,是无法显示出来的,很多没有收录的新字在显示时还是不得不采用字模方式:
值
相关推荐
hzk16.c ucgui 汉字显示 源码
HZK16字库,oled显示的好伙伴,单片机屏幕的好闺蜜
电子-HZK16.c,单片机/嵌入式STM32-F0/F1/F2
hzk12字库的C数组文件 可以直接调用
通过调用HZK16,来模拟LED显示点阵汉字的效果。可以同时写任意三个字符。软件可能还不完善,如有bug请及时提出。本人现在为在南京的实习生,渴望获得项目的实践机会,若能给予,感激不尽。邮箱zhanghtt@126.com
系统中常用的几个字体库文件---ASC16、ASC32-122、HZK16,应用在单片机LED汉字显示。代码部分可以参考网上的
字模提取,C源代码,包含直接提取和经过行列变换后的字模直接保存到文件中,用于在不同的LCD上显示汉字。 希望能够对大家有所帮助!O(∩_∩)O谢谢
利用proteus实现汉字库提取并且在液晶显示器上现实出来,,51单片机,proteus keil
最全的字母、汉字点阵库大全: HZK16S 宋体 HZK16F 仿宋 HZK16H 黑体 HZK16K 楷体 HZK16Y 幼圆 HZK16L 隶书 HZK16C 粗体 HZK16X 细 HZK16V 繁 HZK24F 24x24 仿宋汉字打印...HZK16 16x16 宋体汉字点阵 一个汉字32Byte
ASC及汉字 8*12 8*16 12*16 16*16 24 32 48....字库文件,包含 样式预览图+字库说明文档+使用示例c文件
hzk1216.zip文件中包括hzk12和hzk16字库,可用于点阵字库的制作
电子-HZK24.c,单片机/嵌入式STM32-F0/F1/F2
自己制作的字库文件,包含完整的(HZK12 HZK16 ASC II),做嵌入式GUI的必备。
在DEV C++5.3开发环境下测试通过HZK16,HZK24,HZK32正常读,通过控制台显示出读出来的字库实例,在网上找了很多,很多不能调试通过,花些时间去调试,程序简单,可读性强,这里可以节省大家的时间
中文字体库文件HZK16,以及在显示屏上打印中文字符的代码
博文 https://blog.csdn.net/boysoft2002/article/details/120603436 中提及的16点阵字库,下载后解压就能用。
包括HZK16黑体、HZK16楷体、HZK16宋体、HZK24黑体、HZK24楷体、HZK24宋体、HZK32宋体。