verilog实现按键消抖检测

今天进行了fpga的按键操作学习,本来以为很简单,却是费了好长的时间。

今天下午很随意的觉得按键检测应该和时序电路没啥关系,简单写了个组合逻辑的程序,结果啥都不是。

因为按键肯定要考虑抖动的影响,如果要消抖就必须考虑到前一时刻和该时刻的按键值的变化。因此还是应该用时序逻辑。

随后参考了一篇在网上赞为经典的博文《基于verilog按键消抖设计》。读了他的代码花了不少时间分析,还是很有启发的。核心的算法就是:


通过前一时刻和后一时刻采到的按键值相与来判断按键是否真的按下。


最后借用他的思想,结合自己的板子写了如下程序,实现了按键操作功能。



  • 4
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值