12864液晶的中文资料
一、 概述
二、 带中文字库的128X64是一种具有4位/8位并行、2线或3线串行多种接口方式,内部含有国标一级、二级简体中文字库的点阵图形液晶显示模块;其显示分辨率为128×64, 内置8192个16*16点汉字,和128个16*8点ASCII字符集.利用该模块灵活的接口方式和简单、方便的操作指令,可构成全中文人机交互图形界面。可以显示8×4行16×16点阵的汉字. 也可完成图形显示.低电压低功耗是其又一显著特点。由该模块构成的液晶显示方案与同类型的图形点阵液晶显示模块相比,不论硬件电路结构或显示程序都要简洁得多,且该模块的价格也略低于相同点阵的图形液晶模块。
三、 基本特性:
(1)、低电源电压(VDD:+3.0--+5.5V)(2)、显示分辨率:128×64点(3)、内置汉字字库,提供8192个16×16点阵汉字(简繁体可选) (4)、内置 128个16×8点阵字符 (5)、2MHZ时钟频率(6)、显示方式:STN、半透、正显 (7)、驱动方式:1/32DUTY,1/5BIAS (8)、视角方向:6点(9)、背光方式:侧部高亮白色LED,功耗仅为普通LED的1/5—1/10 (10)、通讯方式:串行、并口可选(11)、内置DC-DC转换电路,无需外加负压 (12)、无需片选信号,简化软件设计(13)、工作温度: 0℃ - +55℃ ,存储温度: -20℃ - +60℃
模块接口说明:
*注释1:如在实际应用中仅使用串口通讯模式,可将PSB接固定低电平,也可以将模块上的J8和“GND”用焊锡短接。
*注释2:模块内部接有上电复位电路,因此在不需要经常复位的场合可将该端悬空。
*注释3:如背光和模块共用一个电源,可以将模块上的JA、JK用焊锡短接。
2.2并行接口
管脚号 | 管脚名称 | 电平 | 管脚功能描述 |
1 | VSS | 0V | 电源地 |
2 | VCC | 3.0+5V | 电源正 |
3 | V0 | - | 对比度(亮度)调整 |
4 | RS(CS) | H/L | RS=“H”,表示DB7——DB0为显示数据 RS=“L”,表示DB7——DB0为显示指令数据 |
5 | R/W(SID) | H/L | R/W=“H”,E=“H”,数据被读到DB7——DB0 R/W=“L”,E=“H→L”, DB7——DB0的数据被写到IR或DR |
6 | E(SCLK) | H/L | 使能信号,高电平有效,下降沿锁存 |
7 | DB0 | H/L | 三态数据线 |
8 | DB1 | H/L | 三态数据线 |
9 | DB2 | H/L | 三态数据线 |
10 | DB3 | H/L | 三态数据线 |
11 | DB4 | H/L | 三态数据线 |
12 | DB5 | H/L | 三态数据线 |
13 | DB6 | H/L | 三态数据线 |
14 | DB7 | H/L | 三态数据线 |
15 | PSB | H/L | H:8位或4位并口方式,L:串口方式(见注释1) |
16 | NC | - | 空脚 |
17 | /RESET | H/L | 复位端,低电平有效(见注释2) |
18 | VOUT | - | LCD驱动电压输出端 |
19 | A | VDD | 背光源正端(+5V)(见注释3) |
20 | K | VSS | 背光源负端(见注释3) |
*注释1:如在实际应用中仅使用并口通讯模式,可将PSB接固定高电平,也可以将模块上的J8和“VCC”用焊锡短接。
*注释2:模块内部接有上电复位电路,因此在不需要经常复位的场合可将该端悬空。
*注释3:如背光和模块共用一个电源,可以将模块上的JA、JK用焊锡短接。
四.模块主要硬件构成说明
控制器接口信号说明:
1、RS,R/W的配合选择决定控制界面的4种模式:
RS | R/W | 功能说明 |
L | L | MPU写指令到指令暂存器(IR) |
L | H | 读出忙标志(BF)及地址记数器(AC)的状态 |
H | L | MPU写入数据到数据暂存器(DR) |
H | H | MPU从数据暂存器(DR)中读出数据 |
2、E信号
E状态 | 执行动作 | 结果 |
高——>低 | I/O缓冲——>DR | 配合/W进行写数据或指令 |
高 | DR——>I/O缓冲 | 配合R进行读数据或指令 |
低/低——>高 | 无动作 |
|
● 忙标志:BF BF标志提供内部工作情况.BF=1表示模块在进行内部操作,此时模块不接受外部指令和数据.BF=0时,模块为准备状态,随时可接受外部指令和数据.利用STATUS RD 指令,可以将BF读到DB7总线,从而检验模块之工作状态.
● 字型产生ROM(CGROM) 字型产生ROM(CGROM)提供8192个此触发器是用于模块屏幕显示开和关的控制。DFF=1为开显示(DISPLAY ON),DDRAM 的内容就显示在屏幕上,DFF=0为关显示(DISPLAY OFF)。DFF 的状态是指令DISPLAY ON/OFF和RST信号控制的。
● 显示数据RAM(DDRAM)模块内部显示数据RAM提供64×2个位元组的空间,最多可控制4行16字(64个字)的中文字型显示,当写入显示数据RAM时,可分别显示CGROM(字库字?)与CGRAM(自定义字)的字型;此模块可显示三种字型,分别是半角英数字型(16*8)、CGRAM字型及CGROM的中文字型,三种字型的选择,由在DDRAM中写入的编码选择?,在0000H—0006H的编码中(其代码分别是0000、0002、0004、0006共4个)将选择CGRAM的自定义字型,02H—7FH的编码中将选择半角英数字的字型,至于A1以上的编码将自动的结合下一个位元组,组成两个位元组的编码形成中文字型的编码BIG5(A140—D75F),GB(A1A0-F7FFH)。
● 字型产生RAM(CGRAM) 字型产生RAM提供图象定义(造字)功能, 可以提供四组16×16点的自定义图象空间,使用者可以将内部字型没有提供的图象字型自行定义到CGRAM中,便可和CGROM中的定义一样地通过DDRAM显示在屏幕中。
● 地址计数器AC地址计数器是用来贮存DDRAM/CGRAM之一的地址,它可由设定指令暂存器来改变,之后只要读取或是写入DDRAM/CGRAM的值时,地址计数器的值就会自动加一,当RS为“0”时而R/W为“1”时,地址计数器的值会被读取到DB6——DB0中。
光标/闪烁控制电路
此模块提供硬体光标及闪烁控制电路,由地址计数器的值来指定DDRAM中的光标或闪烁位置。
五、指令说明
模块控制芯片提供两套控制命令,基本指令和扩充指令如下:
指令表1:(RE=0:基本指令)
指 | 指 令 码 | 功 能 | |||||||||
令 | RS | R/W | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
|
清除 显示 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 将DDRAM填满"20H",并且设定DDRAM的地址计数器(AC)到"00H" |
地址 归位 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | X | 设定DDRAM的地址计数器(AC)到"00H",并且将游标移到开头原点位置;这个指令不改变DDRAM 的内容 |
显示状态开/关 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | D | C | B | D=1: 整体显示 ON C=1: 游标ON B=1:游标位置反白允许 |
进入点 设定 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | I/D | S | 相当于1602输入模式控制字,设定游标的移动方向及指定显示的移位 I/D=1右移,S=1文字移动有效 |
游标或显示移位控制 | 0 | 0 | 0 | 0 | 0 | 1 | S/C | R/L | X | X | 设定游标的移动与显示的移位控制位;这个指令不改变DDRAM 的内容 |
功能 设定 | 0 | 0 | 0 | 0 | 1 | DL | X | RE | X | X | DL=0/1:4/8位数据 RE=1: 扩充指令操作,图形方式 RE=0: 基本指令操作 |
设定CGRAM 地址 | 0 | 0 | 0 | 1 | AC5 | AC4 | AC3 | AC2 | AC1 | AC0 | 设定CGRAM 地址 |
设定DDRAM 地址 | 0 | 0 | 1 | 0 | AC5 | AC4 | AC3 | AC2 | AC1 | AC0 | 设定DDRAM 地址(显示位址) 第一行:80H-87H,三行88H~8FH 第二行:90H-97H,四行98H~9FH |
读取忙标志和地址 | 0 | 1 | BF | AC6 | AC5 | AC4 | AC3 | AC2 | AC1 | AC0 | 读取忙标志(BF)可以确认内部动作是否完成,同时可以读出地址计数器(AC)的值,BF=1,忙 |
写数据到RAM | 1 | 0 | 数据 | 将数据D7——D0写入到内部的RAM (DDRAM/CGRAM/IRAM/GRAM) | |||||||
读出RAM的值 | 1 | 1 | 数据 | 从内部RAM读取数据D7——D0 (DDRAM/CGRAM/IRAM/GRAM) |
指令表2:(RE=1:扩充指令)
指 | 指 令 码 | 功 能 | |||||||||
令 | RS | R/W | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
|
待命 模式 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 进入待命模式,执行其他指令都棵终止 待命模式 |
卷动地址开关开启 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | SR | SR=1:允许输入垂直卷动地址 SR=0:允许输入IRAM和CGRAM地址 |
反白 选择 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | R1 | R0 | 选择2行中的任一行作反白显示,并可决定反白与否。初始值R1R0=00,第一次设定为反白显示,再次设定变回正常 |
睡眠 模式 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | SL | X | X | SL=0:进入睡眠模式 SL=1:脱离睡眠模式 |
扩充 功能 设定 | 0 | 0 | 0 | 0 | 1 | CL | X | RE | G | 0 | CL=0/1:4/8位数据 RE=1: 扩充指令操作 RE=0: 基本指令操作 G=1/0:绘图开关 |
设定绘图RAM 地址 | 0 | 0 | 1 | 0 AC6 | 0 AC5 | 0 AC4 | AC3 AC3 | AC2 AC2 | AC1 AC1 | AC0 AC0 | 设定绘图RAM 先设定垂直(列)地址AC6AC5…AC0 再设定水平(行)地址AC3AC2AC1AC0 将以上16位地址连续写入即可 |
备注:当IC1在接受指令前,微处理器必须先确认其内部处于非忙碌状态,即读取BF标志时,BF需为零,方可接受新的指令;如果在送出一个指令前并不检查BF标志,那么在前一个指令和这个指令中间必须延长一段较长的时间,即是等待前一个指令确实执行完成。
应用举例:
1、使用前的准备:先给模块加上工作电压,再按照下图的连接方法调节LCD的对比度,使其显示出黑色的底影。此过程亦可以初步检测LCD有无缺段现象。
2、字符显示:带中文字库的128X64-0402B每屏可显示4行8列共32个16×16点阵的汉字,每个显示RAM可显示1个中文字符或2个16×8点阵全高ASCII码字符,即每屏最多可实现32个中文字符或64个ASCII码字符的显示。带中文字库的128X64-0402B内部提供128×2字节的字符显示RAM缓冲区(DDRAM)。字符显示是通过将字符显示编码写入该字符显示RAM实现的。根据写入内容的不同,可分别在液晶屏上显示CGROM(中文字库)、HCGROM(ASCII码字库)及CGRAM(自定义字形)的内容。三种不同字符/字型的选择编码范围为?:0000~0006H(其代码分别是0000、0002、0004、0006共4个,只能定义4个字型?见ST7929_CN.FGF资料)显示自定义字型,02H~7FH显示半宽ASCII码字符,A1A0H~F7FFH显示8192种GB2312中文字库字形。
(1)通过字库显示汉字及字符(显示CGROM(中文字库)、HCGROM(ASCII码字库))
字符显示RAM在液晶模块中的地址80H~9FH。字符显示的RAM的地址与32个字符显示区域有着一一对应的关系,其对应关系如下表所示。
80H | 81H | 82H | 83H | 84H | 85H | 86H | 87H |
90H | 91H | 92H | 93H | 94H | 95H | 96H | 97H |
88H | 89H | 8AH | 8BH | 8CH | 8DH | 8EH | 8FH |
98H | 99H | 9AH | 9BH | 9CH | 9DH | 9EH | 9FH |
第一行的起始地址是80H,第8个字符的地址是87H
第二行的起始地址是90H,…
1 0 AC5 AC4 AC3 AC2 AC1 AC0
1行 0 0 0 80H-87H
2行 0 1 0 90H-97H
3行 0 0 1 88H-8FH
4行 0 1 1 98H-9FH
一行可以显示8个16*16的中文汉字,或者16*8的16个英文字母,汉字字母可混先。
例:若要在第一行的第二个位置显示字符串“学习ABC”
A.设定DDRAMD地址指令0x80+1=0x81,确定起始地址
B.然后采用写数据,将字串连续逐个写入“学习ABC”
(2)显示自定义的字符
A.定义一个数组(code)存放自定义的点阵
B.功能设定选择8bit数据流,命令:0x30
C. 选择CGRAM的地址00,命令:0x40, 0100 0000
D.将数组数据连续写入CGRAM中
E.选择根据字符显示的起始位置,确定DDRAM的地址,设定DDRAMD地址指
令。
F.再通过写数据DATA , Write_Data(00)
3 、图形显示
先设垂直地址再设水平地址(连续写入两个字节的数据来完成垂直与水平的坐标地址)
(1)设置图形显示的工作模式,8位并行,RE=1,0x36,0x34
(2)设置上半页起始垂直地址,0x80+i,i=0-31,半页共32行,第一行i=0
(3)设置上半页水平地址范围0x80-0x87, 一共8*16=128位,水平位置的选择只能是16位一个单位的增加?见图表
(4)连续写入16个字节(指针AC会自动加1直到0F),写入的是第一行的数据点阵16*8=128位,再将垂直地址i+1写第二行的数据。………,如果写入的数据的字节数大于(8-i)*2,垂直地址会自动加88+1=88,则后面的数据将自动换到下半屏显示?。
(5)设置下半页起始垂直地址,0x80+i,i=0-31,半页共32行
(6)设置下半页水平地址范围0x88-0x8F
(7)连续写入16个字节,写入的是第一行的数据点阵,再将垂直地址i+1写第二行的数据。………
注意:如果没有写新字符的屏幕要写入空白,不然会显示以前的内容。图形和字符方式选择一种,不能混显。图形模式要全屏输出数据,否则每数据的部分显乱码。
绘图RAM 的地址计数器(AC)只会对水平地址(X 轴)自动加一,当水平地址=0FH 时会重新设为00H 但并不会对垂直地址做进位自动加一,故当连续写入多笔资料时,程序需自行判断垂直地址是否需重新设定。GDRAM的坐标地址与资料排列顺序如下图:
图形显示举例:
A.设置功能字命令,选择图形方式RE=1,8位并行, 0x34,0x36?
B.
128*64点阵
|
垂直地址 80 81
80+32 |
水平地址 80 |
水平地址 87 |
上半屏 |
|
水平地址 88 |
水平地址 8F |
下半屏 |
垂直地址 80 81
80+32 |
4、应用说明
用带中文字库的128X64显示模块时应注意以下几点:
①欲在某一个位置显示中文字符时,应先设定显示字符位置,即先设定显示地址,再写入中文字符编码。
②显示ASCII字符过程与显示中文字符过程相同。不过在显示连续字符时,只须设定一次显示地址,由模块自动对地址加1指向下一个字符位置,否则,显示的字符中将会有一个空ASCII字符位置。
③当字符编码为2字节时,应先写入高位字节,再写入低位字节。
④模块在接收指令前,向处理器必须先确认模块内部处于非忙状态,即读取BF标志时BF需为“0”,方可接受新的指令。如果在送出一个指令前不检查BF标志,则在前一个指令和这个指令中间必须延迟一段较长的时间,即等待前一个指令确定执行完成。指令执行的时间请参考指令表中的指令执行时间说明。⑤“RE”为基本指令集与扩充指令集的选择控制位。当变更“RE”后,以后的指令集将维持在最后的状态,除非再次变更“RE”位,否则使用相同指令集时,无需每次均重设“RE”位。
文章评论(0条评论)
登录后参与讨论