通常的按鍵所用開關為機械彈性開關,當機械觸點斷開、閉合時,由于機械觸點的彈性作用,一個按鍵開關在閉合時不會馬上穩定地接通,在斷開時也不會一下子斷開。因而在閉合及斷開的瞬間均伴隨有一連串的抖動,為了不產生這種現象而作的措施就是按鍵消抖。
抖動時間
抖動時間的長短由按鍵的機械特性決定,一般為5ms~10ms。這是一個很重要的時間參數,在很多場合都要用到按鍵穩定閉合時間的長短則是由操作人員的按鍵動作決定的,一般為零點幾秒至數秒。鍵抖動會引起一次按鍵被誤讀多次。為確保FPGA對鍵的一次閉合僅作一次處理,必須去除鍵抖動。在鍵閉合穩定時讀取鍵的狀態,并且必須判別到鍵釋放穩定后再作處理。
圖1 按鍵抖動
FPGA內實現消抖的方法
在FPGA內實現按鍵消抖的方法多種多樣,但是最簡單的是采用移位寄存器的方法進行消抖。因為移位寄存器的方法不需要對時鐘進行分頻,也不需要進行延時等復雜操作,即可實現對按鍵邊沿的檢測。假設未按下時鍵值=1.
1、在無鍵按下時,移位寄存器samp[7:0]始終采集到高電平,即samp[7:0]=8'b1111_1111;
2、 當鍵按下時,samp[7:0]將采集到低電平,數據的變化方式為samp[7:0]=8'b1111_1110--> 8'b1111_1100-->8'b1111_1000--> ........——>8'b0000_0000;samp[7:0]=8'b1111_1110即為按鍵下降沿。
3、 當松開按鍵時,samp[7:0]將重新采集到高電平,數據變化方式為samp[7:0]=8'b0000_0001--> 8'b0000_0011--> ........-->8'b1111_1111;當samp[7:0]=8'b0111_1111時,即為按鍵上升沿。
圖2 移位寄存器消抖原理圖
審核編輯:湯梓紅
-
FPGA
+關注
關注
1630文章
21797瀏覽量
606019 -
原理圖
+關注
關注
1301文章
6358瀏覽量
235211 -
寄存器
+關注
關注
31文章
5363瀏覽量
121172 -
按鍵消抖
+關注
關注
2文章
27瀏覽量
10486
原文標題:在FPGA內實現按鍵消抖的方法(附參考Verilog代碼)
文章出處:【微信號:zhuyandz,微信公眾號:FPGA之家】歡迎添加關注!文章轉載請注明出處。
發布評論請先 登錄
相關推薦
評論