PCtoLCD2002是一款免费的取字模的软件,支持多种取模方式,可以生成中英文混合的字符串的字模数据,非常方便。在使用的过程中很多功能无法发掘,现在小编就把详细的使用指南为大家陈列一下。
PCtoLCD2002使用指南
0.生成自定义的小字库:
0.使用PCTOLCD的各种调整功能调整出您需要的文字样式,如字体,字样(下划,倾斜,加粗),大小(各种点阵大小的字体,可锁定点阵本身大小(如1616),然后在这个固定的点阵大小内调节文字的大小(例如在1616的点阵中居中显示1212大小的汉字),各项配置大概如下图,具体的要根据自己的需要修改:
字模选项配置如下图:
1.将您需要的汉字和符号集中形成一个文本文件
2.使用“导入文本”的按钮
3.建议选中"生成索引文件"
4.点“开始生成”按钮,选择生成的字库文件名
5.然后耐心等待一段时间(与处理文本大小有关),在此期间建议不要动键盘和鼠标。
6.字库生成完毕.
生成的索引文件,如下图:
生成国标一二级汉字库(生成的文件,包含了日常需要的所有字符、汉字,生成的文件大概1.3MB)
0.使用PCTOLCD的各种调整功能调整出您需要的文字样式,如字体,字样(下划,倾斜,加粗),大小(各种点阵大小的字体,可锁定点阵本身大小(如1616),然后在这个固定的点阵大小内调节文字的大小(例如在1616的点阵中居中显示1212大小的汉字).
1.使用“导入文本”的按钮
2.点右下角"生成国标汉字库"按钮.
3.选择字库文件名后单击确定
4.耐心等待一段时间后既得到生成的汉字库(时间视具体机器而定).
温馨提醒:
生成汉字库结构介绍
本软件使用的汉字库采用与HZK16相近似的结构,即按照输入汉字的顺序依次排列各汉字的点阵数据,以生成的1616点阵汉字库举例介绍
1616点阵汉字库
点阵大小1616,所以每个汉字点阵数据占用32个字节.用户要使用生成的1616点阵小字库中的点阵数据,可以在程序中采用如下算法:
0.在生成的字库汉字列表中得到该汉字的偏移量,也就是汉字的记录号HzNum
1.将其32(HzNum32)即可得出该汉字点阵在字库中的偏移地址.
3.以这个偏移地址为起点,连续读取文件中的32个字节,既为该汉字的点阵信息.
实际上,对于本软件生成的16*16点阵的国标汉字库是采用区位码排列的,所以与标准的HZK16结构是一样的,完全可以互换使用.
例如生成一个2448点阵,楷体,倾斜的汉字库,
0.由于每个汉字占用2448/8= 144个字节,所以用户可先读取生成的索引列表找到该汉字的记录号.
1.将记录号144即得到该汉字在字库中的偏移地址.
2.以这个偏移地址为起点,在字库文件中连续读取144个字节,即为该汉字的点阵信息.
知道了以上信息,可以在检索字模时知道如何编程了。最后如何将字模文件用到头文件里,如下:
同时,在编程检索该字模文件时,编程如下:
#include “GB1616.h” //1616汉字字模
void PutGB1616(unsigned short x, unsigned short y, unsigned char c[2], unsigned int f,unsigned int b)
{
unsigned int i,j,k;
LCD_SetArea(x, y, x+16-1, y+16-1);
for (k=0;k<22;k++) {
if ((codeGB_16[k].Index[0]==c[0])&&(codeGB_16[k].Index[1]==c[1])){
for(i=0;i<32;i++) {
unsigned short m=codeGB_16[k].Msk;
for(j=0;j<8;j++) {
if((m&0x80)==0x80) {
LCD_Write_Data(f>>8);
LCD_Write_Data(f);
}
else {
LCD_Write_Data(b>>8);
LCD_Write_Data(b);
}
m<<=1;
}
}
}
}
}
同样的英文字符,跟上述方法一样。以上的过程大概就是使用PCtoLCD软件设计字模,并将字模用到程序中,同时检索字模的程序该如何编写都有了。
关于PCtolcd2002字符提取软件的说明:
首先注意这个软件只是生成相应的字库或者图片,这与你用的是什么显示器,用的什么驱动芯片,驱动层什么扫描方式完全无关的!!无非就是根据屏上要显示的图案给你生成对应的字节对应值而已,只是将该每个点给你产生对应的字节是什么而已。也就是说所有基于像素点构成的屏都可以通过这个软件生成对应的字符,无论led还是lcd均可。(这就是为啥叫字符提取软件)
其次,取模方式比如顺向和逆向与芯片驱动层写的扫描方式有关系吗?无关!我们驱动层写的各种扫描方式其实最主要的是把握我们mcu数据到显示屏坐标的映射关系的一种确定,但是我们填充各种文字图案时都是基于我们自己应用接口描点函数上实现的,而我们的取模方式正就是指的对应点的顺序写入问题。也就是说,取模方向指的是描点函数(即对应1个像素)写入对应字时的写入顺序问题,换句话说,我们选取取模方向,只需改变应用层写入字或图片时描点函数对应顺序即可(顺向,则由高到低写入;逆向,则由低到高位写入)。因此,取模方式与芯片和驱动层也无关!! 与我们应用层调用描点函数构造其他接口有关
此方法取模汉字时,不管是16x16,24x24.32x32的字体,在设置/字模选项/每行显示数据里,都填的是点阵16,索引3,不然显示不正确的。
1.关于取模方向顺向和逆向的说明:
我们在这个软件上随便写个值查看就能看出,其实际上就是屏幕上同列上行与下行哪个行对应生成字节的高位还是低位的问题。顺序就是屏幕下行属于高位,逆序就是屏幕上行属于低位。以下面红色部分为例,最上面8个点如果下5个点为亮生成的字节是00011111还是11111000的区别
(这实际上跟我们程序逻辑上画点函数是将屏的上行是坐标的高还是低有关系,这里我们的屏幕画点接口就是按屏幕上为低坐标下为高坐标),因此我们按软件顺序生成字符时,基于画点函数构造的写字符和汉字接口按字节也将其高位作为高地址处理即可。当然我们如果软件逆序则构造函数将字节低位作高地址处理。
PCtolcd2002字符提取软件使用说明
2.自定义格式A51和C51的区别:
只是生成字库前缀后缀的去呗,A51按汇编生成,C51按c格式生成,显然我们c编程后者即可