C51四位数码管动态扫描让其中一位闪烁_第1页
C51四位数码管动态扫描让其中一位闪烁_第2页
免费预览已结束,剩余1页可下载查看

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、 6/6C51四位数码管动态扫描让其中一位闪烁 思路说明:将显示程序放入定时器中断,设定一闪烁标志位。定时时间为2MS,定时时间到则将标志位取反,同时也可以将按键扫描程序放入该定时器,则在视觉上可以看到要求位的闪烁。 #include0;x-) for(y=110;y0;y-); void display() if(flashflag=1 else P0=numdbuf0; P1=0 x01; delayus(20); P1=0 x00; if(flashflag=1 else P0=numdbuf1; P1=0 x02; delayus(20); P1=0 x00; if(flashflag

2、=1 else P0=numdbuf2; P1=0 x04; delayus(20); P1=0 x00; if(flashflag=1 else P0=numdbuf3; P1=0 x08; delayus(20); P1=0 x00; void keynum() uchar temp; P2=0 x0f; if(P2!=0 xf0) delayus(10); if(P2!=0 xf0) P2=0 xf7; delayus(10); temp=P2; switch(temp) case 0 xe7:flashbit=1;break; case 0 xd7:flashbit=2;break;

3、case 0 xb7:flashbit=3;break; case 0 x77:flashbit=4;break; default :P2=0 xfb; temp=P2; switch(temp) case 0 xeb:outnum=1;break; case 0 xdb:outnum=5;break; case 0 xbb:outnum=9;break; case 0 x7b:outnum=13;break; default:P2=0 xfd; temp=P2; switch(temp) case 0 xed:outnum=2;break; case 0 xdd:outnum=6;break

4、; case 0 xbd:outnum=10;break; case 0 x7d:outnum=14;break; default:P2=0 xfe; temp=P2; switch(temp) case 0 xee:outnum=3;break; case 0 xde:outnum=7;break; case 0 xbe:outnum=11;break; case 0 x7e:outnum=15;break; default:break; /* if(!key1) delayus(50); if(!key1) outnum=5; while(!key1); delayus(50); */ v

5、oid main() setint(); while(1) dbuf0=outnum/10; dbuf1=outnum%10; dbuf2=2; dbuf3=3; void timer1() interrupt 1 TH0=(65536-10000)/256; TL0=(65536-10000)%256; keynum(); display(); flashflag=flashflag; /8位数码管动态显示时间,可调节, /调节时间时,调节的数闪烁显示; /比较两种闪烁的方法; /2011。3。6 #include #define uint unsigned int #define ucha

6、r unsigned char sbit tiaojie=P10; sbit jia=P11; sbit jian=P12; uchar code table=0 xc0,0 xf9,0 xa4,0 xb0,0 x99,0 x92,0 x82,0 xf8, 0 x80,0 x90,0 xbf; uchar a,b,num1,num2,flag100ms,flag1s,flagtj; uchar miao,fen,shi,flagjia,flagjian; bit flag_1s; uchar code wela8=0 x01,0 x02,0 x04,0 x08,0 x10,0 x20,0 x4

7、0,0 x80; uchar dula8=0,0,1,1,2,2,3,3; void delay(uint z); void intc(); void keyscan(); void disp(); void main() intc(); while(1) keyscan(); disp(); /= void intc() TMOD=0 x01; TH0=(65536-10000)/256; TL0=(65536-10000)%256; ET0=1; EA=1; TR0=1; void timer0() interrupt 1 TH0=(65536-10000)/256; TL0=(65536

8、-10000)%256; a+; if(a=10) flag100ms=1; if(a=100) a=0,flag1s=1,miao+;flag_1s=flag_1s; if(miao=60) miao=0,fen+; if(fen=60) fen=0,shi+; if(shi12) shi=1; /= void disp() uchar i,n; dula7=miao%10; dula6=miao/10; dula5=0 x0a; dula4=fen%10; dula3=fen/10; dula2=0 x0a; dula1=shi%10; dula0=shi/10; for(i=0;i5 else P0=tabledulai; else P0=tabledulai;break; case 2: if(i2 else P0=tabledulai; else P0=tabledulai;break; case 3: if(i=0 else P0=tabledulai; else P0=tabledulai;break; case 0: P0=tabledulai;break; P2=welai; delay(10); P0=0 xff; */ /= void delay(uint z) uint x; uchar

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论