常用的汉子字库
点击此处下载 ourdev_568350.zip(文件大小:2.33M) (原文件名:点阵字库C语言格式.zip)以前写在彩屏上显示汉字(16*16)的驱动,用的是LPC2148。三种字体。
字库是经过转化过的,大概250K,可以全部放处理器。
字库调用的时候很方便,内附算法例子。
http://cache.amobbs.com/bbs_upload782111/files_31/ourdev_568352.jpg
(原文件名:cp.jpg)
/*------------------------------------------------------------------------------------------------------
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中读取汉字编码了。
-------------------------------------------------------*/
#include"hzk16hei.h"
#definehzkname hzk16hei //字库的文件名
unsigned char zm;//一个16*16汉字占用32字节
void get_zm(unsigned char *single_hz)
{
unsigned charqm,wm;
unsigned long int OffSet;
unsigned chark;
qm =*single_hz-0xA0;//求出区码
wm = *(single_hz + 1)-0xA0;//求出位码
OffSet = ((qm - 1)*94 + (wm - 1))*32; //计算偏移量
for (k=0;k<32;k++)//连续取32个,一个汉字32个字节
zm =*(hzkname + OffSet+k);
} 好资料,谢谢了 楼主的彩屏多少钱啊? mark!~~ mark,会用稿 谢谢! 记号一下 不错,很有用,谢谢楼主 好东西,mark~ mark 标记 记号
日后做打印用得着 记号 mark 谢了 回复【楼主位】detector
-----------------------------------------------------------------------
mark 下, 好东西啊 楼主,你的字库是放在哪里的?如果是放在外部flash里面,flash的大小肯定得大于262k,那就需要用19跟地址线来进行寻址,那么如何根据偏移地址来计算这个字模在flash中的实际地址呢,我手上有一个程序,但是我看不懂是如何进行寻址的,硬件电路时这样连接的点击此处下载 ourdev_598133FJ74RS.pdf(文件大小:43K) (原文件名:Protel Schematic.pdf)
字库文件是放在u25rom中,u25一共有19跟地址线,需要分开寻址,a0-a12,q0-q5,一共19跟地址线寻址
显示 汉字程序时这样的:
#define B377 XBYTE //原理图中的u4芯片
/*-----------------------------------------------------------------------------------------
**函数名:hzdisplay()
**功能:显示一个汉字
**参数:x-列,y-行,party-汉字内码区号,addr-汉字内码位码,style-反显正常显示
**返回:void
------------------------------------------------------------------------------------------*/
void hzdisplay(uchar x, uchar y, uchar party, uchar addr,uchar style) //显示一个汉字
{
uchar i;
uint realaddr,ttp,temp;
uchar xdata *hz;
ttp=party*94+addr-95; //计算汉字在GB 2312-80区中的位置 index = (94*(region-1)+location-1)*32;//数组内地址
temp=ttp<<5; //每个字模有32个字节,所以计算得到的地址需要乘以32
temp&=0x1fff;
temp|=0xa000; //取低13位,此时temp为此字字模的首地址
B377=ttp>>8; //取高6位,并用74hc377锁存送出,共19位地址,采用040做字库
ttp=x+y*30;
for(i=0;i<16;i++)
{
realaddr=ttp+i*30;
addrset(realaddr);
hz=temp;
hz+=i<<1;
data1w((style)?~(*hz):*hz);
addrset(realaddr+1);
hz++;
data1w((style)?~(*hz):*hz);
}
}
我想问一下,确定字在字库中的位置后,如何去rom寻址,如何确定a0-a12,q0-q5的取值?
这几句不明白
temp=ttp<<5; //每个字模有32个字节,所以计算得到的地址需要乘以32
temp&=0x1fff;
temp|=0xa000; //取低13位,此时temp为此字字模的首地址
B377=ttp>>8; //取高6位,并用74hc377锁存送出,共19位地址,采用040做字库 mark mark,备用 mark mark mark mark mark mark mark mark 好东西 好资料啊 顶顶更健康 mark 留住先 24c? MARK 看了你这篇文字,我有思路了, 我的想法是
1:搞个字库到芯片里面
2:调用字库用点阵屏显示汉子,动态移动(上下左右)
我手头上面有STM32开发板,里面有SST25VF016B存储器,还有块点阵屏,公司的,现在没没有原理图,
但是看了你这篇文字之后,改思路了,现在你的思路调用字库,在TFT上面显示汉子在说, 好贴子,正在进行彩屏的字符显示工作,谢谢了! MARK!~~
THANKS!~ 感谢分享!!!!!!!! mark 中顶起 汉子库16*16 {:smile:}{:smile:}{:smile:} 你的字体怎么前面32个都是0x00啊,第一个字 “啊” 怎么也不是0x00,求解答啊
页:
[1]