T6963C是一款在仪表中使用得比较多的一种液晶显示控制器。提供文本和点阵两种输出方式,但点阵输出的速度比文本显示的速度要慢很多。在文本方式下,其CGROM控制128个英文ASCII码字符,CGRAM则可由用户自定义32个汉字或128个自定义图形。
由于仪表中使用的汉字经常超过32个,因此,需要对汉字的显示作特别的处理。但由于汉字的处理有些特殊,因此,很多开发人员即偷懒,直接使用点阵需出。
昨天,我到一家比较有名的电力企业参观,见其仪表的显示速度非常之慢,可以断定它的显示是采用点阵而不是采用文本方式,于是写了此文章。
原理:利用液晶故有的CGRAM,将一个汉字作为四个字符,以文本方式显示汉字。
方法:CGRAM中能显示的字符从80H到FFH,共128个。其中,每连续四个字符作为显示一个汉字。故能显示的汉字量为32个。但在系统中使用的汉字数可能会超过32个。所以,采用数据缓冲技术,在需要显示汉字时,临时构成字符显示码。
汉字点阵是以表格形式ChineseTable保存在数据区中。
建立一个长度为16的字符数组CharFlagTable,用来保存当前系统CGRAM中可显示的汉字编号。为了加快系统显示汉字的速度,将汉字分成两组:一级汉字;二级汉字,一级汉字永远保存在CGRAM中,不需要记录编号;而二级汉字在需要显示时,才调于到CGRAM中,需要CharFlagTable来记录编号。其中一级汉字为16个,规定在ChineseTable中前16个汉字为一级汉字,其余的汉字为二级汉字。
程序初始化时,将一级汉字调入和前16个二级汉字同时调入CGRAM;并将CharFlagTable的内容清为0。
WriteOneChin函数实现方法:
根据需要显示的汉字的编号,计算此汉字对应的CharFlagTable编号Num和序列编号Offset,计算方法为:
if (汉字的编号》=16)
{
Num=(汉字的编号-16)%16;
Offset=(汉字的编号-16)/16;
}
再判断对应Num编号的CharFlagTable中的序列编号,如果两者相等,则直接显示该汉字字符,否则,将对应汉字字模调入CGRAM中后,再显示该汉字。
为了提高显示速度,可以将整个显示模式改为非图形模式。
定义全局静态数组:
staTICsigned char CharFlagTable[16];
定义如下函数:
void InitCGRAM(void);
//功能:完成初始化CGRAM字符显示区,初始化CharFlagTable表格,程序逻辑如下:
{
for (I=0;I《16;I++) CharFlagTable[I]=0;
for (I=0;I《32;I++)WriteCGRAM(I);
}
void WriteCGRAM(unsigned int ChinNo);
//功能:完成将对应编号的汉字的字模点阵信息写入到对应的CGRAM内存区,程序逻辑如下:
{
if (ChinNo《16) Num=ChinNo;
else Num=(ChinNo-16)%16+16;
Num*=4;
Num+=0x80; ////得到对应编号汉字的四个字符中第一个字符编号;
{将编号为ChinNo的汉字数组送入到Num到Num+3四个字符中}
}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)