<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          新聞中心

          EEPW首頁(yè) > EDA/PCB > 設(shè)計(jì)應(yīng)用 > 基于FPGA的可鍵盤(pán)控制計(jì)數(shù)電路的設(shè)計(jì)與實(shí)現(xiàn)

          基于FPGA的可鍵盤(pán)控制計(jì)數(shù)電路的設(shè)計(jì)與實(shí)現(xiàn)

          作者: 時(shí)間:2011-11-11 來(lái)源:網(wǎng)絡(luò) 收藏

          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

          d.JPG


          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)鍵代碼:
          e.JPG
          c.JPG

          c1.jpg


          2.2 可預(yù)置數(shù)BCD碼
          圖5為可預(yù)置數(shù)BCD碼。置數(shù)端LOAD為高電平時(shí),將通過(guò)鍵盤(pán)設(shè)置的數(shù)并行置入到D3~D0。然后對(duì)輸入的脈沖直接進(jìn)行BCD碼減法計(jì)數(shù),由Q3~Q0輸出。計(jì)數(shù)結(jié)束,ENDCNT端輸出一個(gè)脈沖。

          f.JPG



          評(píng)論


          相關(guān)推薦

          技術(shù)專(zhuān)區(qū)

          關(guān)閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();