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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

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

FPGA按鍵控制流水燈

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
ID:832896 發(fā)表于 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.     //由按鍵控制的流水燈左移右移,暫停,復(fù)位功能。

  22. module led_flowing(clk,led,rst_n,key_1,key_2,key_3
  23. );
  24.     input clk;
  25.     input rst_n;//復(fù)位按鍵
  26.     input key_1;///控制起停 低電平停止移動,高電平繼續(xù)移動
  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;  //計數(shù)寄存器
  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) //計數(shù)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]);//////////////關(guān)鍵之處。
  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. ////////////////////////////////////////////////////////////////////////////////







復(fù)制代碼


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

使用道具 舉報

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

本版積分規(guī)則

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

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

快速回復(fù) 返回頂部 返回列表
主站蜘蛛池模板: 欧美成人手机视频 | 亚洲综合区 | 午夜视频在线观看网站 | 亚洲精品粉嫩美女一区 | 久久国产精品色av免费观看 | 欧美精品1区2区3区 免费黄篇 | 色天天综合| 日韩成人免费视频 | 久久精品久久久久久 | 久久久久国产一区二区三区 | av中文在线观看 | 亚洲综合在线视频 | 天堂免费| 免费亚洲网站 | 国产精品区二区三区日本 | 国产成人99久久亚洲综合精品 | 国产原创视频 | av 一区二区三区 | 久久精品久久久久久 | 日韩在线中文 | 91婷婷韩国欧美一区二区 | 成人黄色网址大全 | 偷拍自拍第一页 | 国产欧美日韩一区二区三区在线观看 | www.日韩| 日韩精品一区二区三区在线观看 | 国产亚洲一区二区精品 | 久久久久黄 | 国产精品久久久久久久久久尿 | 亚洲精品久久久久久国产精华液 | 精品麻豆剧传媒av国产九九九 | 中文字幕第100页 | 中文天堂网| 久久在线 | 国产精品久久久久久久久久久久久久 | 日韩精品影院 | 欧美在线视频一区 | 午夜影视免费片在线观看 | 国产高清一二三区 | 欧美视频二区 | www.五月天婷婷 |