自己做个简单的电子钟 发现不是一秒跳动
时间:10-02
整理:3721RD
点击:
各位大侠:
小弟用6个数码管做了个电子钟 从00 00 00 开始走 发现 秒计数不是1S 帮忙找下原因 谢谢
程序如下:sbit DIGla=P2^6;
sbit POSla=P2^7;
unsigned char code tablePOS[]={0xfe,0xfd,0xfb,0xf7,0xef,0xdf};
unsigned char code tableDIG[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,
0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71,0};
unsigned char num,temp,Hrh,Hrl,Minh,Minl,Sech,Secl;
unsigned char Hr,Min,Sec;
void Init(void);
void Delay(unsigned char);
void Display(unsigned char,unsigned char,unsigned char,
unsigned char,unsigned char,unsigned char);
void main(void)
{
Init();
Display(0,0,0,0,0,0);
while(1)
{
if(num==20)
{
num=0;
Sec++;
if(Sec==60)
{
Sec=0;
Min++;
if(Min==60)
{
Min=0;
Hr++;
if(Hr==24)
{
Hr=0;
}
}
}
}
Display(Hrh,Hrl,Minh,Minl,Sech,Secl);
}
}
void Init(void)
{
num=0;
POSla=0;
DIGla=0;
TMOD=0x01;
EA=1;
TH0=(65536-50000)/256;
TL0=(65536-50000)%256;
ET0=1;
TR0=1;
}
void Delay(unsigned char z)
{
unsigned char x,y;
for(x=z;x>0;x--)
for(y=110;y>0;y--);
}
void Timer0(void) interrupt 1 using 1
{
TH0=(65536-50000)/256;
TL0=(65536-50000)%256;
num++;
}
void Display(unsigned char Hrh,unsigned char Hrl,unsigned char Minh,
unsigned char Minl,unsigned char Sech,unsigned char Secl)
{
Hrh=Hr/10;
Hrl=Hr%10;
Minh=Min/10;
Minl=Min%10;
Sech=Sec/10;
Secl=Sec%10;
POSla=1;
P0=tablePOS[0]; //1101 1111
POSla=0;
DIGla=1;
P0=tableDIG[Hrh];
DIGla=0;
Delay(3);
P0=0xff;
POSla=1;
P0=tablePOS[1]; //1101 1111
POSla=0;
DIGla=1;
P0=tableDIG[Hrl];
DIGla=0;
Delay(3);
P0=0xff;
POSla=1;
P0=tablePOS[2]; //1101 0111
POSla=0;
DIGla=1;
P0=tableDIG[Minh];
DIGla=0;
Delay(3);
P0=0xff;
POSla=1;
P0=tablePOS[3]; //1111 1011
POSla=0;
DIGla=1;
P0=tableDIG[Minl];
DIGla=0;
Delay(3);
P0=0xff;
POSla=1;
P0=tablePOS[4]; //1101 1111
POSla=0;
DIGla=1;
P0=tableDIG[Sech];
DIGla=0;
Delay(5);
P0=0xff;
POSla=1;
P0=tablePOS[5]; //1101 1111
POSla=0;
DIGla=1;
P0=tableDIG[Secl];
DIGla=0;
Delay(3);
P0=0xff;
}
小弟用6个数码管做了个电子钟 从00 00 00 开始走 发现 秒计数不是1S 帮忙找下原因 谢谢
程序如下:sbit DIGla=P2^6;
sbit POSla=P2^7;
unsigned char code tablePOS[]={0xfe,0xfd,0xfb,0xf7,0xef,0xdf};
unsigned char code tableDIG[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,
0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71,0};
unsigned char num,temp,Hrh,Hrl,Minh,Minl,Sech,Secl;
unsigned char Hr,Min,Sec;
void Init(void);
void Delay(unsigned char);
void Display(unsigned char,unsigned char,unsigned char,
unsigned char,unsigned char,unsigned char);
void main(void)
{
Init();
Display(0,0,0,0,0,0);
while(1)
{
if(num==20)
{
num=0;
Sec++;
if(Sec==60)
{
Sec=0;
Min++;
if(Min==60)
{
Min=0;
Hr++;
if(Hr==24)
{
Hr=0;
}
}
}
}
Display(Hrh,Hrl,Minh,Minl,Sech,Secl);
}
}
void Init(void)
{
num=0;
POSla=0;
DIGla=0;
TMOD=0x01;
EA=1;
TH0=(65536-50000)/256;
TL0=(65536-50000)%256;
ET0=1;
TR0=1;
}
void Delay(unsigned char z)
{
unsigned char x,y;
for(x=z;x>0;x--)
for(y=110;y>0;y--);
}
void Timer0(void) interrupt 1 using 1
{
TH0=(65536-50000)/256;
TL0=(65536-50000)%256;
num++;
}
void Display(unsigned char Hrh,unsigned char Hrl,unsigned char Minh,
unsigned char Minl,unsigned char Sech,unsigned char Secl)
{
Hrh=Hr/10;
Hrl=Hr%10;
Minh=Min/10;
Minl=Min%10;
Sech=Sec/10;
Secl=Sec%10;
POSla=1;
P0=tablePOS[0]; //1101 1111
POSla=0;
DIGla=1;
P0=tableDIG[Hrh];
DIGla=0;
Delay(3);
P0=0xff;
POSla=1;
P0=tablePOS[1]; //1101 1111
POSla=0;
DIGla=1;
P0=tableDIG[Hrl];
DIGla=0;
Delay(3);
P0=0xff;
POSla=1;
P0=tablePOS[2]; //1101 0111
POSla=0;
DIGla=1;
P0=tableDIG[Minh];
DIGla=0;
Delay(3);
P0=0xff;
POSla=1;
P0=tablePOS[3]; //1111 1011
POSla=0;
DIGla=1;
P0=tableDIG[Minl];
DIGla=0;
Delay(3);
P0=0xff;
POSla=1;
P0=tablePOS[4]; //1101 1111
POSla=0;
DIGla=1;
P0=tableDIG[Sech];
DIGla=0;
Delay(5);
P0=0xff;
POSla=1;
P0=tablePOS[5]; //1101 1111
POSla=0;
DIGla=1;
P0=tableDIG[Secl];
DIGla=0;
Delay(3);
P0=0xff;
}
不知芯片,晶振等硬件环境如何
我运行了一下
跟电脑的秒比对了一下
差不多的啊
没问题的程序
要是有问题的话估计就是你的晶振氧化了吧
不是12M了
而且你程序感觉用了全局变量
中断里面返回的是Hr,Min,Sec
调用的却是Display(Hrh,Hrl,Minh,Minl,Sech,Secl);
十位个各位的分离写在显示函数里面就不要定义全局的那六个变量了
1,定时器的计时要配合晶振的大小的。
2. 延时的精准也是要经过多次试验取值的,不能随便,因为程序事件运行长后,误差越滚越大,最后就很明显的。
用定时器肯定不是很准,多少都有误差,即使用1302也不是超精准的,电子设备有个工级误差,具体看那类产品了
谢谢小编无私奉献 正在学习了 谢谢