EDA365欢迎您登录!
您需要 登录 才可以下载或查看,没有帐号?注册
x
3 n& h: l% E- R! M+ e
【Espier FPGA VHDL学习帖】第17帖 按键消抖 ' v9 { J9 B" T# {7 O0 H- B
7 W& k L9 d O5 A' g5 g* o5 Y* }
- h6 [; n: J U( T按键消抖程序的思路都是来源于特权同学的按键消抖,特权同学采用的是VHDL改编了他的程序。
! A, M3 |1 g, w! E1 @& m
( e! p" N+ p5 z; n- _& f6 M
. Z: p' z2 L+ @7 X! g: s20ms就会读取键值,把这个键值放到寄存器low_sw的值锁存到low_sw wire [2:0] led_ctrl = low_sw_r[2:0] &( ~low_sw[2:0]); 这是特权同学
4 ?0 G! `; `7 V
% C2 ^! n( c% o, Q. |7 q; a
4 H; R6 R6 u) B- j5 v& e6 a: vKey_an是检测第一次按下,同时也是cnt计数,本开发板用的大概为48M晶振,并没有进行分频操作,所以 (1110101001100000000)2 这里我们直接用全1
& T* l8 c. y( t 初始值 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
0 [. u( T4 @7 ^) u* G* d8 |: |6 H
* E! }+ m$ W7 T/ s
/ A, J d% D4 R( j5 ?$ L, \* k! [8 p把1跳变到led_ctrl拉高。回顾前面的20ms内如果出现按键被按下, 4 ?; `. j- _; o- }
那么有一个时钟周期里led_ctrl的置高就使得相应的LED灯的亮灭做一次改变,这就达到了目的。 " [/ ] T3 p8 n# F) A& D( I8 c. Z. g7 o
|