使用ATM2864H图形显示液晶嵌入汉字库设计的心得.doc

使用ATM2864H图形显示液晶嵌入汉字库设计的心得.doc

ID:55505772

大小:309.00 KB

页数:6页

时间:2020-05-15

使用ATM2864H图形显示液晶嵌入汉字库设计的心得.doc_第1页
使用ATM2864H图形显示液晶嵌入汉字库设计的心得.doc_第2页
使用ATM2864H图形显示液晶嵌入汉字库设计的心得.doc_第3页
使用ATM2864H图形显示液晶嵌入汉字库设计的心得.doc_第4页
使用ATM2864H图形显示液晶嵌入汉字库设计的心得.doc_第5页
资源描述:

《使用ATM2864H图形显示液晶嵌入汉字库设计的心得.doc》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、使用ATM12864H图形显示液晶嵌入汉字库设计心得前言:最近在做项目过程中,有用到ATM12864H的图形显示液晶,MCU用的是atmel的AT91S40800,以往做这种液晶的汉字显示,是先用字模转换工具将需用到的汉字先提取出来,然后再放到flash中,再做一个索引,每次需要新的汉字时候就做一个汉字字模数据添加进去,现在该项目中扩展的flash够大,完全可以把整个字库装进去对整个系统毫无影响,于是我决定做一个带字库的液晶驱动程序,方便后面液晶菜单的编写和修改。花了好几天功夫,死了N多脑细胞,遇到了很多难点,最后总算把相关问题解决,

2、心情不免舒畅,现在把开发过程心得记录下来,供大家参考。液晶模块介绍:我们使用的液晶ATM12864H是一块采用低功耗CMOS技术图形显示驱动模块,驱动芯片选用的是三星的1片KS0108B和2片KS0107B.DDRAM内存和液晶显示的点对照如下表。该液晶让人郁闷的是,别人是横写模式,它却是竖写模式,这点为用汉字库带来了很大的麻烦,后续会讲到。汉字库介绍:我们用的是UCDOS软件中的文件HZK16,该文件为16×16的国标汉字点阵文件,以二进制格式存储。在文件HZK16中,按汉字区位码从小到大依次存有国标区位码表中的所有汉字,每个汉字占

3、用32个字节,每个区为94个汉字在PC机的文本文件中,汉字是以机内码的形式存储的,每个汉字占用两个字节:第一个字节为区码,为了与ASCII码区别,范围从十六进制的0A1H开始(小于80H的为ASCII码字符),对应区位码中区码的第一区;第二个字节为位码,范围也是从0A1H开始,对应某区中的第一个位码。这样,将汉字机内码减去0A0A0H就得该汉字的区位码。例如汉字“房”的机内码为十六进制的“B7BF”,其中“B7”表示区码,“BF”表示位码。所以“房”的区位码为0B7BFH-0A0A0H=171FH。将区码和位码分别转换为十进制得汉字“

4、房”的区位码为“2331”,即“房”的点阵位于第23区的第31个字的位置,相当于在文件HZK16中的位置为第32×[(23-1)×94+(31-1)]=67136B以后的32个字节为“房”的显示点阵。房子显示的点阵字模如下图所示。查出的汉字字库数据为如下32个字节数据:0x02,0x00,0x01,0x08,0x3F,0xFC,0x20,0x08,0x3F,0xF8,0x21,0x00,0x20,0x84,0x3F,0xFE,0x22,0x00,0x22,0x10,0x23,0xF8,0x22,0x10,0x44,0x10,0x44,

5、0x10,0x88,0xA0,0x10,0x40,存放汉字库和取汉字字模数据:有了汉字库后,我们必须把它存到flash中,我们把它存在0x01100000开始的地址中,hzk16文件总供有262K,我们用编程工具将hzk16二进制文件下载到flash中,当然你也可以另外定义地址存放,但是最好是靠后面放,因为我们前面需要放程序,防止程序太长把字库数据覆盖掉。取汉字数据程序如下:#defineHZK_JDZ0x01100000Voidgetdata(char*str,uchar*c){inti,j;longaddr;uchar*p;i=*

6、str-0xa0;j=*(str+1)-0xa0;addr=32*(94*(i-1)+j-1);p=(uchar*)(HZK_JDZ+addr);for(i=0;i<32;i++){*(c+i)=*(p+i);}}汉字字模数据处理:我们使用的ATM12864H属于竖排的字节,如果直接调用该数据送到DDRAM显示,将会是一堆乱码。数据需要正确处理才能显示。为了正确显示,需要将数据库重新转换成如下图所示的数据。我们将字模分成4个8*8的块,分别用A,B,C,D来表示,新转换后的数据需要先写左上角A区的8个字节,并且是竖排,再写左下角的B区

7、8个字节,再写右上角C区的8个字节,最后是右下角D区的8个字节。接下来我们详细讨论如何将横排的32个原始字节数据转换成我们需要的竖排的32个字节数据。首先我们来分析一下原始数据排列和布局,如下图:由上图我们可以清楚看到,原始数据的排列是,先A区的第1行数据放入第1个字节,接着放B区的第1行数据放入第2个字节,依此类推下去,左半边数据放在偶数下标字节中,右半边数据放在奇数下标的字节中。而转换后的数据排列是A区的第1列数据放入第1个字节中,A区的第2列放入第2个字节,一直到A区的第8列数据放入第8个字节,B区的第1列数据放入第9个字节中,

8、B区的第2列放入第10个字节,一直到B区的第8列数据放入第16个字节中,依此类推下去,再放C区的列数据,D区的列数据,最后D区的第8列数据放入到第32个字节中。因此我们需要对数据进行处理,才能得到我们需要的可以方便显示的

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。