微波EDA网,见证研发工程师的成长!
首页 > 硬件设计 > 嵌入式设计 > 世上最简单的遥控(数码管显示)电子钟(C语言编写)

世上最简单的遥控(数码管显示)电子钟(C语言编写)

时间:11-29 来源:互联网 点击:
/*此程序为红外遥控电子钟,晶振为12M,MCU型号为51系列,电路很简单四位共阳数码管,红外接收管sm0038接在P3.2*/

#include
#define uchar unsigned char
#define uint unsigned int
#define c(x) (x*120000/120000)
sbit IR=P3^2;

sbit ge=P2^3;//数码管四位选控制端
sbit shi=P2^2;
sbit bai=P2^1;
sbit qian=P2^0;

char miao,fen=59,shij=23;//时分秒3个变量
uchar num,ding; //两定时器计数变量
uint temp;//遥控解码变量
uchar i;
uchar j;
bit flag;//控制小数点亮与灭变量
bit power;//控制数码管亮与灭变量
bit flash;//进入时间调整标志位变量

uchar IRBUF[4]; //用于保存解码结果
uchar code table[]={
0xc0,0xf9,0xa4,0xb0,0x99,
0x92,0x82,0xf8,0x80,0x90,
0x88,0x83,0xc6,0xa1,0x86,
0x8e
};

uint Low()
{
TL0=0;
TH0=0;
TR0=1;
while(!IR&&(TH0&0x80)==0);
TR0=0;
return TH0*256+TL0;
}
//=============================================================
uint High()
{
TL0=0;
TH0=0;
TR0=1;
while(IR&&(TH0&0x80)==0);
TR0=0;
return TH0*256+TL0;
}
void xian(uchar shik,uchar fen)
{
P0=table[shik/10];
if(power==0)
qian=0;
else
qian=1;
// delay(2);
qian=1;
if(flag==0)
P0=table[shik%10]&0x7f;
else
P0=table[shik%10]|0x80;
if(power==0)
bai=0;
else
bai=1;
//delay(2);
bai=1;
P0=table[fen/10];
if(power==0)
shi=0;
else
shi=1;
//delay(2);
shi=1;
P0=table[fen%10];
if(power==0)
ge=0;
else
ge=1;
//delay(2);
ge=1;
}
void yin()
{
while(1)
{
restart:
while(IR)
{

xian(shij,fen);
if(flash==1)
{
if(ding>5)
{
ding=0;
power=~power;
//xian(shij,fen);
}
}
}
temp=Low();
if(tempc(9500)) continue;//引导脉冲低电平9000
temp=High();
if(tempc(5000)) continue;//引导脉冲高电平4500
for(i=0;i<4;i++) //4个字节
{
for(j=0;j<8;j++) //每个字节8位
{
temp=Low();
if(tempc(800)) goto restart;
temp=High();
if(tempc(2000)) goto restart;
IRBUF[i]>>=1;
if(temp>c(1120)) IRBUF[i]|=0x80;
}
}
return;
}
}

//==============================================================
main()
{
TMOD=0x11;
EA=1;

TR0=1;
ET0=1;
TL0=0;
TH0=0;

TR1=1;
ET1=1;
TH1=(65536-100)/256; //定时器0设定约1000us中断一次,用于数码管扫描
TL1=(65536-100)%256;
while(1)
{
yin();
switch(IRBUF[2])
{
case 0x58:flash=~flash;if(flash==0)power=0;//进入调整时间状态
break;
case 0x1b:if(flash==1){shij++;if(shij>23)shij=0;}//如果数码管在闪烁则可以进入小时"+"调整
break;
case 0x1f:if(flash==1){shij--;if(shij<=(0-1))shij=23;}//如果数码管在闪烁则可以进入小时"-"调整
break;
case 0x0f:if(flash==1){fen++;if(fen>59)fen=0;}//如果数码管在闪烁则可以进入分"+"调整
break;
case 0x1a:if(flash==1){fen--;if(fen<=(0-1))fen=59;}//如果数码管在闪烁则可以进入分"-"调整
break;
}

}
}
void zhong3() interrupt 3
{

TH1=(65536-50000)/256;
TL1=(65536-50000)%256;
num++;
ding++;
if(num>=10)
{
num=0;
miao++;//数码管闪烁变量
if(flash==0)
flag=~flag;
else
flag=0;
if(miao>119)
{
miao=0;
fen++;
if(fen>59)
{
fen=0;
shij++;
if(shij>23)
shij=0;
}
}
}

}
void zhong1() interrupt 1
{
TL0=0;
TH0=0;
}

Copyright © 2017-2020 微波EDA网 版权所有

网站地图

Top