直接复制粘贴然后运行
然后打开stc烧录到开发板上面就能用 程序哪里不懂的话问我,我闲的蛋疼!
第七届最简单
#include <STC15F2K60S2.H>
#include <intrins.h>
unsigned char tab[]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,0xbf,0xff,0xc6};
unsigned char yi,er,san,si,wu,liu,qi,ba;
unsigned char wendu;
unsigned char moshi=1;
unsigned char jiemian=0;
unsigned int shijian=0;
unsigned char dingshi;
unsigned char guanbi=0;
sbit DQ=P1^4;
void Delayms(int ms)
{
int i,j;
for(i=0;i<ms;i++)
for(j=845;j>0;j--);
}
void chushihua()
{
P2=0XA0;P0=0X00;P2=0X80;P0=0XFF;
P2=0XC0;P0=0X00;P2=0XFF;P0=0XFF;
}
void shumaguan1(unsigned char yi,unsigned char er)
{
P2=0XC0;
P0=0X01;
P2=0XFF;
P0=tab[yi];
Delayms(1);
P2=0XC0;
P0=0X02;
P2=0XFF;
P0=tab[er];
Delayms(1);
}
void shumaguan2(unsigned char san,unsigned char si)
{
P2=0XC0;
P0=0X04;
P2=0XFF;
P0=tab[san];
Delayms(1);
P2=0XC0;
P0=0X08;
P2=0XFF;
P0=tab[si];
Delayms(1);
}
void shumaguan3(unsigned char wu,unsigned char liu)
{
P2=0XC0;
P0=0X10;
P2=0XFF;
P0=tab[wu];
Delayms(1);
P2=0XC0;
P0=0X20;
P2=0XFF;
P0=tab[liu];
Delayms(1);
}
void shumaguan4(unsigned char qi,unsigned char ba)
{
P2=0XC0;
P0=0X40;
P2=0XFF;
P0=tab[qi];
Delayms(1);
P2=0XC0;
P0=0X80;
P2=0XFF;
P0=tab[ba];
Delayms(1);
}
void anjian()
{
if(P30==0)
{
Delayms(5);
if(P30==0)
{
while(!P30);
}
if(jiemian==0)
{
jiemian=1;
}
else
if(jiemian==1)
{
jiemian=0;
}
}
if(P31==0)
{
Delayms(5);
if(P31==0)
{
while(!P31);
}
shijian=0;
}
if(P32==0)
{
Delayms(5);
if(P32==0)
{
while(!P32);
}
if(jiemian==0)
{
shijian=shijian+60;
}
}
if(P33==0)
{
Delayms(5);
if(P33==0)
{
while(!P33);
}
if(jiemian==0)
{
if(moshi==1) //睡眠风
{
moshi=2;
}
else
if(moshi==2) //自然风
{
moshi=3;
}
else
if(moshi==3)
{
moshi=1; //常风变成睡眠风
}
}
}
}
void Delay500us() //@11.0592MHz
{
unsigned char i, j;
_nop_();
_nop_();
i = 6;
j = 93;
do
{
while (--j);
} while (--i);
}
void Delay80us() //@11.0592MHz
{
unsigned char i, j;
_nop_();
i = 1;
j = 217;
do
{
while (--j);
} while (--i);
}
void chushihua2()
{
DQ=0;
Delay500us();
DQ=1;
Delay500us();
}
void xiechengxu(unsigned char dat)
{
unsigned char i;
for(i=0;i<8;i++)
{
DQ=0;
DQ=dat&0x01;
Delay80us();
DQ=1;
dat=dat>>1;
}
Delay80us();
}
unsigned char duchengxu()
{
unsigned char i,dat;
for(i=0;i<8;i++)
{
DQ=0;
dat=dat>>1;
DQ=1;
if(DQ==1)
{
dat=dat|0x80;
}
Delay80us();
}
return dat;
}
unsigned char zhuchengxu()
{
unsigned char di,gao,temp;
chushihua2();
xiechengxu(0xcc);
xiechengxu(0x44);
Delay500us();
chushihua2();
xiechengxu(0xcc);
xiechengxu(0xbe);
Delay500us();
di=duchengxu();
gao=duchengxu();
di=di>>4;
gao=gao<<4;
temp=di|gao;
return temp;
}
void Timer0Init(void) //5毫秒@11.0592MHz
{
AUXR |= 0x80; //定时器时钟1T模式
TMOD &= 0xF0; //设置定时器模式
TL0 = 0x00; //设置定时初值
TH0 = 0x28; //设置定时初值
TF0 = 0; //清除TF0标志
TR0 = 1; //定时器0开始计时
}
void tm1_isr() interrupt 1
{
TL0 = 0x00; //设置定时初值
TH0 = 0x28; //设置定时初值
dingshi++;
if(dingshi==200)
{
dingshi=0;
if(shijian!=0)
{
shijian=shijian-1;
}
}
}
void main()
{
chushihua();
Timer0Init();
EA=1;
ET0=1;
while(1)
{
anjian();
if(jiemian==0)
{
yi=10;er=moshi;san=10;si=11;
wu=0;liu=shijian/100;qi=shijian%100/10;ba=shijian%10;
if(guanbi==0)
{
if(moshi==1)
{
P2=0X80;P0=0XFE;
}
else
if(moshi==2)
{
P2=0X80;P0=0XFD;
}
else
if(moshi==3)
{
P2=0X80;P0=0XFB;
}
}
if(shijian==0)
{
guanbi=1;
P2=0X80;P0=0XFF;
}
else
{
guanbi=0;
}
}
if(jiemian==1)
{
wendu=zhuchengxu();
yi=10;er=4;san=10;si=11;wu=11;
liu=wendu/10;qi=wendu%10;ba=12;
}
shumaguan1(yi,er);
shumaguan2(san,si);
shumaguan3(wu,liu);
shumaguan4(qi,ba);
}
}