技巧分享:如何在FPGA内实现按键消抖?
品慧电子讯在FPGA内实现按键消抖的方法多种多样,但是最简单的是采用移位寄存器的方法进行消抖。因为移位寄存器的方法不需要对时钟进行分频,也不需要进行延时等复杂操作。本文就为大家讲解这种在FPGA内实现按键消抖的方法。抖动的产生通常的按键所用开关为机械弹性开关,当机械触点断开、闭合时,由于机械触点的弹性作用,一个按键开关在闭合时不会马上稳定地接通,在断开时也不会一下子断开。因而在闭合及断开的瞬间均伴随有一连串的抖动,为了不产生这种现象而作的措施就是按键消抖。抖动时间抖动时间的长短由按键的机械特性决定,一般为5ms~10ms。这是一个很重要的时间参数,在很多场合都要用到按键稳定闭合时间的长短则是由操作人员的按键动作决定的,一般为零点几秒至数秒。键抖动会引起一次按键被误读多次。为确保FPGA对键的一次闭合仅作一次处理,必须去除键抖动。在键闭合稳定时读取键的状态,并且必须判别到键释放稳定后再作处理。


- 第一页:FPGA内实现消抖的方法
- 第二页:消抖方法的参考Verilog代码
参考Verilog代码//模块名:EdgeDetect,边沿检测//button:按键,无键按下时为高电平//clk:10M时钟//rst:复位按钮,低电平有效//rise:检测到上升沿,高电平有效,宽度为1个clk//fall:检测到下降沿,高电平有效,宽度为1个clkmodule EdgeDetect(input clk,input rst,input button,output reg rise,output reg fall);reg[7:0] samp;//移位寄存器采集button键值//移位寄存器采集button信息always@(posedge clk or negedge rst)beginif(!rst)samp<=8''b1111_1111;elsesamp<={samp[7:1],button};end//产生上升沿信息always@(posedge clk or negedge rst)beginif(!rst)rise<=1''b0;else if(samp==8''b1111_1110)rise<=1''b1;elserise<=1''b0;end//产生下降沿信息always@(posedge clk or negedge rst)beginif(!rst)fall<=1''b0;else if(samp==8''b0111_1111)fall<=1''b1;elsefall<=1''b0;endendmodule<上一页12
- 第一页:FPGA内实现消抖的方法
- 第二页:消抖方法的参考Verilog代码