基于单片机和可编程逻辑器件实现LED显示屏.docx
《基于单片机和可编程逻辑器件实现LED显示屏.docx》由会员分享,可在线阅读,更多相关《基于单片机和可编程逻辑器件实现LED显示屏.docx(12页珍藏版)》请在冰豆网上搜索。
基于单片机和可编程逻辑器件实现LED显示屏
目录
基于单片机和可编程逻辑器件实现LED显示屏1
51单片机汇编语言教程:
23课:
LED数码管静态显示接口与编程6
基于单片机和可编程逻辑器件实现LED显示屏
0引言
LED显示屏主要由电流驱动电路及LED点阵阵列、控制系统和PC端管理软件三部分构成(图1)。
控制系统负责接收、转换和处理各种外部信号,并实现扫描控制,然后驱动LED点阵显示需要的文字或图案。
控制系统作为LED显示屏的核心部分,直接决定了显示屏的显示效果和性能的优劣。
本文详细分析采用VerilogHDL对ATF1508AS进行编程,实现双口RAM访问和产生LED点阵驱动电路所需的各种时序信号。
1 LED显示屏的基本结构及关键技术
本系统设计中,控制系统采用单片机+CPLD的方案来实现,整个控制系统可分为:
信号接收及处理模块和CPLD的扫描控制模块和LED点阵驱动模块,如图1所示。
本系统的关键技术是使用双口RAM和CPLD芯片,解决LED显示屏中高速数据传输和快速扫描控制的难题,大大提高了动态显示的刷新率。
信号接收与处理模块的功能是AT89S52单片机通过串口接收PC送来的点阵信息,同时对点阵信息做各种不同的处理。
利用双口RAMIDT7007在单片机和ATF1508AS之间以共享的方式建立高速的数据交换通道。
CPLD的扫描控制模块采用ATF1508AS芯片实现。
其功能是从双口RAM读取点阵信息,串行化后送显示扫描驱动电路,同时输出各种所需的控制信号。
CPLD具有扫描速度快,延时短等特点,克服了单片机由于传输速率慢而造成在大屏幕显示时产生的闪烁效应。
2 基于CPLD的扫描控制模块的设计
2.1设计思想
本模块的功能是从存储器中读取数据,将数据输送到显示屏体上,同时产生各种控制信号。
时序产生模块由两部分构成,一是产生访问双口RAM的时序,二是产生LED显示屏接口所需的各种信号。
硬件电路我们采用较常见的CPLD芯片ATF1508来实现控制系统中的时序产生部分。
CPLD是一种具有丰富的可变成I/O引脚的可编程逻辑器件,不仅可以实现常规的逻辑器件功能,还可以实现复杂而独特的时序逻辑功能。
软件我们采用VerilogHDL语言来进行设计。
VerilogHDL是用于逻辑设计的硬件描述语言,已成为IEEE标准。
利用VerilogHDL语言对ATF1508AS进行编程,实现扫描控制模块所需的功能。
扫描控制部分的原理电路如图2所示,ATF1508AS是核心部分,需要根据系统需要定义ATF1508AS的各个I/O端口,下面是I/O端口定义和内部寄存器定义的VerilogHDL语言代码。
moduleLedSequ(color,datain,addrout,CE,OE,SEMR,RWC,sdr,sdb,sck,le,oe1,cs,clk,counter);
inputclk; //系统时钟
input[7:
0]datain;//RAM数据输入
input[1:
0]color;//颜色控制
output[13:
0]addrout;//地址输出口
outputSEMR,RWC;
outputCE,OE,sdr,sdb,sck,le,oe1,cs;
output[3:
0]counter;
reg[3:
0]hcnt;//38译码器计数器
reg[7:
0]data1;//数据寄存器
reg[3:
0]counter;//38翻码器输出端
regSEMR,RWC;
regSDA,SDC;
reg[13:
0]addrout,addr;//addr地址计数器
reg[3:
0]state;//状态寄存器
reg[2:
0]shcnt; //移位脉冲读数器
regCE,OE,sdr,sdb,sck,le,oe1,cs;
reg[8:
0]byte;
parameters0=1'd0,s1=1'd1,s2=1'd2,s3=1'd3,s4=1'd4,s5=1'd5;//状态常量
2.2访问双口RAM时序的产生
IDT7007是具有32KB的双口RAM电路,与ATF1508AS的连接电路如图2所示,其中:
为片选信号,为读写控制信号,为输出使能信号,A0R-A13R为右端口地址总线,D0R-D7R为右端口数据总线,其右端口读写时序如图4所示。
我们采用有限状态机实现,其基本工作原理是:
S0状态进行初始化,S1状态时ATF1508AS首先输出地址信号addrout,然后置相有效,S2状态读取双口RAM的数据,并存储到内容寄存器datain中,从而完成双口RAM的读数据过程。
下面给出ATF1508AS读取双口RAM数据的主要代码:
always@(posedgeclk)
begin//每个时钟周期,状态变化一次
case(state)
s0:
begin //初始化状态
CE=1'b0; //IDT7007片选
OE=1'b1; //IDT7007读选通
le=1'b0;
oe1=1'b0;
cs =1'b0;
addr=14'b0;
SEMR=1'b1; //IDT7007置1有
RWC=1'b1; //写控制1
hcnt=4'b0000;
counter=4'b0000;
state=s1;
end
s1:
begin //输出RAM地址
CE=1'b0;
addrout=addr;//输出地址
OE=1'b0;
SEMR=1'b1;
RWC=1'b1;
shcnt=3'b000;
state=s2;
end
s2:
begin//读双口RAM数据
oe1=1'b0;
data1=datain;
state=s3;
end
……(显示扫描及LED驱动代码部分)
endcase
end
2.3 LED显示驱动时序信号的产生
CPLD与LED点阵的驱动电路接口如图 所示,其中:
CS为3-8译码器片选信号;OE为BMI5026输出使能信号,控制LED点阵是否能被点亮;LE为驱动芯片数据锁存信号;sck为移位脉冲,将CPLD串行输出的红绿数据串行移入MBI5026(移位寄存器);A-D为双3-8译码器构成的4-16译码器的数据输入,实现显示行选通控制;sdr为红数据信号线;sdb为绿数据信号线。
其工作过程为:
S3状态,sck脉冲置0,sdr和sdb分别输出一位数据;S4状态时,sck置1,红和绿数据分别移入相应移位寄存器BMI5026,若不足8位时,返回S3状态,若不足一行时,返回S1状态,读下一个字节,若完成一行数据移位过程,则转S5状态;S5状态时,置le为0,将BMI5026的缓冲寄存中一个显示行的点阵数据送输出寄存器,同时置cs1有效,控制第hcnt行的点阵显示,然后判断一屏内容是否显示完成,返回s1状态。
图4为完整的有限状态机的状态图。
下面给出LED显示屏体驱动时序信号对应的VerilogHDL程序代码:
s3:
begin
sck=1'b0;
sdr=SDA&&color[0];
sdb=SDC&&color[1];
OE=1'b1;CE=1'b1;
state=s4;
end
s4:
begin//移位输出到LED显示屏
sck=1'b1;
shcnt=shcnt+1'b1;
if(shcnt==0)
begin
addr=addr+1'b1;//读完一个字节地址记数器加1
byte=byte+8'b1;
if(byte==nrow)//如果读完一行数据
begin
oe1=1'b1;//关LED显示
cs=1'b1;
le=1'b0;//驱动芯片写入数据
byte=8'b0;
state=s5;//读完一行数据则显示
end
elsestate=s1;
end
elsestate=s3;//当前字节移位输出
end
s5:
begin
sck=1'b0;
le=1'b0;
counter=hcnt;
OE=1'b1;
CE=1'b0;
if(addr==nscreen)
addr=0;
oe1=1'b0;
cs=1'b0;
state=s1;
end
4系统测试及仿真
系统的开发调试环境是:
单片机部分在KeilC51下调试,CPLD部分在Maxplus10下调试。
LED显示屏的扫描控制模块的VerilogHDL源程序编写完成后,在ALTERA公司Maxplus10可以先进行软件仿真,以观察各信号是否符合硬件电路所需的时序要求。
图5为扫描模块CLPD仿真结果,符合设计要求。
通过JTAG接口下载到ATF1508AS后,系统工作正常。
51单片机汇编语言教程:
23课:
LED数码管静态显示接口与编程
2010-02-2718:
56
在单片机系统中,常常用LED数码数码管显示器来显示各种数字或符号。
由于它具有显示清晰、亮度高、使用电压低、寿命长的特点,因此使用非常广泛。
引言:
还记得我们小时候玩的“火柴棒游戏”吗,几根火柴棒组合起来,能拼成各种各样的图形,LED数码管显示器实际上也是这么一个东西。
八段LED数码管显示器
<单片机静态显示接口>
八段LED数码管显示器由8个发光二极管组成。
基中7个长条形的发光管排列成“日”字形,另一个贺点形的发光管在数码管显示器的右下角作为显示小数点用,它能显示各种数字及部份英文字母。
LED数码管显示器有两种不一样的形式:
一种是8个发光二极管的阳极都连在一起的,称之为共阳极LED数码管显示器;另一种是8个发光二极管的阴极都连在一起的,称之为共阴极LED数码管显示器。
如下图所示。
`
共阴和共阳结构的LED数码管显示器各笔划段名和安排位置是相同的。
当二极管导通时,对应的笔划段发亮,由发亮的笔划段组合而显示的各种字符。
8个笔划段hgfedcba对应于一个字节(8位)的D7D6D5D4D3D2D1D0,于是用8位二进制码就能表示欲显示字符的字形代码。
例如,对于共阴LED数码管显示器,当公共阴极接地(为零电平),而阳极hgfedcba各段为0111011时,数码管显示器显示"P"字符,即对于共阴极LED数码管显示器,“P”字符的字形码是73H。
如果是共阳LED数码管显示器,公共阳极接高电平,显示“P”字符的字形代码应为10001100(8CH)。
这里必须注意的是:
很多产品为方便接线,常不按规则的办法去对应字段与位的关系,这个时候字形码就必须根据接线来自行设计了,后面我们会给出一个例程。
在单片机应用系统中,数码管显示器显示常用两种办法:
静态显示和动态扫描显示。
所谓静态显示,就是每一个数码管显示器都要占用单独的具有锁存功能的I/O接口用于笔划段字形代码。
这样单片机只要把要显示的字形代码发送到接口电路,就不用管它了,直到要显示新的数据时,再发送新的字形码,因此,使用这种办法单片机中CPU的开销小。
能供给单独锁存的I/O接口电路很多,这里以常用的串并转换电路74LS164为例,介绍一种常用静态显示电路,以使大家对静态显示有一定的了解。
MCS-51单片机串行口方式押为移们寄存器方式,外接6片74LS164作为6位LED数码管显示器的静态显示接口,把8031的RXD作为数据输出线,TXD作为移位时钟脉冲。
74LS164为TTL单向8位移位寄存器,可实现串行输入,并行输出。
其中A、B(第1、2脚)为串行数据输入端,2个管脚按逻辑与运算规律输入信号,公一个输入信号时可并接。
T(第8脚)为时钟输入端,可连接到串行口的TXD端。
每一个时钟信号的上升沿加到T端时,移位寄存器移一位,8个时钟脉冲过后,8位二进制数全部移入74LS164中。
R(第9脚)为复位端,当R=0时,移位寄存器各位复0,只有当R=1时,时钟脉冲才起作用。
Q1…Q8(第3-6和10-13管脚)并行输出端分别接LED数码管显示器的hg---a各段对应的管脚上。
关于74LS164还能作如下的介绍:
所谓时钟脉冲端,其实就是需要高、低、高、低的脉冲,不管这个脉冲是怎么来的,比如,我们用根电线,一端接T,一端用手拿着,分别接高电平、低电平,那也是给出时钟脉冲,在74LS164获得时钟脉冲的瞬间(再讲清楚点,是在脉冲的沿),如果数据输入端(第1,2管脚)是高电平,则就会有一个1进入到74LS164的内部,如果数据输入端是低电平,则就会有一个0进入其内部。
在给出了8个脉冲后,最先进入74LS164的第一个数据到达了最高位,然后再来一个脉冲会有什么发生呢?
再来一个脉冲,第一个脉冲就会从最高位移出,就象车站排队买票,栏杆就那么长,要从后面进去一本人,前面必须要从前面走出去一本人才行。
搞清了这一点,下面让我们来看电路,6片7LS164首尾相串,而时钟端则接在一起,这样,当输入8个脉冲时,从单片机RXD端输出的数据就进入到了第一片74LS164中了,而当第二个8个脉冲到来后,这个数据就进入了第二片74LS164,而新的数据则进入了第一片74LS164,这样,当第六个8个脉冲完成后,首次送出的数据被送到了最左面的164中,其他数据依次出现在第一、二、三、四、五片74LS164中。
有个问题,在第一个脉冲到来时,除了第一片74LS164中接收数据外,其他各片在干吗呢?
它们也在接收数据,因为它们的时钟端都是被接在一起的,可是数据还没有送到其他各片呢,它们在接收什么数据呢?
。
。
。
。
。
。
其实所谓数据不过是一种说法而已,实际就是电平的高低,当第一个脉冲到来时,第一片164固然是从单片机接收数据了,而其它各片也接到前一片的Q8上,而Q8是一根电线,在数字电路中它只可能有两种状态:
低电平或高电平,也就是“0”和“1”。
所以它的下一片74LS164也相当于是在接收数据啊。
只是接收的全部是0或1而已。
这个问题放在这儿说明,可能有朋友不屑一顾,而有的朋友可能还是不清楚,这实际上涉及到数的本质的问题,如果不懂的,请仔细思考,并找一些数字电路的数,理解164的工作原理,再来看这个问题,或者去看看我的另一篇文章《27课:
关于单片机的一些基本概念》的文章。
务必搞懂,搞懂了这一点,你的级别就高过开始学习者,可谓入门者了。
入口:
把要显示的数分别放在显示缓冲区60H-65H共6个单元中,并且分别对应各个数码管LED0-LED5。
出口:
将预置在显示缓冲区中的6个数成对应的显示字形码,然后输出到数码管显示器中显示。
单片机led显示程序如下:
DISP:
MOVSCON,#00H;初始化串行口方式0
MOVR1,#06H;显示6位数
MOVR0,#65H;60H-65H为显示缓冲区
MOVDPTR,#SEGTAB;字形表的入口地址
LOOP:
MOVA,@R0;取最高位的待显示数据
MOVCA,@A+DPTR;查表获取字形码
MOVSBUF,A;送串行口显示
DELAY:
JNBTI,DELAY;等待发送完毕
CLRTI;清发送标志
DECR0;指针下移一位,准备取下一个待显示数
DJNZR1,LOOP;直到6个数据全显示完。
RET
SETTAB:
;字形表,前面有介绍,以后我们再介绍字形表的制作。
DB03H9FH27H0DH99H49H41H1FH01H09H0FFH
;0123456789消隐码
单片机显示测试用主程序
ORG0000H
AJMPSTART
ORG30H
START:
MOVSP,#6FH
MOV65H,#0
MOV64H,#1
MOV63H,#2
MOV62H,#3
MOV61H,#4
MOV60H,#5
LCALLDISP
SJMP$
如果按图示数码管排列,则以上主程序将显示的是543210,想想看,如果要显示012345该怎样送数?
下面我们来分析一下字形表的制作问题。
先就上述“标准”的图形来看吧。
写出数据位和字形的对应关系并列一个表如下(设为共阳型,也就是对应的输出位为0时笔段亮)
如何,字形表会做了吧,就是这样列个表格,根据要求(0亮或1亮)写出对应位的0和1,就成了。
做个练习,写出A-F的字形码吧。
如果为了接线方便而打乱了接线的次序,那么字形表又该如何接呢?
也很简单,一样地列表啊。
以新实验板为例,共阳型。
接线如下:
P0.7P0.6P0.5P0.4P0.3P0.2P0.1P0.0
CEHDGFAB
则字形码如下所示:
;00010100028H
;1011111107EH
;2101001000A4H
;30110010064H
;40111001072H
;50110000161H
;60010000121H
;7011111007CH
;80010000020H
;90110000060H
作为练习,大家写出A-F的字形代码。
本来这里是讲解单片机数码管显示器的静态接口的,到此应当可算结束了,但是我还想接着上面讲到的数的本质的问题再谈一点。
单片机中有一些术语、名词本来是帮助我们理解事物的,但有时我们会被这些术语的相关语义所迷惑,以致不能进一步认清他们的本质,由此一般陷入困惑的境界。
只有深入地了解了74LS164的工作特性,才能真正理解何谓串行的数据。
有兴趣的朋友还能再看看我网站查找相关内容