久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 12004|回復: 2
打印 上一主題 下一主題
收起左側

verilog學習筆記二:用狀態機實現按鍵的消抖及按鍵按下次數計數

[復制鏈接]
跳轉到指定樓層
樓主
ID:51025 發表于 2014-8-29 17:34 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
module keytest (clk, key, ledout, weiout, key_count);

input clk;
input  [4:0] key;
output reg [7:0] ledout;
output reg [7:0] weiout;


parameter key_init  = 0;
parameter key_delay = 1;
parameter key_check = 2;

reg [15:0] state_clk_count;
output reg [3:0]  key_count ;
reg       state_clk;
reg [1:0]  key_state;
reg [4:0]  key_temp;


initial
begin
key_state = key_init;
state_clk = 0;
state_clk_count = 4'b0000;
key_count = 4'b0000;
key_temp = 4'b1111;
ledout = 7'b11000000;
weiout = ~8'b1000_0000;
end

//狀態機時鐘分頻
always @(posedge clk)
begin
state_clk_count <= state_clk_count + 1;
if(state_clk_count == 16'hffff)
state_clk <= ~ state_clk;
end   

//狀態機
always @(posedge state_clk )
begin
//key_temp  <= key;    //把鍵碼的值賦給寄存器
case (key_state)
key_init :  
if(key == 5'b11111)
key_state <= key_init;
else
   key_state <=key_delay;
key_delay :
if(key == 5'b11111)
key_state <= key_init;
else
   key_state <=key_check;
key_check :
if(key == 5'b11111)    //釋放按鍵后,按鍵計數+1
begin
key_count <= key_count +1;
key_state <= key_init;
end
else                    //按鍵按下時,維持此狀態,直到按鍵釋放
begin
key_state <= key_check;
key_temp  <= key;    //把鍵碼的值賦給寄存器
end
default :
key_state <= key_init;
endcase
end


always @(state_clk or key_count)
begin
case (key_count)
4'b0001 : ledout = 7'b11111001; // 1
4'b0010 : ledout = 7'b10100100; // 2
4'b0011 : ledout = 7'b10110000; // 3
4'b0100 : ledout = 7'b10011001; // 4
4'b0101 : ledout = 7'b10010010; // 5
4'b0110 : ledout = 7'b10000010; // 6
4'b0111 : ledout = 7'b11111000; // 7
4'b1000 : ledout = 7'b10000000; // 8
4'b1001 : ledout = 7'b10010000; // 9
4'b1010 : ledout = 7'b10001000; // A
4'b1011 : ledout = 7'b10000011; // B
4'b1100 : ledout = 7'b11000110; // C
4'b1101 : ledout = 7'b10100001; // D
4'b1110 : ledout = 7'b10000110; // E
4'b1111 : ledout = 7'b10001110;
default : ledout = 7'b11000000;
endcase
end
endmodule


  程序如上,主要思想是將按鍵按下分為幾個狀態:初始化、延時消抖、按鍵檢測,同時,為了實現按鍵的計數,在本程序中的key_check狀態中,當按鍵按下時,把鍵值賦值給鍵值寄存器,等到按鍵松開后,才進行鍵值處理,這樣可以較好的實現按鍵按下計數。當有幾個按鍵時,程序如下所示,思想與上例相同。

module keytest (clk, key, ledout, weiout, key_id,key_count_o);

input clk;
input  [4:0] key;
output reg [7:0] ledout;
output reg [7:0] weiout;
output reg [3:0] key_id;   //鍵碼
output reg [3:0] key_count_o; //連續按鍵次數


parameter key_init  = 0;    //按鍵狀態
parameter key_delay = 1;
parameter key_check = 2;

reg [15:0] state_clk_count;  //狀態機時鐘分頻計數
reg [3:0]  key_count [4:0];  //5個按鍵中,每個按鍵連續按鍵次數寄存  
reg       state_clk;        //狀態機時鐘
reg [1:0]  key_state;       //按鍵狀態寄存
reg [4:0]  key_temp;        //鍵值寄存器


initial
begin
key_state = key_init;
state_clk = 0;
state_clk_count = 4'b0000;
key_id = 4'b0000;
key_temp = 4'b1111;
ledout = 7'b11000000;
weiout = ~8'b1000_0000;
end

//狀態機時鐘分頻
always @(posedge clk)
begin
state_clk_count <= state_clk_count + 1;
if(state_clk_count == 16'hffff)
state_clk <= ~ state_clk;
end   

//狀態機
always @(posedge state_clk )
begin
case (key_state)
key_init :  
if(key == 5'b11111)
key_state <= key_init;
else
   key_state <=key_delay;
key_delay :
if(key == 5'b11111)
key_state <= key_init;
else
   key_state <=key_check;
key_check :
if(key == 5'b11111)    //釋放按鍵后,按鍵計數+1
begin
case (key_temp)
    5'b01111:
begin
key_id <= 1;
key_count_o <= key_count[0];
key_count[0] <= key_count[0] + 1;
key_count[1] <= 0;
key_count[2] <= 0;
key_count[3] <= 0;
key_count[4] <= 0;
end
    5'b10111:
begin
key_id <= 2;
key_count_o <= key_count[1];
key_count[1] <= key_count[1] + 1;
key_count[0] <= 0;
key_count[2] <= 0;
key_count[3] <= 0;
key_count[4] <= 0;
end
    5'b11011:
begin
key_id <= 3;
key_count_o <= key_count[2];
key_count[2] <= key_count[2] + 1;
key_count[0] <= 0;
key_count[1] <= 0;
key_count[3] <= 0;
key_count[4] <= 0;
end
    5'b11101 :
begin
key_id <= 4;
key_count_o <= key_count[3];
key_count[3] <= key_count[3] + 1;
key_count[4] <= 0;
key_count[0] <= 0;
key_count[1] <= 0;
key_count[2] <= 0;
end
    5'b11110 :
begin
key_id <= 5;
key_count_o <= key_count[4];
key_count[4] <= key_count[4] + 1;
key_count[0] <= 0;
key_count[1] <= 0;
key_count[2] <= 0;
key_count[3] <= 0;
end
    default :
begin
key_id <= 0;
key_count[0] <= 0;
key_count[1] <= 0;
key_count[2] <= 0;
key_count[3] <= 0;
key_count[4] <= 0;
key_count_o  <= 0;
end   
  endcase
   key_state <=key_init;
end
else                    //按鍵按下時,維持此狀態,直到按鍵釋放
begin
key_state <= key_check;
key_temp  <= key;    //把鍵碼的值賦給寄存器
end
default :
key_state <= key_init;
endcase
end


always @(state_clk or key_count_o or key_id)
begin
case (key_count_o)  //數碼管段選
4'b0001 : ledout = 7'b11111001; // 1
4'b0010 : ledout = 7'b10100100; // 2
4'b0011 : ledout = 7'b10110000; // 3
4'b0100 : ledout = 7'b10011001; // 4
4'b0101 : ledout = 7'b10010010; // 5
4'b0110 : ledout = 7'b10000010; // 6
4'b0111 : ledout = 7'b11111000; // 7
4'b1000 : ledout = 7'b10000000; // 8
4'b1001 : ledout = 7'b10010000; // 9
4'b1010 : ledout = 7'b10001000; // A
4'b1011 : ledout = 7'b10000011; // B
4'b1100 : ledout = 7'b11000110; // C
4'b1101 : ledout = 7'b10100001; // D
4'b1110 : ledout = 7'b10000110; // E
4'b1111 : ledout = 7'b10001110;
default : ledout = 7'b11000000;
endcase
   
    case (key_id)    //按照鍵碼進行數碼管位選
1 : weiout = ~8'b1000_0000;
2 : weiout = ~8'b0100_0000;
3 : weiout = ~8'b0010_0000;
4 : weiout = ~8'b0001_0000;
5 : weiout = ~8'b0000_1000;
default : weiout = ~8'b1000_0000;
endcase
end


分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏1 分享淘帖 頂 踩
回復

使用道具 舉報

沙發
ID:163409 發表于 2020-1-4 00:14 | 只看該作者
您好,感謝您的分享,請問三段式狀態機能實現延時檢測嗎?怎么實現?
回復

使用道具 舉報

板凳
ID:704585 發表于 2020-3-25 16:59 | 只看該作者
感謝樓主分享
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

手機版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 午夜tv免费观看 | 国产在线精品一区二区三区 | 成人午夜视频在线观看 | 99在线精品视频 | 国产精品久久国产精品久久 | 日本公妇乱淫xxxⅹ 国产在线不卡 | 精品欧美乱码久久久久久1区2区 | 一区二区免费高清视频 | 日韩在线观看视频一区 | 成人av久久| 久久久av| 久久久国产网站 | 91精品国产色综合久久不卡98口 | 免费观看羞羞视频网站 | 一区二区三区不卡视频 | 亚洲一二三在线观看 | 五月激情婷婷网 | 91免费在线看 | 中文二区 | 欧美日韩久久久久 | 人人干人人看 | 91在线| 免费视频二区 | 在线国产一区二区 | 国产激情免费视频 | 国产精品久久久久久久久久软件 | 最新国产精品 | 在线国产小视频 | 久久夜色精品国产 | 国内精品视频在线 | 久久91精品 | 美女一级毛片 | 精品一区二区三区在线观看 | 一区二区不卡 | 99久久精品视频免费 | 九九久久免费视频 | 国产精品日韩欧美 | 九九久久久 | 99精品电影 | 亚洲自拍偷拍视频 | 成人一区二区在线 |