当前位置: 首页 > news >正文

基于FPGA的按键消抖

按键工作原理

当KEY1按下时,整条电路就会导通,这个时候KEY1就是低电平;

当KEY1松开时,整条电路就会断开,这个时候KEY1就是高定平;

我们可以通过判断KEY1的高低电平来判断按键是否被按下。 

为什么按键消抖 

由于机械按键的物理特性缘故,按键在按下的过程中,会出现一段时间的抖动,同时在放开按键的过程中也出现一段时间的抖动,这就导致在判断时候可能检测为多次的按键按下,一般我们认为检测到一次按键为低电平,就可以认为按键被按下了,所以我们在使用按键时必须进行消抖,以保证按键被按下时只检测到一次低电平。

图1是未消消抖,可以看到按键在按下和松开是会存在抖动,一般是在20ms左右,如果在这个抖动区间对按键进行判断就会出现多次按下的结果,影响实际应用。

 图2是按键消抖后的结果,我们判断到抖动后,做一个固定的时间延迟,延迟之后对按键进行对应的采样判断即可。

 

按键框计图 

 key_debouncer模块实现计数功能:当按键输入有变化时,计时器清零,否则就累加,直到加到一个预定值(例如 10ms),就认为按键稳定,输出按键值,这样就得到以后没有抖动的按键值。

edge_detect:对输出的稳定按键值做上升沿或者下降沿判断就可以了。

 系统程序框架

本实验是通过按键来控制流水灯的变化,每当按键按下一次,流水灯就变化一次。

视频讲解可以关注B站账号

http://www.lryc.cn/news/334011.html

相关文章:

  • 1.网络编程-网络协议
  • 代码+视频,手动绘制logistic回归预测模型校准曲线(Calibration curve)(2)
  • 金融数据_Scikit-Learn决策树(DecisionTreeClassifier)实例
  • bash的login shell与non-login shell,以及各自的初始化过程
  • 为什么苹果 Mac 电脑需要使用清理软件?
  • 33. UE5 RPG使用增强输入激活GameplayAbility(三)
  • speech to text 库FastASR交叉编译arm target的配置
  • WPS快速将插入Excle数据插入Word
  • Springboot 集成Rabbitmq之延时队列
  • 【云开发笔记NO.22】运用云原生产品打造技术中台
  • C++进阶(五) 哈希
  • 【算法基础】基于异或的排序、基于异或的经典面试题
  • HTML2:列表和表格
  • 用于无人机小型化设计的高精度温补晶振
  • 轨迹规划 | 图解最优控制LQR算法(附ROS C++/Python/Matlab仿真)
  • 工业视觉检测
  • wheeltec轮趣ROS教育机器人的网络连接
  • 【Linux ARM 裸机】开发环境搭建
  • 怎么保证缓存与数据库的最终一致性?
  • 免费SSL通配符证书/SSL泛域名证书获取教程
  • mysql结构与sql执行流程
  • vue快速入门(十二)v-key索引标志
  • 智能网联汽车自动驾驶数据记录系统DSSAD数据配置
  • linux知识点
  • 微信小程序实现滚动标签
  • 大语言模型上下文窗口初探(下)
  • Java整合ElasticSearch8.13
  • 2.网络编程-HTTP和HTTPS
  • MTK i500p AIoT解决方案
  • ES入门十四:分词器