单片机LED点阵显示方法与程序代码

单片机LED点阵显示方法与程序代码

ID:40160128

大小:356.51 KB

页数:7页

时间:2019-07-23

单片机LED点阵显示方法与程序代码_第1页
单片机LED点阵显示方法与程序代码_第2页
单片机LED点阵显示方法与程序代码_第3页
单片机LED点阵显示方法与程序代码_第4页
单片机LED点阵显示方法与程序代码_第5页
资源描述:

《单片机LED点阵显示方法与程序代码》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、单片机LED点阵显示方法与程序代码        点阵的接法有共阴和共阳两种(共阳指的是对每一行LED来讲是共阳)。        由于51单片机驱动能力有限,亮度不够,所以一般需要三极管驱动,下图为一个8X8点阵原理图,仅仅是仿真,如果需要接实物的话,加上三极管才足够亮。显示的方法有两种:1、逐列扫描方式。如下图所示,P1口输出列码决定哪一列能亮(相当于位码),P2口输出行码(列数据)决定列上哪些LED亮(相当于段码),能亮的列从左向右扫描完8列(相当于位码循环移位8次)即显示出一帧完整的图像。2、

2、逐行扫描方式,与逐列扫描调换,即P2口输出位码,P1口输出段码,扫描完8行显示出一帧图像。以逐行扫描为例,从上图可以很明了的知道点阵的显示原理了(红色表示高电平,绿色表示低电平),当把扫描速度加快,人的视觉停留,看见的就是一幅图或一个字了,如下图所示。一、行扫描静态显示,用51单片机实现上图静态显示的程序如下:#include#defineucharunsignedchar#defineuintunsignedintucharcodeTAB[]={0x81,0xFD,0xFD,0xC

3、1,0xBF,0xBF,0xBD,0xC3};uchari,t;delay(uchart){while(t--){;}}voidmain(void){while(1){P2=0x01;for(i=0;i<8;i++){P1=TAB;delay(100);P2=P2<<1

4、P2>>7;}}}二、行扫描翻页显示字码取模方式为逐行第一次从字码数组中取出第1~8个数据置于列上,行扫描顺序为1~8行,显示一帧,第二次取第9~16个数据,行扫描顺序仍为1~8行,显示第二帧,第三次取第17~24个数据,……实现图显

5、示效果的程序如下:/*8X8行扫描,翻页显示*/#include#defineucharunsignedchar#defineuintunsignedintucharcodeTAB[]={0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,//空屏0xFD,0xFD,0xFD,0xFD,0xFD,0xFD,0xC1,0xFF,//L0xE3,0xDD,0xDD,0xDD,0xDD,0xDD,0xE3,0xFF,//O0xDD,0xDD,0xDD,0xDD,

6、0xDD,0xEB,0xF7,0xFF,//V0xC1,0xFD,0xFD,0xC1,0xFD,0xFD,0xC1,0xFF,//E0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,//空屏};uchari,t;delay(uchart){while(t--){;}}voidmain(void){ucharN,T;while(1){for(N=0;N<6;N++)//循环扫描一遍6帧for(T=0;T<100;T++)//速度{P2=0x01;for(i=0;i<8;i+

7、+){P1=TAB[i+8*N];delay(100);P2=P2<<1

8、P2>>7;}}}}三、行扫描上下移动显示。如果是逐行取字模时,第一次从字码数组中取出第1~8个数据置于列上,行扫描顺序为1~8行,显示一帧,第二次取第2~9个数据,行扫描顺序仍为1~8行,显示第二帧,……如此便是向上移动。如果将上述的行扫描顺序改为8~1行,就是向下移动,但显示的图像是倒立的了,为了使得它不倒立,详细请看程序。另外取模方式不同,就有不同的编程方式。显示图上移效果的程序如下:/*8X8行扫描,上移显示*/#inc

9、lude#defineucharunsignedchar#defineuintunsignedintucharcodeTAB[]={0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,//空屏0xFD,0xFD,0xFD,0xFD,0xFD,0xFD,0xC1,0xFF,//L0xE3,0xDD,0xDD,0xDD,0xDD,0xDD,0xE3,0xFF,//O0xDD,0xDD,0xDD,0xDD,0xDD,0xEB,0xF7,0xFF,//V0xC1,

10、0xFD,0xFD,0xC1,0xFD,0xFD,0xC1,0xFF,//E0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,//空屏};uchari,t;delay(uchart){while(t--){;}}voidmain(void){ucharN,T;while(1){for(N=0;N<40;N++)//循环扫描一遍40帧for(T=0;T<60;T++)//移动速度{P2=0x01;for(i=0;i<8;i++

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

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

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