单片机系统中汉字显示论文

时间:2022-03-05 02:10:00

导语:单片机系统中汉字显示论文一文来源于网友上传,不代表本站观点,若需要原创文章可咨询客服老师,欢迎参考。

单片机系统中汉字显示论文

一、硬件组成

本系统中采用香港精电公司的内置T6963控制器[1]的240128T点阵图形液晶显示器。该显示器1行为240点,能容纳16×16点阵的汉字15个,总列数为128点,能显示8行汉字。为了使用MCU操作可使用1片512KB的存储器(如本系统中的29F040)用来存储全部的国标16×16点阵汉辽、8×16的ASCII码点阵数据以及汉字语句编码数据。为了降低成本和减小体积,对于速度要求不是很高的场合也可采用大容量的串行数据存储器,如AT45DB041B。具体的硬件控制电路如图1所示(与汉字显示无关的电路略)。

由于29F040的容量为512KB,而5031微控制器只能管理64KB的数据间,所以可将29F040分成16页,每页32KB,占单片机系统数据空间的8000H~0FFFFH(剩余32KB为单片机系统的其他存储器和外设)。页码由单片机的P1.0~P1.3选择。液晶显示器的地址为7FF8H~7FF9H。

二、汉字显示原理及软件设计

UCDOS软件中的文件HZK16和文件ASC16分别为16×16的国标汉字点阵文件和8×16的ASCII码点阵文件,以二进制格式存储。在文件HZK16中,按汉字区位码从小到大依次存有国标区位码表中的所有汉字,每个汉字占用32个字节,每个区为94个汉字。在文件ASC16中按ASCII码从小到大依次存有8×16的ASCII码点阵,每个ASCII码占用16个字节。

在PC机的文本文件中,汉字是以机内码的形式存储的,每个汉字占用两个字节:第一个字节为区码,为了与ASCII码区别,范围从十六进制的0A1H开始(小于80H的为ASCII码字符),对应区位码中区码的第一区;第二个字节为位码,范围也是从0A1H开始,对应某区中的第一个位码。这样,将汉字机内码减去0A0AH就得该汉字的区位码。

例如汉字“房”的机内码为十六进制的“B7BF”,其中“B7”表示区码,“BF”表示位码。所以“房”的区位码为0B7BFH-0A0A0H=171FH。将区码和位码分别转换为十进制得汉字“房”的区位码为“2331”,即“房”的点阵位于第23区的第31个字的位置,相当于在文件HZK16中的位置为第32×[(23-1)×94+(31-1)]=67136B以后的32个字节为“房”的显示点阵。

在本单片机系统中,起始地址的高4位为页号,送P1口,低15位为数据区地址,送指针DPTR。利用“MOVX”指令连续取32个字节送LCD的相应位置,就能实现正确的汉字显示。

ASCII码的显示与汉字的显示基本原理相同。在文件ASC16中不存在机内码的问题,其显示点阵直接按ASCII码从小到大依次排列,只是每个ASCII码在文本文件中只占1个字节且小于80H,而且ASCII码为8×16点阵,所以在ASCII16文件中,每个ASCII码的点阵也只占16个字节。

首先提取16×16的国标汉字点阵和8×16的ASCII码点阵(如UCDOS软件中的HZK16和ASC16)并将其直接写入29F040。其中HZK16(共256KB)点0~7页。为了便于编程,ASC16虽然只有4KB,也单独占用第8页。其余剩下的空间用来存储汉字语句的编码。

由于240×128点阵的LED显示器每个只能显示15个汉字(16×16点阵汉字),即30个字节。所以可将需要显示的语句按30个字节为1行进行编写,不足30个字符的则补空格。在PC机上进行录入时,每行30个字符再加上回车键和换行符,实占32个字符。所录入的语句以纯文本形式存盘,再将该文本文件以二进制的形式写入29F040的第9页。那么,以后根据需要显示的语句行号便可以进行正确的显示。此,作者推出荐使用DOS版本的WPS软件的“编辑非文收文件”功能,它能清楚地显示每行是否有30个字符。

根据以上原则,显示1行汉字的具体程序框图如图2所示。

为方便读者,将已经在实际应用中中通过的汇编子程序列出如下(关于LCD控制器T6963的用户法请见参考文献1)。

LCDCOMEQU7FF9H

LCDDATEQU7FF8H

;显示1行汉字子程序

;汉字语句位置编号DPTR;行号:R6PRHZ:MOV24H,DPH

MOV25H,DPL

PUSHDPH

PUSHDPL

MOVA,DPH;计算页号

RRA

RRA

ADDA,#9;从第9区开始存放每行字符的机内码

ORLA,#0F0H

MOVP1,A

LCALLRL245;行号乘以32(每行32个字符)

SETB24H,7;数据地址位于8000H~0FFFFH

MOVDPH,24H

MOVDPL,25H

MOVR0,#0E0H

MOVR7,#30;连续取出30个字符至0E0H内部数据存储器

PRHZ3:MOVXA,@DPTR

MOV@R0,A

INCR0

INCDPTR

DJNZR7,PRHZ3

MOV1DH,#30;显示0E0H后的一行字符(共30个)

MOVR5,#0;当前列R5

MOVR0,#0E0H

MOVA,#7FH;是否为ASCII码?

CLRC

SUBBA,@R0

JCDPHZ1

MOV26H,@R0

INCR0

MOV24H,R6;ASCII码显示

MOV25H,R5

LCALLPRASCII

SJMPPRHZ4

DPHZ1:MOV24H,@R0;是汉字则将机内码送24H25H

INCR0

MOV25H,@R0

INCR0

MOVA,25H

CLRC

SUBBA,#0A1H;机内码转换为二进制的区码和位码

MOV25H,A

MOVA,24H

CLRC

SUBBA,#0A1H

LCALLDPONHZ;显示1个汉字

DEC1DH

INCR5

PRHZ4:INCR5

DJNZ1DH,PRHZ5

POPDPL

POPDPH

RET

PR0:MOVDPTR,#LCDCOM;读状态

MOVXA,@DPTR

RET

PR01:LCALLPR0;读、写一数据前

JNBACC.0,PR01

JNBACC.1,PR01

RET

PR02:LCALLPR0;连续读前

JNBACC.2,PR02

RET

PR03:LCALLPR0;连续写前

JNBACC.3,PR02

RET

PR1:LCALLPR01;双字节参数R2,R3

MOVA,R2

LCALLPR14

PR11:LCALLPR01;单字节参数R3

MOVA,R3

LCALLPR14

PR12:LCALLPR01;无参数指令R4

MOVA,R4

SJMPPR15

PR14:MOVDPTR,#LCDDAT

PR15:MOVX@DPTR,A

RET

RL245:MOVR7,#5;24H25H左移5

RLL1:CLRC

MOVA,25H

RLCA

MOV25H,A

MOVA,24H

RLCA

MOV24H,A

DJNZR7,RLL1

RET

;行位置R6(0~7),列位置R5(0~29),汉字区别24H,位码25H

DPONHZ:MOVA,24H;显示1个汉字

MOVB,#94;每区94个汉字

MULAB

ADDA,25H

MOV25H,A

CLRA

ADDCA,B

MOV24H,A

RRA;获得32KB为1页的页号

RRA

ORLA,#0F0H

MOVP1,A;页号送P1口

LCALLRL245;汉字序号乘以32

SETB24H,7;因为存储器位于单片机系统的7FFFH~0FFFFH

MOVDPH,24H

MOVDPL,25H

MOVR2,#32;在该位置连续取出32个字节

MOVR1,#0C0H

DPHZ2:MOVXA,@DPTR

INCDPTR

MOV@R1,A

INCR1

DJNZR2,DPHZ2

MOVR1,#0C0H

MOVA,R6;根据行列位置计算LCD指针

MOVB,#16

MULAB

MULB,#30

MULAB

ADDA,R5

MOV25H,A

MOVR2,A

CLRA

ADDCA,B

MOV24H,A

MOVR3,A

MOV26H,#16;将取出的点阵送LCD显示

PRHZ6:MOVR4,#24H

LCALLPR1;双字节参数R2,R3

MOVA,@R1

MOVR3,A

INCR1

MOVR4,#0C0H

LCALLPR11;单字节参数R3

MOVA,@R1

MOVR3,A

INCR1

MOVR4,#0C0H

LCALLPR11

MOVA,#30

ADDA,25H

MOVR2,A

CLRA

ADDCA,24H

MOVR3,A

MOV24H,A

DJNZ26H,PRHZ6

RET

注:由于以上程序直接引自下面的应用实例,调用以上程序时请让寄存器组位于第2区,即R0对应10H。

三、应用实例

我们应用本文介绍的方法成功地进行了某医疗仪器的设计。该设计要求具有完整的中、英文字符提示和汉字处方显示,并尽可能地为今后的功能扩展和处方修改留有余地。目前仪器中用到的汉字约1200个,语句行为1300行左右,而且用户认为利用工控PC机设计成本过高,要求尽可能地降低成本。显然,对于该系统利用传统的汉字处理方式进行设计虽然能节省一定的存储空间,但庞大的汉字和语句重新编码工作却让人望而生畏,而且当处方修改须要用到新的汉字时相当麻烦。我们利用8031单片机系统和本文介绍的方法进行设计,整个硬件电路和底层程序设计只用了1周的时间,大大地缩短了开周期。而且由于本系统可调用所有的ASCII码和全部汉字库,所以对于功能的扩展和处方的修改十分方便。