0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

基于FPGA實(shí)現(xiàn)按鍵消抖處理

FPGA技術(shù)實(shí)戰(zhàn) ? 來(lái)源:FPGA技術(shù)實(shí)戰(zhàn) ? 2024-10-24 14:54 ? 次閱讀

引言:按鍵在電子產(chǎn)品中經(jīng)常用到,由于按鍵的機(jī)械特性,按鍵在閉合或松開(kāi)的瞬間伴隨著一連串的抖動(dòng),這樣的抖動(dòng)將直接影響設(shè)計(jì)系統(tǒng)的穩(wěn)定性。因此,必須對(duì)抖動(dòng)進(jìn)行處理。本文介紹如何在FPGA中實(shí)現(xiàn)按鍵消抖處理。

1. 原理概述

在機(jī)械按鍵的觸點(diǎn)閉合和斷開(kāi)時(shí),都會(huì)產(chǎn)生抖動(dòng),為了保證系統(tǒng)能正確識(shí)別按鍵的開(kāi)關(guān),就必須對(duì)按鍵的抖動(dòng)進(jìn)行處理。按鍵抖動(dòng)如下圖所示。

wKgZoWcZ70mAC2W4AACAmfe5EFc997.png

圖1:按鍵機(jī)械抖動(dòng)

wKgaomcZ70mACMGpAAB6oBD80YQ996.png

圖2:按鍵輸入在FPGA IO接口產(chǎn)生的抖動(dòng)

抖動(dòng)時(shí)間的長(zhǎng)短由按鍵的機(jī)械特性決定,一般為5ms~10ms。這是一個(gè)很重要的時(shí)間參數(shù),在很多場(chǎng)合都要用到。按鍵穩(wěn)定閉合時(shí)間的長(zhǎng)短則是由操作人員的按鍵動(dòng)作決定的,一般為零點(diǎn)幾秒至數(shù)秒。按鍵抖動(dòng)會(huì)引起一次按鍵被誤讀多次,如圖2所示。

按鍵消抖處理即:每次在按鍵閉合或松開(kāi)期間,跳過(guò)這段抖動(dòng)時(shí)間,再檢測(cè)按鍵的狀態(tài)。故通過(guò)簡(jiǎn)單的延時(shí)就可實(shí)現(xiàn)按鍵的消抖動(dòng)。

2.軟件代碼設(shè)計(jì)

按鍵濾波模塊key_filter.v設(shè)計(jì)采用狀態(tài)機(jī)實(shí)現(xiàn)按鍵按下和彈起檢測(cè)。

10ms延遲定時(shí)器

always @(posedge clk_i)begin //10ms 延遲定時(shí)器
    if(cnt10ms < CNT_10MS) 
        cnt10ms <= cnt10ms + 1'b1;
    else 
        cnt10ms <= 25'd0;
end

按鍵檢測(cè)狀態(tài)機(jī):

always @(posedge clk_i)begin
    key_s_r <= key_s;
end


always?@(posedge?clk_i)begin
    if(en_10ms)begin //10ms 延遲定時(shí)器
        case(key_s)
        KEY_S0:begin
           if(!key_i) //判斷按鍵是否按下,如果按下,則轉(zhuǎn)入狀態(tài)KEY_S1
               key_s <= KEY_S1; 
        end  
        KEY_S1:begin
           if(!key_i) //10ms后,再次判斷按鍵是否按下,
               key_s <= KEY_S2; //如果按下,則轉(zhuǎn)入狀態(tài)KEY_S2
            else 
               key_s <= KEY_S0; //如果未按下,則轉(zhuǎn)回KEY_S0
        end 
        KEY_S2:begin
           if(key_i) //10ms后,判斷按鍵是否彈起,如果彈起,則轉(zhuǎn)入狀態(tài)KEY_S3
               key_s <= KEY_S3; 
        end  
        KEY_S3:begin
           if(key_i) //10ms后,再次判斷按鍵是否彈起,
              key_s <= KEY_S0; //如果彈起,則轉(zhuǎn)入狀態(tài)KEY_S0
            else   
              key_s <= KEY_S2; //如果未彈起,則轉(zhuǎn)回KEY_S2
        end
        endcase                  
    end
end
按鍵有效輸出:當(dāng)狀態(tài)從KEY_S1 轉(zhuǎn)到 KEY_S2 代表依次按鈕按下 key_cap 輸出一次高電平。
assign key_cap = (key_s==KEY_S2)&&(key_s_r==KEY_S1);

3.硬件測(cè)試與驗(yàn)證

硬件平臺(tái):XC7Z035FFG676-2

Vivado軟件:2017.4

工程編譯完成后,下載bit文件到電路板,測(cè)試結(jié)果如下所示。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • FPGA
    +關(guān)注

    關(guān)注

    1625

    文章

    21619

    瀏覽量

    601149
  • 接口
    +關(guān)注

    關(guān)注

    33

    文章

    8441

    瀏覽量

    150704
  • 狀態(tài)機(jī)
    +關(guān)注

    關(guān)注

    2

    文章

    491

    瀏覽量

    27452
  • 按鍵消抖
    +關(guān)注

    關(guān)注

    2

    文章

    27

    瀏覽量

    10437

原文標(biāo)題:FPGA入門基礎(chǔ)之按鍵消抖實(shí)驗(yàn)

文章出處:【微信號(hào):FPGA技術(shù)實(shí)戰(zhàn),微信公眾號(hào):FPGA技術(shù)實(shí)戰(zhàn)】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    按鍵電路的實(shí)現(xiàn)方式

    按鍵通常的按鍵所用開(kāi)關(guān)為機(jī)械彈性開(kāi)關(guān),當(dāng)機(jī)械觸點(diǎn)斷開(kāi)、閉合時(shí),由于機(jī)械觸點(diǎn)的彈性作用,一個(gè)按鍵開(kāi)關(guān)在閉合時(shí)不會(huì)馬上穩(wěn)定地接通,在斷開(kāi)時(shí)也
    的頭像 發(fā)表于 08-29 11:25 ?4531次閱讀

    fpga教程之——按鍵

    電平,這次對(duì)按鍵進(jìn)行操作則是對(duì)FPGA進(jìn)行輸入了?! ?. 按鍵  2.1 按鍵輸入原理  
    發(fā)表于 02-27 11:49

    按鍵

    請(qǐng)問(wèn)大家的按鍵是用什么方法解決的,如普通的按鍵如何。
    發(fā)表于 09-26 22:17

    FPGA按鍵的方法

    FPGA按鍵的方法
    發(fā)表于 05-01 16:12

    技術(shù)分享:明德?lián)P按鍵的原理和基于fpga設(shè)計(jì)

    高頻抖動(dòng)略去。需要注意的是,軟件需要占據(jù)一定的系統(tǒng)資源。盡管硬件和軟件
    發(fā)表于 08-02 10:38

    【Runber FPGA開(kāi)發(fā)板】配套視頻教程——按鍵實(shí)驗(yàn)

    本視頻是Runber FPGA開(kāi)發(fā)板的配套視頻課程,主要介紹按鍵的方法和FPGA如何實(shí)現(xiàn)
    發(fā)表于 04-13 10:35

    MCU按鍵問(wèn)題

    按鍵問(wèn)題機(jī)械按鍵是必須的,1、延時(shí)
    發(fā)表于 11-04 06:37

    STM32單片機(jī)按鍵FPGA按鍵的相關(guān)資料分享

    寫在前面:STM32單片機(jī)按鍵FPGA按鍵
    發(fā)表于 01-18 06:39

    按鍵都有哪些處理方式?

    按鍵都有哪些處理方式除了硬件電路用軟件怎么實(shí)現(xiàn)
    發(fā)表于 11-01 07:06

    基于FPGA按鍵電路設(shè)計(jì)

    采用了VHDL語(yǔ)言編程的設(shè)計(jì)方法,通過(guò)FPGA來(lái)實(shí)現(xiàn)按鍵的硬件電路。論述了基于計(jì)數(shù)器、RS觸發(fā)器和狀態(tài)機(jī)3種方法來(lái)
    發(fā)表于 12-05 14:13 ?224次下載

    VHDL—按鍵

    按鍵檢測(cè)需要,一般有硬件和軟件兩種方式。硬件就是加去抖動(dòng)電路,這樣從根本上解決按鍵抖動(dòng)問(wèn)題。除了用專用電路以外,用可編程FPGA或者CP
    發(fā)表于 11-11 17:17 ?2次下載

    vhdl按鍵程序(七種方式實(shí)現(xiàn)按鍵

    按鍵通常的按鍵所用開(kāi)關(guān)為機(jī)械彈性開(kāi)關(guān),當(dāng)機(jī)械觸點(diǎn)斷開(kāi)、閉合時(shí),由于機(jī)械觸點(diǎn)的彈性作用,一個(gè)按鍵開(kāi)關(guān)在閉合時(shí)不會(huì)馬上穩(wěn)定地接通,在斷開(kāi)時(shí)也
    發(fā)表于 01-29 16:04 ?5.6w次閱讀
    vhdl<b class='flag-5'>按鍵</b><b class='flag-5'>消</b><b class='flag-5'>抖</b>程序(七種方式<b class='flag-5'>實(shí)現(xiàn)</b><b class='flag-5'>按鍵</b><b class='flag-5'>消</b><b class='flag-5'>抖</b>)

    按鍵的軟件和硬件方法

    采用鍋?zhàn)衅?b class='flag-5'>按鍵測(cè)量波形。按鍵按下與抬起的部分都出現(xiàn)抖動(dòng),大致時(shí)間10ms左右。為了防止按鍵誤按或者重復(fù)識(shí)別,必須要按鍵
    的頭像 發(fā)表于 03-01 10:53 ?1.4w次閱讀
    <b class='flag-5'>按鍵</b><b class='flag-5'>消</b><b class='flag-5'>抖</b>的軟件和硬件方法

    FPGA內(nèi)實(shí)現(xiàn)按鍵的方法

    通常的按鍵所用開(kāi)關(guān)為機(jī)械彈性開(kāi)關(guān),當(dāng)機(jī)械觸點(diǎn)斷開(kāi)、閉合時(shí),由于機(jī)械觸點(diǎn)的彈性作用,一個(gè)按鍵開(kāi)關(guān)在閉合時(shí)不會(huì)馬上穩(wěn)定地接通,在斷開(kāi)時(shí)也不會(huì)一下子斷開(kāi)。因而在閉合及斷開(kāi)的瞬間均伴隨有一連串的抖動(dòng),為了不產(chǎn)生這種現(xiàn)象而作的措施就是按鍵
    的頭像 發(fā)表于 09-05 10:43 ?1164次閱讀
    <b class='flag-5'>FPGA</b>內(nèi)<b class='flag-5'>實(shí)現(xiàn)</b><b class='flag-5'>按鍵</b><b class='flag-5'>消</b><b class='flag-5'>抖</b>的方法

    如何在FPGA實(shí)現(xiàn)按鍵

    FPGA(現(xiàn)場(chǎng)可編程門陣列)中實(shí)現(xiàn)按鍵是一個(gè)重要的設(shè)計(jì)環(huán)節(jié),特別是在處理用戶輸入時(shí),由于物
    的頭像 發(fā)表于 08-19 18:15 ?1221次閱讀