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