【Espier FPGA VHDL学习帖】第17帖 按键消抖
按键消抖程序的思路都是来源于特权同学的按键消抖,特权同学采用的是VHDL改编了他的程序。
20ms就会读取键值,把这个键值放到寄存器low_sw的值锁存到low_sw
wire [2:0] led_ctrl = low_sw_r[2:0] &( ~low_sw[2:0]); 这是特权同学
Key_an是检测第一次按下,同时也是cnt计数,本开发板用的大概为48M晶振,并没有进行分频操作,所以
(1110101001100000000)2 这里我们直接用全1
初始值 1 1 0 0 1 1 -> key_rst
0 0 1 1 0 0 ->取反
1 1 0 0 1 ->key_rst_r
0 1 0 0 0 key_an
把1跳变到led_ctrl拉高。回顾前面的20ms内如果出现按键被按下,
那么有一个时钟周期里led_ctrl的置高就使得相应的LED灯的亮灭做一次改变,这就达到了目的。
附上我的工程
LESSON6_SW_xiaodou.rar
(2.93 MB, 下载次数: 26)
[
本帖最后由 常见泽1 于 2013-12-15 02:27 编辑 ]