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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 11963|回復(fù): 2
打印 上一主題 下一主題
收起左側(cè)

verilog學(xué)習(xí)筆記二:用狀態(tài)機實現(xiàn)按鍵的消抖及按鍵按下次數(shù)計數(shù)

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
ID:51025 發(fā)表于 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

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

//狀態(tài)機
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)    //釋放按鍵后,按鍵計數(shù)+1
begin
key_count <= key_count +1;
key_state <= key_init;
end
else                    //按鍵按下時,維持此狀態(tài),直到按鍵釋放
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


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

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; //連續(xù)按鍵次數(shù)


parameter key_init  = 0;    //按鍵狀態(tài)
parameter key_delay = 1;
parameter key_check = 2;

reg [15:0] state_clk_count;  //狀態(tài)機時鐘分頻計數(shù)
reg [3:0]  key_count [4:0];  //5個按鍵中,每個按鍵連續(xù)按鍵次數(shù)寄存  
reg       state_clk;        //狀態(tài)機時鐘
reg [1:0]  key_state;       //按鍵狀態(tài)寄存
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

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

//狀態(tài)機
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)    //釋放按鍵后,按鍵計數(shù)+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                    //按鍵按下時,維持此狀態(tài),直到按鍵釋放
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)  //數(shù)碼管段選
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)    //按照鍵碼進(jìn)行數(shù)碼管位選
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 分享淘帖 頂 踩
回復(fù)

使用道具 舉報

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

使用道具 舉報

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

使用道具 舉報

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

本版積分規(guī)則

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

Powered by 單片機教程網(wǎng)

快速回復(fù) 返回頂部 返回列表
主站蜘蛛池模板: 欧美精品在线一区 | 亚洲免费精品 | 亚洲男人网 | 国产日韩欧美精品一区二区三区 | 国产亚洲一区二区在线观看 | 色成人免费网站 | 欧美不卡一区 | 国产高清在线 | 黄色精品 | 欧美在线一区视频 | 二区中文字幕 | 国产精品视频www | 五月天激情综合网 | 中文字幕一区在线观看视频 | 日本爱爱视频 | 中文字幕在线观看www | 欧美成人精品激情在线观看 | 又黄又色 | 日韩成人免费 | 作爱视频免费看 | 免费黄色片在线观看 | 久久久精| 欧美激情精品久久久久久免费 | 成人不卡 | 成人日韩av| 日韩精品一区在线观看 | 狠狠爱综合网 | 色综合一区二区三区 | 久久精品视频一区二区 | 羞羞在线视频 | 久久欧美高清二区三区 | 在线中文字幕亚洲 | 精品国模一区二区三区欧美 | 国产一区二区三区在线免费观看 | 亚洲精品1区 | 欧美日韩久 | 国内精品免费久久久久软件老师 | 国产精品九九九 | 9久9久9久女女女九九九一九 | 成人性生交大片免费看r链接 | 国产精品一区二区久久 |