本文引用地址:http://www.ex-cimer.com/article/201611/321416.htm
程序三
利用動態(tài)掃描和定時器1在數碼管上顯示
出從765432開始以1/10秒的速度往下遞減
直至765398并保持顯示此數,與此同時利
用定時器0以500MS速度進行流水燈從上至
下移動,當數碼管上數減到停止時,實驗
板上流水燈也停止然后全部開始閃爍,3秒
后(用T0定時)流水燈全部關閉、數碼管上
顯示出"HELLO"。到此保持住。
#include //52單片機頭文件
#include //包含有左右循環(huán)移位子函數的庫
#define uint unsigned int //宏定義
#define uchar unsigned char //宏定義
sbit dula=P2^6;
sbit wela=P2^7;
uchar code table[]={ //顯示數據編碼
0x3f,0x06,0x5b,0x4f,
0x66,0x6d,0x7d,0x07,
0x7f,0x6f,0x77,0x7c,
0x39,0x5e,0x79,0x71,
0x76,0x79,0x38,0x3f,0};
uchar temp,t0,t1,bai,shi,ge,flag,flag1;
uint shu;
void init(); //函數聲明
void display(uchar aa,uchar bb,uchar cc,uchar bai,uchar shi,uchar ge);
void delay(uint z) //延時子函數
{
uint x,y;
for(x=z;x>0;x--)
for(y=110;y>0;y--);
}
void main() //主函數
{
init();
while(1)
{
if(flag1!=1) //如果flagi不再等于1則顯示數據
display(7,6,5,bai,shi,ge);
else
display(16,17,18,18,19,20); //否則顯示hello
}
}
void init() //初始化函數
{
shu=432;
temp=0xfe;
P1=temp;
TMOD=0x11;
TH0=(65536-50000)/256; //定時器初始化
TL0=(65536-50000)%256;
TH1=(65536-50000)/256;
TL1=(65536-50000)%256;
EA=1;
ET0=1;
ET1=1;
TR0=1;
TR1=1;
}
void timer0() interrupt 1 //定時器0中斷
{
TH0=(65536-50000)/256;
TL0=(65536-50000)%256;
t0++;
if(flag!=1) //flag不等于1時進行流水燈
{
if(t0==10)
{
t0=1;
temp=_crol_(temp,1);
P1=temp;
}
}
else //否則進行燈閃爍
{
if(t0%4==0) //小燈每200毫秒變化一次
P1=~P1;
if(t0==60)
{
TR0=0; //3秒后關閉定時器0,關閉燈,并置flag=1
P1=0xff;
flag1=1;
}
}
}
void timer1() interrupt 3 //定時器1中斷函數
{
TH1=(65536-50000)/256;
TL1=(65536-50000)%256;
t1++;
if(t1==2)
{
t1=0;
shu--;
bai=shu/100;
shi=shu%100/10;
ge=shu%10;
if(shu==398) //當到398時把原來T0中的數清除,重新加裁初值讓小燈閃爍
{
TR0=0;
TH0=(65536-50000)/256;
TL0=(65536-50000)%256;
TR0=1;
flag=1;
t0=0;
P1=0xff;
TR1=0;
}
}
}
void display(uchar aa,uchar bb,uchar cc,uchar bai,uchar shi,uchar ge) //顯示子函數
{
dula=1;
P0=table[aa];
dula=0;
P0=0xff;
wela=1;
P0=0xfe;
wela=0;
delay(1);
dula=1;
P0=table[bb];
dula=0;
P0=0xff;
wela=1;
P0=0xfd;
wela=0;
delay(1);
dula=1;
P0=table[cc];
dula=0;
P0=0xff;
wela=1;
P0=0xfb;
wela=0;
delay(1);
dula=1;
P0=table[bai];
dula=0;
P0=0xff;
wela=1;
P0=0xf7;
wela=0;
delay(1);
dula=1;
P0=table[shi];
dula=0;
P0=0xff;
wela=1;
P0=0xef;
wela=0;
delay(1);
dula=1;
P0=table[ge];
dula=0;
P0=0xff;
wela=1;
P0=0xdf;
wela=0;
delay(1);
}
評論