51单片机8*8点阵LED显示原理及程序

51单片机8*8点阵LED显示原理及程序

ID:37843153

大小:29.00 KB

页数:7页

时间:2019-06-01

51单片机8*8点阵LED显示原理及程序_第1页
51单片机8*8点阵LED显示原理及程序_第2页
51单片机8*8点阵LED显示原理及程序_第3页
51单片机8*8点阵LED显示原理及程序_第4页
51单片机8*8点阵LED显示原理及程序_第5页
资源描述:

《51单片机8*8点阵LED显示原理及程序》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、51单片机8*8点阵LED显示原理及程序更多发布时间:2008年8月16日 在8X8点阵LED上显示柱形,让其先从左到右平滑移动三次,其次从右到左平滑移动三次,再次从上到下平滑移动三次,最后从下到上平滑移动三次,如此循环下去。  1.程序设计内容  8X8点阵LED工作原理说明:8X8点阵共需要64个发光二极管组成,且每个发光二极管是放置在行线和列线的交叉点上,当对应的某一列置1电平,某一行置0电平,则相应的二极管就亮;因此要实现一根柱形的亮法,如图49所示,对应的一列为一根竖柱,或者对应的一行为一根横柱,因此实现柱的亮的方法如下所述:  一根竖柱:对应的列置1,而行则采用扫

2、描的方法来实现。  一根横柱:对应的行置0,而列则采用扫描的方法来实现。  2.硬件电路  3.汇编源程序ORG00HSTART:NOPMOVR3,#3LOP2:MOVR4,#8MOVR2,#0LOP1:MOVP1,#0FFHMOVDPTR,#TABAMOVA,R2MOVCA,@A+DPTRMOVP3,AINCR2LCALLDELAYDJNZR4,LOP1DJNZR3,LOP2MOVR3,#3LOP4:MOVR4,#8MOVR2,#7LOP3:MOVP1,#0FFHMOVDPTR,#TABAMOVA,R2MOVCA,@A+DPTRMOVP3,ADECR2LCALLDELAYD

3、JNZR4,LOP3DJNZR3,LOP4MOVR3,#3LOP6:MOVR4,#8MOVR2,#0LOP5:MOVP3,#00HMOVDPTR,#TABBMOVA,R2MOVCA,@A+DPTRMOVP1,AINCR2LCALLDELAYDJNZR4,LOP5DJNZR3,LOP6MOVR3,#3LOP8:MOVR4,#8MOVR2,#7LOP7:MOVP3,#00HMOVDPTR,#TABBMOVA,R2MOVCA,@A+DPTRMOVP1,ADECR2LCALLDELAYDJNZR4,LOP7DJNZR3,LOP8LJMPSTARTDELAY:MOVR5,#10D2:M

4、OVR6,#20D1:MOVR7,#248DJNZR7,$DJNZR6,D1DJNZR5,D2RET  TABA:DB0FEH,0FDH,0FBH,0F7H,0EFH,0DFH,0BFH,07FHTABB:DB01H,02H,04H,08H,10H,20H,40H,80HEND  4.C51语言源程序#include  unsignedCHARcodetaba[]={0xfe,0xfd,0xfb,0xf7,0xef,0xdf,0xbf,0x7f};unsignedCHARcodetabb[]={0x01,0x02,0x04,0x08,0x10,0x20,

5、0x40,0x80};  voidDELAY(void)  {  unsignedCHARi,j;  for(i=10;i>0;i--)  for(j=248;j>0;j--);  }  voidDELAY1(void)  {  unsignedCHARi,j,k;  for(k=10;k>0;k--)  for(i=20;i>0;i--)  for(j=248;j>0;j--);  }  voidmain(void)  {  unsignedCHARi,j;  while(1)  {  for(j=0;j<3;j++)  //FROMlefttoright3time  {f

6、or(i=0;i<8;i++){  P3=taba[i];  P1=0xff;  DELAY1();}  }  for(j=0;j<3;j++)  //FROMrighttoleft3time  {for(i=0;i<8;i++){  P3=taba[7-i];  P1=0xff;  DELAY1();}  }  for(j=0;j<3;j++)  //FROMtoptobottom3time  {for(i=0;i<8;i++){  P3=0x00;  P1=tabb[7-i];  DELAY1();}  }  for(j=0;j<3;j++)  //FROMbottomt

7、otop3time  {for(i=0;i<8;i++){  P3=0x00;  P1=tabb[i];  DELAY1();}  }  }  }

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

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

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