手动按键复位程序(包含按键消抖)

 1 //这是一个按键复位程序
 2 module stable_key(
 3     i_clkin,
 4     i_inKey,
 5     o_outKey
 6  );
 7
 8 input i_clkin;
 9 input i_inKey;
10 output o_outKey;
11
12 reg key=1;
13 reg key_get = 1;     //key输出指示信号
14 reg [20:0]  cntK = 0;
15 reg o_outKey_r = 1;
16
17 always@(posedge i_clkin)
18     if(key != i_inKey)                  //首先判断i_inKey信号是否有电平变化,
19         begin                           //如果有电平变化,计数器和输出信号指示信号复位
20             cntK <= 0;
21             key_get <= 0;               //按键消抖
22         end
23     else if(cntK == 1999999)
24         begin
25             o_outKey_r <= key;
26             cntK <= 0;
27             key_get <= 1;
28         end
29     else if(key_get == 0)
30         begin
31             cntK <= cntK + 21‘b1;
32         end
33
34     key <= i_inKey;
35
36
37 assign o_outKey = o_outKey_r;
38 endmodule

程序解释:

时间: 2024-11-10 07:48:20

手动按键复位程序(包含按键消抖)的相关文章

最好的按键扫描和消抖方法,适用于复合、长按、按下或抬起响应按键

刚参加工作的时候,看了一些同事采用的按键扫描和消抖方法,对比学校里和网上查到的按键处理,发现觉得不尽善尽美,有以下几点: 1. 消抖复杂,效率低.有人直接在电平判断后使用delay()函数,进行消抖,耽误时间:有人在按键电平中断中进行消抖和处理,导致其他的服务反应慢,不适合做实时系统: 2. 许多功能在不同界面下是不同的,把按键处理在中断进行,导致分支很多,业务流不清晰. 3. 特殊功能按键的处理麻烦.在需要长按作为特殊按键.复合按键响应.复合按键长按响应的时候,需要增加很多的标志位,反复使用i

【黑金原创教程】【FPGA那些事儿-驱动篇I 】实验二:按键模块① - 消抖

实验二:按键模块① - 消抖 按键消抖实验可谓是经典中的经典,按键消抖实验虽曾在<建模篇>出现过,而且还惹来一堆麻烦.事实上,笔者这是在刁难各位同学,好让对方的惯性思维短路一下,但是惨遭口水攻击 ... 面对它,笔者宛如被甩的男人,对它又爱又恨.不管怎么样,如今 I'll be back,笔者再也不会重复一样的悲剧. 按键消抖说傻不傻说难不难.所谓傻,它因为原理不仅简单(就是延迟几下下而已),而且顺序语言(C语言)也有无数不尽的例子.所谓难,那是因为人们很难从单片机的思维跳出来 ... 此外,

关于按键消抖实验

对于特权同学按键消抖程序的理解:(程序源码见<深入浅出玩转FPGA>P191) 第一个always块中,在每个时钟周期(clk)对按键值进行采样 第二个always块中,利用边沿脉冲检测法,当key_rst有下降沿时,key-an将输出一个周期的高脉冲 第三个always块中,利用cnt进行循环计数(计数时间周期大约20ms),当keg-an为1时,cnt将清零,然后从零开始计数(由此产生一个20ms,从而消除抖动部分的影响) 第四个always块中,每当cnt从0计数到20'hfffff(即

Verilog HDL那些事_建模篇笔记(实验三:按键消抖)

实验三:按键消抖 首先将按键消抖功能分成了两个模块,电平检查模块和10ms延迟模块.电平检测模块用来检测按键信号的变化(是否被按下),10ms延迟模块用来稳定电平检查模块的输入,进而稳定按键信号,防止其抖动而产生的信号跳变而影响输出. 设计思路:     1.当电平检测模块检查到按键被按下(输入由高电平变为低电平),则拉高H2L_Sig电平,然后拉低. 2.10ms延迟模块,检测到H2L_Sig高电平,则对其进行10ms过滤,拉高输出. 3.当按键被释放,电平检测模块会拉高L2H_Sig电平,然

09A-独立按键消抖实验01——小梅哥FPGA设计思想与验证方法视频教程配套文档

芯航线--普利斯队长精心奉献 ? 实验目的: 1.复习状态机的设计思想并以此为基础实现按键消抖 2.单bit异步信号同步化以及边沿检测 3.在激励文件中学会使用随机数发生函数$random 4.仿真模型的概念 实验平台:芯航线FPGA核心板 实验原理: ????按键在电子设计中使用的最多,从复位到控制设置均可以看到其身影.现在按键的功能也种类也越来越多,例如多向按键.自锁按键.薄膜按键等.普通按键其硬件示意图如图9-1所示. 图9-1 按键示意图 芯航线开发板所载的为两脚贴片按键,分别位于开发板

基础项目(6)基于尖峰脉冲的按键消抖程序设计讲解

 写在前面的话 我们通常所用的按键开关为机械弹性开关,当机械触点断开.闭合时,由于机械触点的弹性作用,一个按键开关在闭合时不会马上稳定地接通,在断开时也不会马上断开.因而在闭合及断开的瞬间均伴随有一连串的抖动,为了避免这种现象造成的干扰而作的措施就是按键消抖. 抖动时间的长短由按键的机械特性决定,一般为5ms-10ms.按键稳定闭合时间的长短则是由操作人员的按键动作决定的,一般为零点几秒至数秒.键抖动会引起一次按键被误读多次.为确保智能单元对按键的一次闭合仅作一次处理,必须消除键抖动.在按键闭合

按键消抖之终极解决方案

1.按键消抖的原理 图1.按键抖动示意图 我们平常所用的按键为机械弹性开关,由于触点的弹性作用,按键在闭合时不会马上稳定的接通,而是有一段时间的抖动,在断开时也不会立即断开.抖动时间由按键的机械特性所决定,一般为5ms~10ms.所以我们在做按键检测时都要加一个消抖的过程. 按键消抖主要有两种方案: 一是延时重采样:二是持续采样. 从理论上来说,延时(如10ms)重采样的准确率肯定低于持续采样. 2.按键消抖的方法 (1)延时重采样 延时重采样的意思是,当第一次检测到键值由'1'变为'0'时,再

jQueryAjax模拟按键消抖(可设置抖动延迟时间)

在硬件中,按键等都会有抖动现象,如何消除抖动,不重复触发事件呢,这就要用到消抖机制了. 这是我用jQuery模拟硬件消抖原理,额,可能是吧...又不对的地方,希望有高手指点指点. ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56

按键消抖学习

KevinChen的博客——KevinChen's Blog [博客大赛]按键消抖之终极解决方案 http://bbs.ednchina.com/BLOG_ARTICLE_3020402.HTM EE_FPGA基础教程系列 -- 按键消抖  http://wenku.baidu.com/link?url=CGJkd0CRwzW-dreuF5FSiNWbUDHGE6HQIO3A8kWmERPkJmkr9vh2YOPLq3vKC8wvkaLxOa4iwSVM-ESqiODsvJwOrOpNTS24_