实验原理
按键作为基本的人机输入接口,由于其机械特性,在按键按下或松开的时候,都是会有抖动的。按键小豆的方式有很多。我的方法是通过计时来消抖,通过一个计数器,当按键输入有变化时,计数器清零,否则就累加,直到加到一个预定值,就认为按键稳定,输出按键值,这样就得到了没有抖动的按键值。
module key(
input clk,
input key_in, //按键输入
output reg key_out //按键输出
);
parameter COUNT_VALUE = 20;
reg [5:0]cnt_press; //按键按下计数器
reg [5:0]cnt_release;//按键未按计数器
always @(posedge clk)
begin
if(key_in == 1'b1)//按键未按下
begin
cnt_press <= 6'd0;
cnt_release <= cnt_release + 1;
end
if(key_in == 1'b0)//按键按下
begin
cnt_press <= cnt_press + 1;
cnt_release <= 6'd0;
end
end
//------输出按键状态,0-按键按下,1-按键未按----------
always @(posedge clk)
begin
if(cnt_press == COUNT_VALUE)
key_out <= 1'b0;
else if(cnt_release == COUNT_VALUE)
key_out <= 1'b1;
end