在做項目(工程)的時候,我們經(jīng)常要用到比較多的按鍵,而且IO資源緊張,于是我們就想方設(shè)法地在別的模塊中節(jié)省IO口,好不容易擠出一兩個IO口,卻發(fā)現(xiàn)仍然不夠用,實在沒辦法了就添加一個IC來掃鍵。一個IC雖然價格不高,但對于大批量生產(chǎn)而且產(chǎn)品利潤低的廠家來說,這是一筆不菲的開支!
那,我們能不能想到比較好的掃鍵方法:用最少的IO口,掃最多的鍵?可以嗎?
舉個例:給出5個IO口,能掃多少鍵?有人說是2*3=6個,如圖一:
圖二
不多不少,正好10個鍵!這種掃鍵方式比較少見吧!漂亮!掃鍵流程:設(shè)IO1輸出為“0”,檢測IO2…IO5,若判斷有相應(yīng)健按下,則可知有?。?/span>若無鍵,則繼續(xù)掃鍵:設(shè)IO2輸出為“0”,檢測IO3,IO4,IO5,判斷有無鍵按下,如此類推。這里應(yīng)注意:當(dāng)掃某一IO口(輸出為“0”)時,不要去檢測已經(jīng)掃過的IO口。如:此時設(shè)置IO2輸出為“0”,依次檢測IO3,IO4,IO5,但不要去檢測IO1,否則會出錯(為什么,請思考)。
真強!被您看出20個鍵!多了一個對稱的三角形??墒?,像這樣的排列能正確掃20個鍵嗎?回答是肯定的:不能!上下三角形相互對稱,其對稱掃出的鍵無法區(qū)別。有沒有注意到分析圖三時提到的注意點?(à“當(dāng)掃某IO口時,不要去檢測已經(jīng)掃過的IO口,否則會出錯”)
我們分析一下圖四:當(dāng)IO1輸出“0”時,按下K11或K11’鍵都能被IO2檢測到,但I(xiàn)O2檢測卻無法區(qū)別K11和K11’鍵!同理,不管掃哪個IO口,都有兩個對稱的鍵不能區(qū)分。
我們假想,如果能把對稱鍵區(qū)分開來,我們就能正常地去判斷按鍵。我們在思考:有沒有單向?qū)ㄐ云骷??有!見圖五!
夠酷吧!等等,大家先別滿足現(xiàn)狀,我們再看一下圖二,是不是有點啟發(fā)?對,我們再分析一下“用5個IO口對地衍生的5個鍵”??磮D六:
S = (N-1)*N + N ――啟用二極管
S = (N-1)*N /2 + N ――省掉二極管
免責(zé)聲明:本文來源嵌入式ARM,版權(quán)歸原作者所有。如涉及作品版權(quán)問題,請與我聯(lián)系刪除。
長按前往圖中包含的公眾號關(guān)注
免責(zé)聲明:本文內(nèi)容由21ic獲得授權(quán)后發(fā)布,版權(quán)歸原作者所有,本平臺僅提供信息存儲服務(wù)。文章僅代表作者個人觀點,不代表本平臺立場,如有問題,請聯(lián)系我們,謝謝!