图有点乱,注意红色区域就行了,仿真不行的看是不是少加了驱动。

#include <reg52.h>
#include <stdlib.h>
#define uint unsigned long
#define uchar unsigned char
sbit N5 = P1^0;
sbit N6 = P1^1;
sbit N7 = P1^2;
sbit N8 = P1^3;
sbit S1 = P3^7;//加按钮
sbit S2 = P3^6;//减按钮
sbit S3 = P3^5;//清零按钮
uchar code table[]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90}; //0~916进制共阳极编码
uchar shi=0;
uint num;
void delayms(uint xms) //延时函数
{
uint i,j;
for(i=xms;i>0;i--)
for(j=10;j>0;j--);
}
void timer0() interrupt 1
{
if(shi>99)
{ //定时器
shi=0;
num++;
}
TH0=(65536-50000)/256; //重新赋值
TL0=(65536-50000)%256;
shi++; //1毫秒加1
}
void display(unsigned long num)
{
N5=0;
P0=table[(num%10000)/1000];
delayms(1);
P0=0XFF;
N5=1;
N6=0; //显示小数点
P0=table[(num%1000)/100]+0x80; //+0x80是共阴极,+0x7f是共阳极
delayms(1);
P0=0XFF;
N6=1;
N7=0;
P0=table[(num%100)/10];
delayms(1);
P0=0XFF;
N7=1;
N8=0;
P0=table[num%10];
delayms(1);
P0=0XFF;
N8=1;
}
void main()
{
TMOD=0X01; /*中断初始化*/
TH0=(65536-50000)/256;
TL0=(65536-50000)%256;
EA=1; //中断总开关
ET0=1; //请求中断
TR0=1; //允许中断
num=0; //初始化0000
while(1)
{
while(1)
{
display(num);
if(S1==0)//判断是否按下 开始计数
{
delayms(50);
if(S1==0) //再次确定
{
num++;
TR0=1;
}
while(!S1); //消抖
delayms(50);
while(!S1);
//跳出所在的第一个while循环
break;
}
else if(S2==0)//判断是否按下 清零
{
delayms(50);
if(S2==0) //再次确定
{
num=0;
}
while(!S2); //消抖
delayms(50);
while(!S2);
//跳出所在的第一个while循环
break;
}
else if(S3==0)//判断是否按下---暂停
{
delayms(50);
if(S3==0) //再次确定
{
while(!S3);
TR0=0;
}
while(!S3); //消抖
delayms(50);
while(!S3);
//跳出所在的第一个while循环
break;
}
}
}
}

被折叠的 条评论
为什么被折叠?



