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