51单片机-秒表C程序_第1页
51单片机-秒表C程序_第2页
51单片机-秒表C程序_第3页
51单片机-秒表C程序_第4页
51单片机-秒表C程序_第5页
已阅读5页,还剩1页未读 继续免费阅读

下载本文档

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

文档简介

#include /52系列单片机头文件#define uchar unsigned char#define uint unsigned int sbit key1=P34;sbit key2=P35;sbit gao1=P25;sbit gao2=P24;sbit gao3=P23;sbit dula=P26;/申明U1锁存器的锁存端sbit wela=P27;/申明U2锁存器的锁存端uchar code table=0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71;void delayms(uchar);int numt1,numt0,nums=0,numf=0,num=0;void display(uchar numdis0,uchar numdis1,uchar numdis2,uchar numdis3) /显示子函数 uchar mmiao0,mmiao1,miao0,miao1,fen0,fen1,shi0,shi1; /分离两个分别要显示的数mmiao1=numdis0/10;mmiao0=numdis0%10; P0=tablemmiao0;dula=1; /送十位段选数据dula=0;/原来段选数据通过位选锁存器造成混乱P0=0xfe;wela=1;/送位选数据wela=0;delayms(5);/延时P0=0xff;wela=1;/消影wela=0;P0=tablemmiao1;dula=1; /送十位段选数据dula=0;/原来段选数据通过位选锁存器造成混乱P0=0xfd;wela=1;/送位选数据wela=0;delayms(5);/延时P0=0xff;wela=1;/消影wela=0;P0=0x40;dula=1; /送十位段选数据dula=0;/原来段选数据通过位选锁存器造成混乱P0=0xfb;wela=1;/送位选数据wela=0;delayms(5);/延时P0=0xff;wela=1;/消影wela=0; miao1=numdis1/10;miao0=numdis1%10; P0=tablemiao0;dula=1; /送十位段选数据dula=0;/原来段选数据通过位选锁存器造成混乱P0=0xf7;wela=1;/送位选数据wela=0;delayms(5);/延时P0=0xff;wela=1;/消影wela=0;P0=tablemiao1; /送个位段选数据dula=1;dula=0;P0=0xef;wela=1;wela=0;delayms(5);P0=0xff;wela=1;/wela=0;P0=0x40;dula=1; /送十位段选数据dula=0;/原来段选数据通过位选锁存器造成混乱P0=0xdf;wela=1;/送位选数据wela=0;delayms(5);/延时P0=0xff;wela=1;/消影wela=0; fen1=numdis2/10;fen0=numdis2%10; P0=tablefen0;dula=1; /送十位段选数据dula=0;/原来段选数据通过位选锁存器造成混乱P0=0xbf;wela=1;/送位选数据wela=0;delayms(5);/延时P0=0xff;wela=1;/消影wela=0;P0=tablefen1; /送个位段选数据dula=1;dula=0;P0=0x7f;wela=1;wela=0;delayms(5);P0=0xff;wela=1;/wela=0;P0=0x40;dula=1; /送十位段选数据dula=0;/原来段选数据通过位选锁存器造成混乱 gao1=0;delayms(5);/延时P0=0xff; gao1=0;gao1=1; shi1=numdis3/10;shi0=numdis3%10; P0=tableshi0;dula=1; /送十位段选数据dula=0;/原来段选数据通过位选锁存器造成混乱gao2=0;delayms(5);/延时P0=0xff;gao2=0;gao2=1;P0=tableshi1; /送个位段选数据dula=1;dula=0;gao3=0;delayms(5);P0=0xff;gao3=0;gao3=1;void delayms(uchar xms)uchar i,j;for(i=xms;i0;i-) /i=xms即延时约xms毫秒for(j=110;j0;j-);void init() /初始化函数TMOD=0x01;/设置定时器0为工作方式1(0000 0001)TH0=(65536-9174)/256;/装初值50ms一次中断TL0=(65536-9174)%256;EA=1; /开总中断ET0=1; /开定时器0中断void keyscan() if(key1=0)delayms(5);if(key1=0)while(!key1);TR0=TR0;/启动或停止定时器0if(key2=0)delayms(5);if(key2=0)numt1=0;num=0; /清0numf=0;TR0=0;init();/清零后定时器从初始值开始计,否则接着清零前开始while(!key2);void main()init();/初始化函数while(1) keyscan();display(numt1,num,numf,nums);void T0_time() interrupt 1TH0=(65536-9174)/256;/重装初值TL0=(65536-9174)%256;numt1+;numt0+;

温馨提示

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

评论

0/150

提交评论