基于FPGA的可鍵盤(pán)控制計(jì)數(shù)電路的設(shè)計(jì)與實(shí)現(xiàn)
2.1.2 鍵盤(pán)掃描電路工作原理
圖3為鍵盤(pán)掃描原理圖。CLK_40K為鍵盤(pán)掃描工作時(shí)鐘,連續(xù)讀取數(shù)據(jù)輸入端KEY_LIE[3..0]的信息;CLK_2K為鍵值控制工作時(shí)鐘信號(hào),無(wú)鍵按下時(shí)控制電路循環(huán)掃描輸出;P3,P2,P1,P0為鍵盤(pán)譯碼輸出BCD碼形式;START端為數(shù)據(jù)輸出標(biāo)志信號(hào),當(dāng)P3-P0輸出時(shí),START端輸出一個(gè)脈沖。工作時(shí),由行信號(hào)輸出端KEY_HANG[2..0]循環(huán)輸出“110”,“101”,“011”。當(dāng)沒(méi)有按鍵按下時(shí),掃描電路列信號(hào)輸入端檢測(cè)到“1111”。當(dāng)有按鍵按下時(shí),例如按下1鍵,此時(shí)行信號(hào)KEY_HANG[2..0]輸出“011”,由圖2可知。列信號(hào)輸入端將檢測(cè)到“0111”,在掃描譯碼時(shí),可根據(jù)行信號(hào)輸出和列信號(hào)輸入數(shù)據(jù)同時(shí)判斷“0110111”對(duì)應(yīng)數(shù)據(jù)為1。本文引用地址:http://www.ex-cimer.com/article/190980.htm
2.1.3 鍵盤(pán)掃描電路VEIDL實(shí)現(xiàn)
鍵盤(pán)掃描電路主要有判斷按鍵有無(wú)按下,鍵值識(shí)別和去抖動(dòng)處理等功能。其中去抖處理主要為了避免外界振動(dòng)引起按鍵誤動(dòng),以及保證按鍵每穩(wěn)定閉合一次,系統(tǒng)僅對(duì)其響應(yīng)一次。采用不同的鍵盤(pán)其機(jī)械抖動(dòng)時(shí)間各異,本文設(shè)置去抖時(shí)間為20 ms。圖4為鍵盤(pán)掃描電路VHDL描述流程圖。以下是去抖動(dòng)程序關(guān)鍵代碼:
2.2 可預(yù)置數(shù)BCD碼計(jì)數(shù)電路
圖5為可預(yù)置數(shù)BCD碼計(jì)數(shù)電路。置數(shù)端LOAD為高電平時(shí),將通過(guò)鍵盤(pán)設(shè)置的數(shù)并行置入到D3~D0。然后對(duì)輸入的脈沖直接進(jìn)行BCD碼減法計(jì)數(shù),由Q3~Q0輸出。計(jì)數(shù)結(jié)束,ENDCNT端輸出一個(gè)脈沖。
評(píng)論