这套题相对来说比较简单,但是我记得我也是通过这套题学会的用定时器刷新数码管,第一次写的时候把所有的程序都写在中断里面了(虽然现在还是没有把中断写的很简明),以前面对这样的题也会无从下手,但现在也终于可以觉得这种好简单(●'◡'●)
#include<stc15f2k60s2.h>
#include"iic.h"
unsigned char wei[8]={0x01,0x02,0x04,0x08,0x10,0x20,0x40,0x80};
unsigned char duan[]={0xC0,0xF9,0xA4,0xB0,0x99,0x92,0x82,0xF8,0x80,0x90,0xbf,0xff};
unsigned char tab[8]={11,0,5,0,0,0,0,0};
unsigned char key=0;
unsigned int water=0;
unsigned int water1=0;
unsigned int jiage=0;
unsigned int dianya=0;
bit led_flag=0;
void delayms(unsigned int ms)
{
int i,j;
for(i=0;i<ms;i++)
for(j=0;j<845;j++);
}
void HC_138(unsigned char m)
{
switch(m)
{
case(4):P2|=0X80;P2&=0X9F;break;
case(5):P2|=0XA0;P2&=0XBF;break;
case(6):P2|=0XC0;P2&=0XDF;break;
case(7):P2|=0XE0;P2&=0XFF;break;
}
}
void allinit()
{
HC_138(4);P0=0xff;
HC_138(4);P0=0x00;
HC_138(4);P0=0x00;
HC_138(4);P0=0xff;
}
void timer0init()
{
TMOD=0X01;
TH0=(65536-1000)/256;
TL0=(65535-1000)%256;
EA=1;
TR0=1;
ET0=1;
}
void timer0() interrupt 1
{
static i=0,m=0;
TH0=(65536-1000)/256;
TL0=(65535-1000)%256;
HC_138(6);
P0=wei[i];
HC_138(7);
P0=duan[tab[i]];
i++;
if(i==8)
i=0;
if(key==1)
{
m++;
HC_138(5);
P04=1;
if(m==100)
{
water++;
water1=water;
if(water==9999)
key=2;
m=0;
}
}
else
{
HC_138(5);
P04=0;
}
if(led_flag==1)
{
HC_138(4);
P0=~0X01;
}
else
{
HC_138(4);
P0=0xff;
}
}
void keyscan()
{
if(P30==0)
{
delayms(10);
if(P30==0)
{
key=1;
}
while(!P30);
}
if(P31==0)
{
delayms(10);
if(P31==0)
{
key=2;
water=0;
}
while(!P31);
}
}
void keyshow()
{
if(key==1)
{
tab[4]=water/1000;
tab[5]=water%1000/100;
tab[6]=water%100/10;
tab[7]=water%10;
}
if(key==2)
{
jiage=water1*0.5;
tab[4]=jiage/1000;
tab[5]=jiage%1000/100;
tab[6]=jiage%100/10;
tab[7]=jiage%10;
}
}
void dianya_jiance()
{
dianya=AD_read(0x01)*190;
if(dianya>=1250)
led_flag=1;
else
led_flag=0;
}
void main()
{
allinit();
timer0init();
while(1)
{
keyscan();
keyshow();
dianya_jiance();
}
}