以前用51的時(shí)候,在Proteus里邊仿真過(guò)很多東西,51的一些基本功能都做過(guò)實(shí)驗(yàn),復(fù)雜點(diǎn)的東西雖然也有,但是都是隨性而來(lái),需要什么用什么,程序顯得臃腫難讀,效率低下,且沒(méi)有及時(shí)把分析記錄下來(lái)
本文引用地址:http://cafeforensic.com/article/201611/321542.htm有時(shí)間自己再做一遍鬧鐘,跟以前做的感覺(jué)差別很大,以前好像都是COPY,自己改動(dòng)的很少,而且老覺(jué)得程序長(zhǎng),當(dāng)自己去設(shè)計(jì)步驟時(shí),出現(xiàn)的問(wèn)題卻不在這個(gè)地方,雖然51對(duì)于很多人而言,已再熟悉不過(guò),但是我覺(jué)得算法都一樣,在很熟悉的51上驗(yàn)證算法是很有效率的
功能:
1:時(shí)鐘顯示
2:時(shí)鐘可調(diào)
3:可設(shè)鬧鐘
4:鬧鐘隨時(shí)可關(guān)
思路:
1:時(shí)鐘用定時(shí)器1控制,每隔一秒,秒變量+1,
數(shù)碼管掃描顯示時(shí)鐘
2:設(shè)置2個(gè)可調(diào)時(shí)分按鍵,按鍵按下,對(duì)應(yīng)時(shí)間變量+1
3:設(shè)置模式鍵,奇數(shù)次按下,改變鬧鐘時(shí)分
偶數(shù)次按下,改變時(shí)鐘時(shí)分
不斷地查詢(xún)檢測(cè),時(shí)鐘時(shí)分==鬧鐘時(shí)分?,如果等于,則相應(yīng)鬧鈴
4:設(shè)置關(guān)鬧鈴鍵,按下時(shí)關(guān)閉鬧鈴
在這個(gè)地方會(huì)出現(xiàn)一個(gè)小問(wèn)題,鬧鐘是否開(kāi)啟需要一直掃描,關(guān)鬧鐘按鍵也需要一直掃描,
當(dāng)按鍵按下,在此刻關(guān)掉鬧鐘,但是,在這一分鐘之內(nèi),鬧鐘都有開(kāi)啟的理由,故關(guān)了之后,
再次檢測(cè)鬧鐘時(shí),鬧鐘會(huì)再次打開(kāi),
改善方法:設(shè)置標(biāo)志量,當(dāng)關(guān)鬧鐘之后的額定時(shí)間內(nèi),不再檢測(cè)鬧鐘,額定時(shí)間與鬧鐘的控制精度有關(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é)小時(shí)鍵
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é)時(shí)鐘還是鬧鈴控制按鍵
uchar mode_number;//模式計(jì)數(shù)
uchar sec_count;
uint a,b; //模式計(jì)數(shù)
uchar minu0=1;
uchar hour0,sec0, //鬧鐘
hour1,minu1,sec1,//時(shí)鐘
h1,h2,m1,m2,s1,s2,//顯示位
k;//狀態(tài)轉(zhuǎn)換標(biāo)志
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; //定時(shí)器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; //時(shí)鐘一開(kāi)始工作
}
void delay(uchar z)
{
int x,y;
for(x=z;x>0;x--)
for(y=110;y>0;y--);
}
void ex0_int() interrupt 0
{
//作用待添加
}
評(píng)論