实例解说1602字符液晶显示 解Word文件下载.docx
- 文档编号:21628558
- 上传时间:2023-01-31
- 格式:DOCX
- 页数:15
- 大小:557.10KB
实例解说1602字符液晶显示 解Word文件下载.docx
《实例解说1602字符液晶显示 解Word文件下载.docx》由会员分享,可在线阅读,更多相关《实例解说1602字符液晶显示 解Word文件下载.docx(15页珍藏版)》请在冰豆网上搜索。
上表中的字符代码与我们PC中的字符代码是基本一致的。
因此我们在向DDRAM写C51字符代码程序时甚至可以直接用P1='
A'
这样的方法。
PC在编译时就把“A”先转为41H代码了。
字符代码0x00~0x0F为用户自定义的字符图形RAM(对于5X8点阵的字符,可以存放8组,5X10点阵的字符,存放4组),就是CGRAM了。
后面我会详细说的。
0x20~0x7F为标准的ASCII码,0xA0~0xFF为日文字符和希腊文字符,其余字符码(0x10~0x1F及0x80~0x9F)没有定义。
那么如何对DDRAM的内容和地址进行具体操作呢,下面先说说HD44780的指令集及其设置说明,请浏览该指令集,并找出对DDRAM的内容和地址进行操作的指令。
共11条指令:
HD44780的指令集
1.清屏指令
功能:
<
1>
清除液晶显示器,即将DDRAM的内容全部填入"
空白"
的ASCII码20H;
2>
光标归位,即将光标撤回液晶显示屏的左上方;
3>
将地址计数器(AC)的值设为0。
2.光标归位指令
把光标撤回到显示器的左上方;
把地址计数器(AC)的值设置为0;
保持DDRAM的内容不变
3.进入模式设置指令
设定每次定入1位数据后光标的移位方向,并且设定每次写入的一个字符是否移动。
参数设定的情况如下所示:
位名
设置
I/D
0=写入新数据后光标左移
1=写入新数据后光标右移
S
0=写入新数据后显示屏不移动
1=写入新数据后显示屏整体右移1个字
4.显示开关控制指令
控制显示器开/关、光标显示/关闭以及光标是否闪烁。
参数设定的情况如下:
D
0=显示功能关
1=显示功能开
C
0=无光标
1=有光标
B
0=光标闪烁
1=光标不闪烁
5.设定显示屏或光标移动方向指令
使光标移位或使整个显示屏幕移位。
S/C
R/L
设定情况
0
0
光标左移1格,且AC值减1
1
光标右移1格,且AC值加1
1
显示器上字符全部左移一格,但光标不动
显示器上字符全部右移一格,但光标不动
6.功能设定指令
设定数据总线位数、显示的行数及字型。
DL
0=数据总线为4位
1=数据总线为8位
N
0=显示1行
1=显示2行
F
0=5×
7点阵/每字符
1=5×
10点阵/每字符
7.设定CGRAM地址指令
设定下一个要存入数据的CGRAM的地址。
8.设定DDRAM地址指令
(注意这里我们送地址的时候应该是0x80+Address,这也是前面说到写地址命令的时候要加上0x80的原因)
9.读取忙信号或AC地址指令
读取忙碌信号BF的内容,BF=1表示液晶显示器忙,暂时无法接收单片机送来的数据或指令;
当BF=0时,液晶显示器可以接收单片机送来的数据或指令;
读取地址计数器(AC)的内容。
10.数据写入DDRAM或CGRAM指令一览
将字符码写入DDRAM,以使液晶显示屏显示出相对应的字符;
将使用者自己设计的图形存入CGRAM。
11.从CGRAM或DDRAM读出数据的指令一览
读取DDRAM或CGRAM中的内容。
基本操作时序:
读状态
输入:
RS=L,RW=H,E=H
输出:
DB0~DB7=状态字
写指令
RS=L,RW=L,E=下降沿脉冲,DB0~DB7=指令码
输出:
无
读数据
RS=H,RW=H,E=H
DB0~DB7=数据
写数据
RS=H,RW=L,E=下降沿脉冲,DB0~DB7=数据
呵呵,看到这么多的控制指令希望你没有头晕。
其实这么多的指令刚开始的时候没有必要全部掌握,随着学习的深入可以再尝试去用更复杂的控制指令。
下面让我们一起驱动1602的液晶吧。
下面是我的液晶的连接图,用的是那种蓝底白字的液晶,其实蓝底白字和那种绿底黑字的液晶唯一的区别就是颜色的问题,至于用哪种液晶,就看各位自己的喜好咯。
这就是我做测试用的最小系统,单片机是STC89C516,晶振为12M。
液晶为蓝底白字的那种1602。
当我们硬件连接错误,或者程序错误时就会出现下图这种情况,就是上排显示16的白色的块(蓝底黑字的液晶则显示的是16个黑块)。
下面我们来驱动1602吧在1602的上排显示“LCD1602checkok”下排显示“studyup”程序中没有用到忙检测,而是用的是延时函数来替代忙检测
#include<
reg52.h>
//包含头文件,这个嘛,就不用多说了~~
#defineuintunsignedint
//预定义一下
#defineucharunsignedchar
sbitrs=P3^5;
//1602的数据/指令选择控制线
sbitrw=P3^6;
//1602的读写控制线
sbiten=P3^7;
//1602的使能控制线
/*P2口接1602的D0~D7,注意不要接错了顺序,我以前可在这上面吃过亏~*/
ucharcodetable[]="
LCD1602checkok"
;
//要显示的内容1放入数组table
ucharcodetable1[]="
studyup"
//要显示的内容2放入数组table1
voiddelay(uintn)
//延时函数
{
uintx,y;
for(x=n;
x>
0;
x--)
for(y=110;
y>
y--);
}
/*********************************************************************************/
●voidlcd_wcom(ucharcom)
//1602写命令函数
(单片机给1602写命令)
{//1602接收到命令后,不用存储,直接由HD44780执行并产生相应动作
rs=0;
//选择指令寄存器
rw=0;
//选择写
P2=com;
//把命令字送入P2
delay(5);
//延时一小会儿,让1602准备接收数据
en=1;
//使能线电平变化,命令送入1602的8位数据口
en=0;
voidlcd_wdat(uchardat)
//1602写数据函数
rs=1;
//选择数据寄存器
//选择写
P2=dat;
//把要显示的数据送入P2
//使能线电平变化,数据送入1602的8位数据口
voidlcd_init()
//1602初始化函数
lcd_wcom(0x38);
//8位数据,双列,5*7字形
lcd_wcom(0x0c);
//开启显示屏,关光标,光标不闪烁
lcd_wcom(0x06);
//显示地址递增,即写一个数据后,显示位置右移一位
lcd_wcom(0x01);
//清屏
voidmain()
//主函数
{
ucharn,m=0;
lcd_init();
//液晶初始化
lcd_wcom(0x80);
//显示地址设为80H(即00H,)上排第一位(也是执行一条命令)
for(m=0;
m<
16;
m++)
//将table[]中的数据依次写入1602显示
lcd_wdat(table[m]);
delay(200);
lcd_wcom(0x80+0x44);
//重新设定显示地址为0xc4,即下排第5位
for(n=0;
n<
8;
n++)
//将table1[]中的数据依次写入1602显示
lcd_wdat(table1[n]);
delay(200);
while
(1);
//动态停机
程序写好后烧写进单片机,现在让我们看看效果吧
这就是显示的效果。
下面让我们来看看如何显示一个自定义的字符吧
我们从CGROM表上可以看到,在表的最左边是一列可以允许用户自定义的CGRAM,从上往下看着是16个,实际只有8个字节可用。
它的字符码是00000000-00000111这8个地址,表的下面还有8个字节,但因为这个CGRAM的字符码规定0-2位为地址,3位无效,4-7全为零。
因此CGRAM的字符码只有最后三位能用也就是8个字节了。
等效为0000X111,X为无效位,最后三位为000-111共8个。
如果我们要想显示这8个用户自定义的字符,操作方法和显示CGROM的一样,先设置DDRAM位置,再向DDRAM写入字符码,例如“A”就是41H。
现在我们要显示CGRAM的第一个自定义字符,就向DDRAM写入00000000B(00H),如果要显示第8个就写入00000111(08H),简单吧!
好!
现在我们来看怎么向这八个自定义字符写入字模。
有个设置CGRAM地址的指令大家还记得吗?
赶快再找出来看看。
从这个指令可以看出指令数据的高2位已固定是01,只有后面的6位是地址数据,而这6位中的高3位就表示这八个自定义字符,最后的3位就是字模数据的八个地址了。
例如第一个自定义字符的字模地址为01000000-01000111八个地址。
我们向这8个字节写入字模数据,让它能显示出“℃”
地址:
01000000 数据:
00010000
图示:
○○○■○○○○
01000001 00000110
○○○○○■■○
01000010 00001001
○○○○■○○■
01000011 00001000
○○○○■○○○
01000100 00001000
01000101 00001001
01000110 00000110
01000111 00000000
○○○○○○○○
下面我们写一段程序让这8个自定义字符显示出一个心的图案:
(由于上面那个显示程序已经有很详细的注释了,因此这个程序只对与上个程序不同的地方写注释)
#defineuintunsignedint
ucharcodetable[]={0x03,0x07,0x0f,0x1f,0x1f,0x1f,0x1f,0x1f,
0x18,0x1E,0x1f,0x1f,0x1f,0x1f,0x1f,0x1f,
0x07,0x1f,0x1f,0x1f,0x1f,0x1f,0x1f,0x1f,
0x10,0x18,0x1c,0x1E,0x1E,0x1E,0x1E,0x1E,
0x0f,0x07,0x03,0x01,0x00,0x00,0x00,0x00,
0x1f,0x1f,0x1f,0x1f,0x1f,0x0f,0x07,0x01,
0x1f,0x1f,0x1f,0x1f,0x1f,0x1c,0x18,0x00,
0x1c,0x18,0x10,0x00,0x00,0x00,0x00,0x00};
//心图案
/*uchar
codetable1[]={0x10,0x06,0x09,0x08,0x08,0x09,0x06,0x00};
//字符℃*/
voidlcd_wcom(ucharcom)
lcd_wcom(0x38);
lcd_wcom(0x0c);
lcd_wcom(0x06);
lcd_wcom(0x01);
voidmain()
charm=0;
lcd_wcom(0x40);
//设定CGRAM地址
64;
//将心型代码写入CGRAM中
lcd_wcom(0x85);
//设定上排的显示位置
4;
//显示心型图案的上半部分
lcd_wdat(m);
lcd_wcom(0xc5);
//将显示坐标转移到下排和上排相对应的地方
for(m=4;
//显示心型图案的下半部分
让我们一起来看看显示的效果吧~~
在绿底黑字液晶模块和蓝底白字液晶模块上分别显示的效果。
下面再为大家展示几种可能出现的问题
1:
通电之后,程序也烧写进去了,但是1602就是不显示,只显示一排黑块(一般都是在上排8个小黑块,记得刚开始用1602液晶的时候,被这个整怕了~~),怎么样,你郁闷了吧,其实出现这种问题的原因无非以下几种:
硬件连线上的错误,这种错误一般用万用表仔细检查后很容易找出来。
第二种情况就是硬件连接上是正确的,那么此时出问题最大的就是程序上了,如果你用的是忙检测,看一下忙检测函数写对了没,如果用的是延时函数,那么看看延时的时间是否够长。
再就是看看时序图,这点很重要的哦。
如果硬件和软件都没有错,那么就要考虑1602是否坏了,但是出现这种情况的几率很小,如果遇到这种情况,你可以考虑去买彩票了~~
下面这种情况你遇到过吗?
我遇到过了的,搞得我很是郁闷~~
我做的实验是要液晶显示ABC这三个字母,并且开光标,光标闪烁。
大家可以在第一排的最后几位看到ABC和光标都已经显示出来了。
但是为什么其它位会显示这么多8呢?
嘿嘿~~郁闷吧。
出现这种情况的原因就是在初始化液晶的时候,要把清屏指令放在最后面,否则就会出现上图这种情况。
怎么样,第一次听说吧~不过,我不知道其它的液晶是否也有这个问题出现,至少我用的这块就有这种情况,但是我的另一个液晶则没有这种情况出现,不管是在一开始就清屏还是最后清屏。
大家注意下就可以了,万一出现了这种情况,就会处理了~~
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 实例解说1602字符液晶显示 实例 解说 1602 字符 液晶显示