以前用51的時候,在Proteus里邊仿真過很多東西,51的一些基本功能都做過實驗,復雜點的東西雖然也有,但是都是隨性而來,需要什么用什么,程序顯得臃腫難讀,效率低下,且沒有及時把分析記錄下來
本文引用地址:http://2s4d.com/article/201611/321542.htm有時間自己再做一遍鬧鐘,跟以前做的感覺差別很大,以前好像都是COPY,自己改動的很少,而且老覺得程序長,當自己去設(shè)計步驟時,出現(xiàn)的問題卻不在這個地方,雖然51對于很多人而言,已再熟悉不過,但是我覺得算法都一樣,在很熟悉的51上驗證算法是很有效率的
功能:
1:時鐘顯示
2:時鐘可調(diào)
3:可設(shè)鬧鐘
4:鬧鐘隨時可關(guān)
思路:
1:時鐘用定時器1控制,每隔一秒,秒變量+1,
數(shù)碼管掃描顯示時鐘
2:設(shè)置2個可調(diào)時分按鍵,按鍵按下,對應時間變量+1
3:設(shè)置模式鍵,奇數(shù)次按下,改變鬧鐘時分
偶數(shù)次按下,改變時鐘時分
不斷地查詢檢測,時鐘時分==鬧鐘時分?,如果等于,則相應鬧鈴
4:設(shè)置關(guān)鬧鈴鍵,按下時關(guān)閉鬧鈴
在這個地方會出現(xiàn)一個小問題,鬧鐘是否開啟需要一直掃描,關(guān)鬧鐘按鍵也需要一直掃描,
當按鍵按下,在此刻關(guān)掉鬧鐘,但是,在這一分鐘之內(nèi),鬧鐘都有開啟的理由,故關(guān)了之后,
再次檢測鬧鐘時,鬧鐘會再次打開,
改善方法:設(shè)置標志量,當關(guān)鬧鐘之后的額定時間內(nèi),不再檢測鬧鐘,額定時間與鬧鐘的控制精度有關(guān)
程序如下:
#include
#define uchar unsigned char
#define uint unsigned int
sbit beep=P3^1;
sbit led=P3^0;
sbit hour_key=P3^4;//調(diào)節(jié)小時鍵
sbit minu_key=P3^5;//調(diào)節(jié)分鐘鍵
sbit stopsounder_key=P3^3; //關(guān)鬧鐘按鍵
bit sounder_flag=0;
sbit mode_key=P3^7; //調(diào)節(jié)時鐘還是鬧鈴控制按鍵
uchar mode_number;//模式計數(shù)
uchar sec_count;
uint a,b; //模式計數(shù)
uchar minu0=1;
uchar hour0,sec0, //鬧鐘
hour1,minu1,sec1,//時鐘
h1,h2,m1,m2,s1,s2,//顯示位
k;//狀態(tài)轉(zhuǎn)換標志
uchar code select[]={0x7f,0xbf,0xdf,0xef,0xf7,0xfb,0xfd,0xfe};
uchar code table[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f};
void keyscan();
void init();
void delay(uchar z);
void display(uchar,uchar,uchar);
void mode_check();
void init()
{
a=0;
b=0;
k=0;
hour1=0;
minu1=0;
sec1=0;
hour0=0;
minu0=1;
sec0=0;
TMOD=0x11; //定時器0,1工作于方式1;賦初值
TH0=(65536-5000)/256;
TL0=(65536-5000)%6;
TH1=(65536-50000)/256;
TL1=(65536-50000)%6;
EA=1;
EX0=1;
//ET0=0;
ET1=1;
IT0=1; //P3.2引腳下經(jīng)沿產(chǎn)生外部中斷0
//PX0=1;
//TR0=1; //初始,秒表不工作
TR1=1; //時鐘一開始工作
}
void delay(uchar z)
{
int x,y;
for(x=z;x>0;x--)
for(y=110;y>0;y--);
}
void ex0_int() interrupt 0
{
//作用待添加
}
評論