關(guān)于單片機(jī)獨(dú)立按鍵的詳解
但如果在觸點(diǎn)抖動(dòng)期間檢測(cè)按鍵的通與斷狀態(tài),可能導(dǎo)致判斷出錯(cuò),即按鍵一次按下或釋放被錯(cuò)誤地認(rèn)為是多次操作,這種情況是不允許出現(xiàn)的。為了克服按鍵觸點(diǎn)機(jī)械抖動(dòng)所致的檢測(cè)誤判,確保CPU對(duì)一次按鍵動(dòng)作只確認(rèn)一次按鍵,必須采取去抖動(dòng)措施。
本文引用地址:http://www.ex-cimer.com/article/201612/324144.htm消除按鍵抖動(dòng)的措施:
具體措施可從硬件、軟件兩方面予以考慮。在鍵數(shù)較少時(shí),可采用硬件去抖,而當(dāng)鍵數(shù)較多時(shí),采用軟件去抖。
軟件措施:
在第一次檢測(cè)到有鍵按下時(shí),執(zhí)行一段延時(shí)10ms的子程序,之后,
再次檢測(cè)該鍵的電平狀態(tài),如果該鍵電平仍保持閉合狀態(tài)電平,
則確認(rèn)為真正有鍵按下。否則,認(rèn)為無(wú)鍵按下;
同理,在檢測(cè)到該鍵釋放后,也應(yīng)采用相同的步驟進(jìn)行確認(rèn),
從而可消除抖動(dòng)的影響。
code:
/*獨(dú)立按鍵,采用共陽(yáng)極數(shù)碼管*/
#include
#include
#define uint unsigned int
#define uchar unsigned char
sbit key1=P2^3;
sbit ledA=P1^0;
uchar num;
void delay(uint z);
uchar code dutable[]={
0xc0,0xf9,0xa4,0xb0,0x99,
0x92,0x82,0xf8,0x80,0x90};//段選0~9
void main()
{
while(1)
{
if(key1==0)
{
delay(10);//去按下抖動(dòng)延時(shí)
if(key1==0)
{
ledA=0;
num++;
if(num==10)
{
num=0;
}
}
while(!key1);//等待按鍵釋放
delay(10);//去釋放抖動(dòng)延時(shí)
while(!key1);//確定已經(jīng)釋放
}
else
{
ledA=1;
}
P0=dutable[num];
}
}
void delay(uint z)
{
uint x,y;
for(x=z;x>0;x--)
{
for(y=0;y<=110;y++)
{
}
}
}
評(píng)論