您的位置 首页 动态

51单片机完成BPC电波钟解码C程序

使用STC12C5202单片机,晶振使用12M的,速度是12倍速的,电波钟模块引脚是接在单片机P3^2口的数码管是使用动态扫描的方式,四位数码管

//运用STC12C5202单片机,晶振运用12M的,速度是12倍速的,电波钟模块引脚是接在单片机P3^2口的

//数码管是运用动态扫描的方法,四位数码管显现
#include
#define uchar unsigned char
#define uint unsigned int
uchar xiaoshi,fenzon;
uchar tt=0;
#define duan P1
uchar code tab[]={ 0x12,/*0*/
0xD7,/*1*/
0x4A,/*2*/
0x43,/*3*/
0x87,/*4*/
0x23,/*5*/
0x22,/*6*/
0x57,/*7*/
0x02,/*8*/
0x03,/*9*/
};
sbit fen=P3^3;
sbit sf =P3^4;
sbit si =P3^5;
sbit ss =P3^7;
sbit led=P3^0;
/////////////////////////////////////////////////////////////////////////////
sbit MKin =P3^2; //电波钟模块信号引脚
uint shu=0;
uchar a[7];
void delay(uint k)
{
while(k–);
}
void duo_MoKuai()
{
uchar i=0;
for(;i<6;i++)
{
a[i]=0;
}
shu=0;
while(shu<116) //找启始码1.8秒低电平
{
if(!MKin)
{
delay(12000); //延时16mS
shu++;
}
else shu=0;
}
delay(2000); tt=0;
while(!MKin)delay(2000); //等候高电平完毕
delay(12000);
/////////////////////////////////////////////////////////////////////////////
while(MKin)delay(2000); //这是第一个脉冲;//依据协议该位只能是0、1、2,不能是3不然超出范围,表明接纳过错,重新同步
delay(12000);
while(!MKin)delay(2000);
delay(12000);
while(MKin)delay(2000); //这是第二个脉冲;//依据协议,该位有必要为0,不然便是过错,以为丢掉同步,故也不需要进行效验堆集核算
delay(12000);
while(!MKin)delay(2000);
delay(2000);
while(MKin) //第三位//这是小时的十位
{
delay(12000);
a[0]++;
}
delay(12000);
while(!MKin)delay(2000);
delay(2000);
while(MKin) //第四位 //这是小时的个位
{
delay(12000);
a[1]++;
}
delay(12000);
while(!MKin)delay(2000);
delay(2000);
while(MKin) //第五位//这是分钟的高位
{
delay(12000);
a[2]++;
}
delay(12000);
while(!MKin)delay(2000);
delay(2000);
while(MKin) //第六位//这是分钟的中位
{
delay(12000);
a[3]++;
}
delay(12000);
while(!MKin)delay(2000);
delay(2000);
while(MKin) //第七位//这是分钟的低位
{
delay(12000);
a[4]++;
}
delay(12000);
}
void Zuan_Huan()
{
uchar k;
duo_MoKuai(); //读电波钟模块
for(k=0;k<5;k++)
{
if(27>(a[k])>23) a[k]=0x03;
else if(17<(a[k])<21) a[k]=0x02;
else if(11<(a[k])<15) a[k]=0x01;
else if(8>(a[k])>5) a[k]=0;
}

xiaoshi=((a[0])*4)|(a[1]);
fenzon=(((a[2])*16)|((a[3])*4)|(a[4]));
}
/////////////////////////////////////////////////////////////////
void desplay()
{
duan=tab[xiaoshi/10];
ss=0;
delay(2000);
ss=1;
duan=tab[xiaoshi%10];
si=0;
delay(2000);
si=1;
duan=tab[fenzon/10];
sf=0;
delay(2000);
sf=1;
duan=tab[fenzon%10];
fen=0;
delay(2000);
fen=1;
}

void main()
{
uint aa;
while(1)
{
Zuan_Huan();
for(aa=0;aa<1000;aa++)
desplay();
}
}

声明:本文内容来自网络转载或用户投稿,文章版权归原作者和原出处所有。文中观点,不代表本站立场。若有侵权请联系本站删除(kf@86ic.com)https://www.86ic.net/news/dongtai/318418.html

为您推荐

联系我们

联系我们

在线咨询: QQ交谈

邮箱: kf@86ic.com

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

返回顶部