然后再讓P00,P02,P03為高電平,P01為低電平。同理用上面的方法可以檢測(cè)出按下的那個(gè)按鍵。(部分程序源代碼會(huì)在后面貼出來,閱讀代碼可以更好理解電路)
5)、接下來這種方案則更為強(qiáng)大。不過需要用到一個(gè)A/D轉(zhuǎn)換器(有的單片機(jī)集成有A/D轉(zhuǎn)換器,則更為方便)。如果A/D轉(zhuǎn)化器的分辨率為n位,理論上是可以擴(kuò)展2^n(2的n次方)個(gè)按鍵。
這是一種接AD轉(zhuǎn)化器的方案,有兩種:第一種是并聯(lián)式;第二種是串聯(lián)式。在功能上也有些不同。第一種的話各個(gè)電阻值各不相同,當(dāng)按下不同按鍵時(shí),進(jìn)入AD的模擬量是不一樣的,通過AD轉(zhuǎn)換,就可以得到按下的是哪個(gè)按鍵。方式一還可以同時(shí)識(shí)別多個(gè)按鍵,即可以設(shè)置組合鍵,只要電阻取得合適。
方式二各個(gè)電阻可以取一樣的,方便計(jì)算,但是不能有組合按鍵。因?yàn)楫?dāng)按下上面的按鍵后,下面所有按鍵都會(huì)被短路。(在實(shí)際運(yùn)用中,還需要接地,這里沒有畫出)。前面說理論上可以擴(kuò)展2^n個(gè)按鍵,這只是理論,因?yàn)檫@里電阻的精度有限,所以實(shí)際是不可能的,兩個(gè)模擬量之間要有足夠大的差值,程序才可能準(zhǔn)確的分辨。
上面就是我介紹的五種按鍵擴(kuò)展方案,后面幾種比較另類,不過也有他們的優(yōu)點(diǎn)。以上電路我都仿真過,可以實(shí)現(xiàn)。
附方案4鍵盤掃描源代碼:
sbit line_1=P0.1;
sbit line_2=P0.2;
sbit line_3=P0.3;
sbit line_4=P0.4
char key=0;
void key_scan()
{
line_1=line_2=line_3=line_4=1;
if(~(line_1&&line_2&&line_3&&line_4))
{
if(line_1==0) {key=13;return;}
if(line_2==0) {key=14; return;}
if(line_3==0) {key=15;return;}
if(line_4==0) {key=16; return;}
}
line_2=line_3=line_4=1;
line_1=0;
if(~(line_2&&line_3&&line_4))
{
delay();
if(line_2==0) {key=1;return;}
if(line_3==0) {key=2;return;}
if(line_4==0) {key=3;return;}
}
line_1=line_3=line_4=1;
line_2=0;
if(~(line_1&&line_3&&line_4))
{
delay();
if(line_3==0) {key=5;return;}
if(line_4==0) {key=6;return;}
}
line_1=line_2=line_4=1;
line_3=0;
if(~(line_2&&line_1&&line_4))
{
delay();
if(line_4==0) {key=9;return;}
}
line_4=0;
line_1=line_2=line_3=1;
if(~(line_2&&line_3&&line_1))
{
delay();
if(line_1==0) {key=10;return;}
if(line_2==0) {key=11;return;}
if(line_3==0) {key=12;return;}
}
line_3=0;
line_1=line_2=line_4=1;
if(~(line_2&&line_3&&line_4))
{
delay();
if(line_1==0) {key=7;return;}
if(line_2==0) {key=8;return;}
}
line_2=0;
line_1=line_3=line_4=1;
if(~(line_2&&line_3&&line_4))
{
delay();
if(line_1==0) {key=4;return;}
}
return;
}
評(píng)論