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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

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

FPGA按鍵控制流水燈

[復制鏈接]
跳轉到指定樓層
樓主
ID:832896 發表于 2021-3-26 22:15 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
  1. `timescale 1ns / 1ps
  2. //////////////////////////////////////////////////////////////////////////////////
  3. // Company:
  4. // Engineer:
  5. //
  6. // Create Date: 2020/12/05 12:01:14
  7. // Design Name:
  8. // Module Name: led_flowing
  9. // Project Name:
  10. // Target Devices:
  11. // Tool Versions:
  12. // Description:
  13. //
  14. // Dependencies:
  15. //
  16. // Revision:
  17. // Revision 0.01 - File Created
  18. // Additional Comments:
  19. //
  20. //////////////////////////////////////////////////////////////////////////////////

  21.     //由按鍵控制的流水燈左移右移,暫停,復位功能。

  22. module led_flowing(clk,led,rst_n,key_1,key_2,key_3
  23. );
  24.     input clk;
  25.     input rst_n;//復位按鍵
  26.     input key_1;///控制起停 低電平停止移動,高電平繼續移動
  27.     input key_2;///控制左移 流水燈左移    按下按鍵為0,控制左移,再按一次停止
  28.     input key_3;//控制右移  流水燈右移    按下按鍵為0,控制右移,再按一次停止
  29. output reg[3:0] led;//led power on _0  led power off _1    led燈低電平亮,led燈高電平熄滅
  30. reg [0:0]led_dir; // led left _1                                  led right _0     該位左移為1,右移為0;
  31. reg [0:0]led_on; //led on_1                          off_0



  32. reg[31:0] timer_cout;  //計數寄存器
  33.     always@(posedge clk or negedge rst_n)                 //achieve timer++  
  34.    
  35.     begin
  36.     if(rst_n!=1)
  37.         begin
  38.         timer_cout<=32'd0;
  39.         
  40.         end
  41.    else if(timer_cout==32'd49_999_999) //計數50_000_000次為1秒,時鐘為50Mhz
  42.        begin
  43.        timer_cout<=32'd0;
  44.        end
  45.     else
  46.         begin
  47.         timer_cout<=timer_cout+32'd1;
  48.         end   
  49.     end
  50.   
  51. //
  52. always@(posedge clk or negedge rst_n)
  53.     begin
  54.     if(rst_n!=1)
  55.         begin
  56.         led<=4'b1110;
  57.         end
  58.     else if((timer_cout==32'd49_999_999)&&(led_on==1))          //led_on==1開啟移位功能
  59.         begin
  60.         if(led_dir==1)  // 右移
  61.             begin
  62.             led<={led[0],led[3:1]};  //0,3,2,1,0
  63.             end                                                                //1,0,3,2
  64.         else                                                                        //2,1,0,3
  65.             begin
  66.             led<={led[2:0],led[3]};//2,1,0,3//左移
  67.             end                                                                //1,0,3,2,
  68.         end                                                                        //0,3,2,1,
  69.     end                                                                                //3,2,1,0
  70. //3位按鍵程序
  71. reg [20:1] cnt;

  72. always@(posedge clk or negedge rst_n)
  73.     begin
  74.     if(rst_n!=1)
  75.         begin
  76.         cnt<=20'd0;
  77.         end
  78.     else
  79.         begin
  80.         cnt<=cnt+20'd1;
  81.         end
  82.     end

  83. reg[2:0]low_sw;
  84. always@(posedge clk or negedge rst_n)
  85. begin
  86.     if (!rst_n)
  87.         begin
  88.          low_sw <= 3'b111;
  89.          end
  90.     else if (cnt== 20'hfffff) //滿20ms,將按鍵值鎖存到寄存器low_sw中cnt == 20'hfffff
  91.         begin
  92.                 low_sw <= {key_3,key_2,key_1};
  93.         end
  94. end


  95. reg[2:0] low_sw_r;
  96. always@(posedge clk or negedge rst_n)// 每個時鐘周期的上升沿將low_sw鎖存到low_sw_r中
  97. begin
  98.      if (!rst_n)
  99.      low_sw_r <= 3'b111;
  100.     else
  101. low_sw_r <= low_sw;


  102.   end
  103.   wire [2:0]led_ctrl = low_sw_r[2:0]&(~low_sw[2:0]);//////////////關鍵之處。
  104. //判斷鍵值與功能
  105. always @(posedge clk  or negedge rst_n)
  106. if (!rst_n)
  107.      begin
  108.          led_on = 1'b0;
  109.          led_dir = 1'b0;
  110.      end
  111. else
  112.      begin
  113.          if(led_ctrl[0]) led_on <= ~led_on;
  114.          if(led_ctrl[1]) led_dir <= 1'b1;
  115.          if(led_ctrl[2]) led_dir <= 1'b0;
  116.      end

  117. endmodule

  118. ////////////////////////////////////////////////////////////////////////////////







復制代碼


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

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 国产欧美日韩一区 | 在线一区二区三区 | 色精品视频 | 亚洲www| 国产精品区二区三区日本 | 欧美mv日韩mv国产网站91进入 | 91久久精品一区二区二区 | 丝袜美腿一区二区三区动态图 | 日韩视频观看 | 色噜噜狠狠色综合中国 | 久久久精品网 | 婷婷色国产偷v国产偷v小说 | 亚洲一页 | 成人99| 亚洲高清视频在线 | 99精品视频在线 | 色久在线 | 国产精品亚洲一区二区三区在线观看 | 亚洲国产成人久久久 | 中文字幕国产精品视频 | 天天色天天 | 美女在线视频一区二区三区 | 成人免费视频在线观看 | 日本在线网址 | 国产欧美精品一区二区色综合朱莉 | 欧美激情在线精品一区二区三区 | 亚洲成人午夜电影 | 视频三区 | 皇色视频在线 | 国产精品久久久久久久久久久久 | 日韩免费av | 日韩久久久久 | 成人黄在线观看 | 精品成人一区二区 | 亚洲一区二区三区免费视频 | 欧美亚洲国产一区二区三区 | 99久久精品国产一区二区三区 | 九九精品在线 | 激情福利视频 | 日韩欧美视频网站 | 亚洲一区 中文字幕 |