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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

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

89c51單片機32個心形流水燈設計

  [復制鏈接]
跳轉到指定樓層
樓主
這是最近做的課程設計,用了3、4天的時間,我們是一個小組,6個人共同完成的,其中的內容也有借鑒網上的,但沒有照搬,代碼完全是自己寫的,附件里有流水燈的代碼和原理圖及仿真圖,本次設計用到的是89c51單片機,新手報到,還望海涵,原理圖和仿真是用的proteus8.3,程序的編寫用的是keil 5。

電路原理圖如下:


設計要求:
設計一個用單片機控制的心形流水燈系統;
LED燈數量為32個;
可以實現循環點亮、依次熄滅的基本功能;
可以實現對角閃亮、間隔閃亮、順時針閃亮、逆時針閃亮等多種功能(也可自行增加功能)。

學生需要完成的任務:
完成心形流水燈電路設計,利用Keil軟件編寫程序,Proteus軟件進行電路功能仿真,并將仿真結果采用錄屏形式生成視頻,視頻類型建議用.mp4格式,大小不超過200M。


目錄

目錄
一、總體方案設計
1、單片機的選擇
2、LED燈控制方式的比較與選擇
3、硬件設計
二、電路原理圖設計
1、時鐘電路
2、復位電路
3、顯示電路
4、電源電路
三、程序設計
1、Keil 軟件介紹
2、程序編寫設計
3、程序調試
4、電路功能仿真
附件:
1、程序代碼:
2、小組成員任務分配表

一、總體方案設計
1、單片機的選擇

單片機作為該電路的主要控制器芯片,是整個系統核心部分,主要負責控制LED燈的亮滅變化的速度以及變化效果。89c51單片機共有32個I/O口,能夠滿足32個流水燈的設計需求;另外80c51具有4k字節的FLASH閃存和128字節的RAM,編寫的程序很小,非常能夠滿足設計的需求;除此之外,89c51單片機還具有靈活性高且廉價的特點,綜合考慮,選擇89c51芯片作為設計的方案。

2、LED燈控制方式的比較與選擇

方案一:采用位操作的方式對32個i/o口進行操作

方案二:采用總線的方式對32個i/o口進行操作

由于采用位操作的方式,還需要聲明32個i/o口,另外在寫程序的時候語句較多,過程繁瑣;而采用總線操作的方式,則不需要聲明i/o口,與位操作相比,采用總線的方式在程序編寫時能用很少的語句實現相同的功能效果;所以,選擇方案二,即采用總線操作的方式對32個i/o口操作。

3、硬件設計

心形流水燈設計所需的系統應該具有:由32個發光二極管組成的顯示電路、由晶振和電容組成的時鐘電路、電源、復位電路即軟件部分。心形流水燈的硬件設計框圖如圖1-3.1所示


二、電路原理圖設計
1、時鐘電路

單片機內有一個由反相放大器所構成的振蕩電路, XTAL1 和 XTAL2 分別為振蕩電路的輸入端和輸出端。 在 XTAL1 和 XTAL2 引腳上外接石英晶體和微調電容構成并聯振蕩回路。晶振頻率設置為 11.0592MHZ, 作用是產生時鐘信號。 單片機晶振提供的時鐘頻率越高,那么單片機運行速度就越快,單片接的一切指令的執行都是建立在單片機晶振提供的時鐘頻率紙上。電容值為 30pF, 可以起到頻率微調作用。時鐘電路如圖2-1.1所示:

2、復位電路

當輸入連續兩個機器周期以上高電平時為有效,用來完成單片機的復位初始值操作,復位后程序計數器PC=0000H,即復位后將從程序儲存器的0000H單元讀取第一條指令碼,通俗的講,就是單片機重新開始命令,防止程序走偏。復位電路如圖2-2.1所示:

3、顯示電路

單片機的 P0 口為 8 位的漏極開路的雙向 I/O 口,當 P0口作為普通的 I/O 口使用時,需要上拉電阻,這時為準雙向口。 P1 、P2、 P3 都為 8位的準雙向口,具有內部上拉電阻。圖 6 為顯示電路,單片機 I/O 口一對一直接控制 LED 燈,顯示電路中的 32 個電阻既為上拉電阻,也起到電路分壓作用,防止燒壞元器件。顯示電路如圖2-3.1所示

4、電源電路

本次課程設計,單片機正常工作要求輸出電壓為穩定的 5V,輸出電壓能夠適應所帶負載的啟動項能。并且電路還必須簡單可靠,能夠輸出足夠大的電流,但是不至于會燒壞元器件。我們采用 USB 取電,4.8V 鋰電池供電。電源電路如圖所示, 兩個電阻起到濾波作用, 兩個電阻的作用是平衡電路中的電流,以免在只有 1 個 LED 燈亮時燒壞元器件。電源電路如圖2-4.1所示。



三、程序設計
1、Keil 軟件介紹

本次課程設計,我們采用Keil軟件進行C語言編程。Keil軟件是美國Keil Software公司開發的,它適合 WindowsXP、Win7 等系統,具有可視化操作界面,使用方便簡單,并且支持 C51 語言、匯編語言以及兩者混合編程等多種方式的單片機設計,KeilC51 在兼容標準 C 語言的基礎上,又增加了很多與 51系列單片機硬件相關的編譯特性,其生成的程序代碼運行的速度快,所需的存儲器空間小。

Keil 軟件已被完全集成到一個功能強大的全新環境中,該開發環境集成了文件編譯處理、編譯鏈接、項目管理、工具引用、和仿真軟件模擬器等多種功能。 Keil 軟件具有豐富的庫函數,同時也帶有功能強大的集成開發調試工具,可以自動識別所編寫程序的語法錯誤,編譯效率也很高, 能將源文件編譯為二進制機器語言代碼,其軟件調試仿真功能也很強大,能通過單步、設置斷點等功能讓編程者了解 CPU 正在進行的程序,并能監控各變量以及各寄存器是否符合編程者的要求。

2、程序編寫設計

單片機的應用系統由硬件和軟件組成,在硬件原理圖搭建完成上電之后,暫時還不能看到流水燈循環點亮的現象,還需要編寫程序控制單片機管腳電平的高低變化,來實現 LED 燈的各種亮滅功能。其程序流程圖3-2.1如圖所示:


例如,先將 P0、P1、P2、P3 全部置 1,即通入高電平,用 16 進制表示為 0XFF,則 32個 LED 燈全部處于熄滅狀態。然后給 P0 口賦值0X7F,即只有 P0.0 處于低電平時,LED1 燈點亮。使用延時函數 delay,并設置延時時間為0.2秒,延時時間一到 P0 口的值就變為 0X3F, 即 P0.0和 P0.1都為高電平, LED2 也開始點亮,如此循環 P0口控制的8 個 LED 燈全部點亮,
當高電平變為低電平時, LED 燈熄滅。P1、P2、P3 口控制的 LED燈閃亮和熄滅原理同 P0 口一樣,所以就可以看到 LED 燈的流水效果了。

圖3-2.1程序設計流程圖

3、程序調試

在程序編寫好了之后,需要連接工程并編譯,經過反復的檢查、編譯、調試,程序沒有錯誤后,最后獲得目標代碼 Hex文件。將程序代碼文件調入 Proteus軟件,進行電路功能仿真,并根據仿真結果進行程序的修改和完善。所以程序的調試就顯得至關重要。其中,將每個閃爍的部分都寫成一個子函數,直接在主函數中調用即可實現閃爍的花樣和效果,各子函數與主函數的結構框圖如圖3-3.1所示:


4、電路功能仿真

在各部分電路設計的基礎上,按照總體電路圖在 Proteus上一一進行器件選擇,并連接。將電路連接好后,為各個器件選擇合適的參數,然后調入已編譯好的目標代碼Hex 文件,啟動仿真。根據 LED 燈是否發亮,判斷所設計的電路是否可以實現 32 個 LED燈依次點亮、依次熄滅、對角閃亮、對角熄滅、間隔閃亮、間隔熄滅等多種功能。電路仿真的結果為 32 個 LED 燈依次發亮、依次熄滅,并可以實現多種亮滅功能。

1







附件:1、程序代碼:
  1. #include<reg52.h>
  2. #include<intrins.h> //庫函數
  3. #define uint unsigned int
  4. #define uchar unsigned char//宏定義
  5. void delay(uint xms)//延時函數
  6. {
  7.               uint i,j;
  8.               for(i=xms;i>0;i--)
  9.                             for(j=110;j>0;j--);
  10. }
  11. void zys(uint t)//左右閃爍
  12. {
  13.               while(t--)
  14.               {
  15.                             P3=P2=0x00;
  16.                             delay(500);
  17.                             P3=P2=0xff;
  18.                             P1=P0=0x00;
  19.                             delay(500);
  20.                             P1=P0=0xff;
  21.               }
  22. }
  23. void qs(uint t)//全部閃亮
  24. {
  25.               while(t--)
  26.               {
  27.                             P0=P1=P2=P3=0xff;
  28.                             delay(300);
  29.                             P0=P1=P2=P3=0x00;
  30.                             delay(300);
  31.               }
  32.               P1=P2=P3=P0=0xff;
  33. }
  34. void ycdl(uint t)//依次點亮
  35. {
  36.               uchar code table[]={0xfe,0xfc,0xf8,0xf0,0xe0,0xc0,0x80,0x00};
  37.               uint i;
  38.               while(t--)
  39.               {
  40.                             for(i=0;i<8;i++)
  41.                                           {
  42.                                                         P0=table[i];
  43.                                                         delay(200);
  44.                                           }
  45.                             for(i=0;i<8;i++)
  46.                                           {
  47.                                                         P1=table[i];
  48.                                                         delay(200);
  49.                                           }
  50.                             for(i=0;i<8;i++)
  51.                                           {
  52.                                                         P2=table[i];
  53.                                                         delay(200);
  54.                                           }
  55.                             for(i=0;i<8;i++)
  56.                                           {
  57.                                                         P3=table[i];
  58.                                                         delay(200);
  59.                                           }
  60.               }
  61. }
  62. void ycxm (uint t)//依次熄滅
  63. {
  64.                             uchar code table[]={0xfe,0xfc,0xf8,0xf0,0xe0,0xc0,0x80,0x00};
  65.               uint i;
  66.               while(t--)
  67.               {
  68.                             P0=P1=P2=P3=0x00;
  69.                             for(i=0;i<8;i++)
  70.                                           {
  71.                                                         P0=~table[i];
  72.                                                         delay(200);
  73.                                           }
  74.                             for(i=0;i<8;i++)
  75.                                           {
  76.                                                         P1=~table[i];
  77.                                                         delay(200);
  78.                                           }
  79.                             for(i=0;i<8;i++)
  80.                                           {
  81.                                                         P2=~table[i];
  82.                                                         delay(200);
  83.                                           }
  84.                             for(i=0;i<8;i++)
  85.                                           {
  86.                                                         P3=~table[i];
  87.                                                         delay(200);
  88.                                           }
  89.               }
  90. }
  91. void jgs(uint t)//間隔閃爍
  92. {
  93.               while(t--)
  94.               {
  95.                             P0=P1=P2=P3=0xaa;
  96.                             delay(500);
  97.                             P0=P1=P2=P3=~0xaa;
  98.                             delay(500);
  99.               }
  100.               P0=P1=P2=P3=0xff;
  101.               delay(200);
  102. }

  103. void sszs(uint t)//順時針閃爍
  104. {
  105.               uchar a,i;
  106.               while(t--)
  107.               {
  108.                             a=0xfe;
  109.                             for(i=0;i<8;i++)
  110.                             {
  111.                                           P0=a;
  112.                                           delay(200);
  113.                                           a=_crol_(a,1);
  114.                             }
  115.                             P0=0xff;
  116.                             a=0xfe;
  117.                             for(i=0;i<8;i++)
  118.                             {
  119.                                           P1=a;
  120.                                           delay(200);
  121.                                           a=_crol_(a,1);
  122.                             }
  123.                             P1=0xff;
  124.                             a=0xfe;
  125.                             for(i=0;i<8;i++)
  126.                             {
  127.                                           P2=a;
  128.                                           delay(200);
  129.                                           a=_crol_(a,1);
  130.                             }
  131.                             P2=0xff;
  132.                             a=0xfe;
  133.                             for(i=0;i<8;i++)
  134.                             {
  135.                                           P3=a;
  136.                                           delay(200);
  137.                                           a=_crol_(a,1);
  138.                             }
  139.                             P3=0xff;
  140.               }
  141. }
  142. void nszs(uint t)//逆時針閃爍
  143. {
  144.               uchar a,i;
  145.               while(t--)
  146.               {
  147.                             a=0x7f;
  148.                             for(i=0;i<8;i++)
  149.                             {
  150.                                           P3=a;
  151.                                           delay(200);
  152.                                           a=_cror_(a,1);
  153.                             }
  154.                             P3=0xff;
  155.                             a=0x7f;
  156.                             for(i=0;i<8;i++)
  157.                             {
  158.                                           P2=a;
  159.                                           delay(200);
  160.                                           a=_cror_(a,1);
  161.                             }
  162.                             P2=0xff;
  163.                             a=0x7f;
  164.                             for(i=0;i<8;i++)
  165.                             {
  166.                                           P1=a;
  167.                                           delay(200);
  168.                                           a=_cror_(a,1);
  169.                             }
  170.                             P1=0xff;
  171.                             a=0x7f;
  172.                             for(i=0;i<8;i++)
  173.                             {
  174.                                           P0=a;
  175.                                           delay(200);
  176.                                           a=_cror_(a,1);
  177.                             }
  178.                             P0=0xff;
  179.               }
  180. }
  181. void djs1(uint t)//對角閃爍2個順時針
  182. {
  183.               uchar i;
  184.               uchar code table[]={0xf0,0xe1,0xc3,0x87,0x0f,0x1f,0x3f,0x7f,
  185.                                                                                                                                                           0xff,0xff,0xff,0xff,0xff,0xfe,0xfc,0xf8,0xf0,
  186.                                                                                                                                                           0xff,0xff,0xff,0xff,0xff,0xfe,0xfc,0xf8,
  187.                                                                                                                                                           0xf0,0xe1,0xc3,0x87,0x0f,0x1f,0x3f,0x7f,0xff};
  188.               while(t--)
  189.               {
  190.                             for(i=0;i<17;i++)
  191.                                           {
  192.                                                         P0=P2=table[i];
  193.                                                         P1=P3=table[i+17];
  194.                                                         delay(200);
  195.                                           }
  196.                             for(i=0;i<17;i++)
  197.                                           {
  198.                                                         P1=P3=table[i+17];
  199.                                                         P0=P2=table[i];
  200.                                                         delay(200);
  201.                                           }
  202.               }
  203.               delay(300);
  204.               P0=P1=P2=P3=0xff;
  205. }
  206. void djs2(uint t)//對角閃4個逆時針
  207. {
  208.               uchar i;
  209.               uchar code table[]={0x0f,0x87,0xc3,0xe1,0xf0,0x78,0x3c,0x1e,0x0f};
  210.               while(t--)
  211.               {
  212.                             for(i=0;i<9;i++)
  213.                                           {
  214.                                                         P1=P2=P3=P0=table[i];
  215.                                                         delay(200);
  216.                                           }
  217.               }
  218. }
  219. void sxhx(uint t)//從上往下畫心
  220. {
  221.               uchar code table[]={0xfe,0xfc,0xf8,0xf0,0xe0,0xc0,0x80,0x00,
  222.                                                                                                                                                           0x7f,0x3f,0x1f,0x0f,0x07,0x03,0x01,0x00};
  223.               uint i;
  224.               while(t--)
  225.               {
  226.                             for(i=0;i<8;i++)
  227.                                           {
  228.                                                         P0=table[i];
  229.                                                         P3=table[i+8];
  230.                                                         delay(200);
  231.                                           }
  232.                             for(i=0;i<8;i++)
  233.                                           {
  234.                                                         P1=table[i];
  235.                                                         P2=table[i+8];
  236.                                                         delay(200);
  237.                                           }
  238.                             P1=P2=P3=P0=0xff;
  239.                             delay(300);
  240.               }
  241. }

  242. void main()
  243. {
  244. while(1)
  245. {
  246. ycdl(1);
  247.               ycxm(1);
  248.               jgs(3);
  249.               sszs(1);
  250.               nszs(1);
  251.               djs1(1);
  252.                             djs2(3);
  253.                             zys(3);
  254.                             sxhx(1);
  255.                             qs(3);
  256. }
  257. }
復制代碼
全部資料51hei下載地址:
心形流水燈設計報告.doc (1.14 MB, 下載次數: 86)
心形流水燈設計報告.pdf (1.2 MB, 下載次數: 43)

評分

參與人數 1黑幣 +50 收起 理由
admin + 50 共享資料的黑幣獎勵!

查看全部評分

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

使用道具 舉報

沙發
ID:503891 發表于 2019-4-5 02:52 | 只看該作者
很高興能夠幫到你,當然可以借鑒
回復

使用道具 舉報

板凳
ID:355499 發表于 2019-4-19 16:17 | 只看該作者
wangsonghu 發表于 2019-4-5 02:52
很高興能夠幫到你,當然可以借鑒

能否給我發你的電路和程序,謝謝,單片機新人。QQ郵箱:1113572709,
回復

使用道具 舉報

地板
ID:754119 發表于 2020-6-21 17:26 | 只看該作者
不錯不錯,感謝分享
回復

使用道具 舉報

5#
ID:861525 發表于 2020-12-16 17:00 | 只看該作者
太有用了,很給力
回復

使用道具 舉報

6#
ID:869243 發表于 2020-12-28 10:02 來自手機 | 只看該作者
謝謝您提供這么好的資料
回復

使用道具 舉報

7#
ID:1126674 發表于 2024-6-24 08:40 | 只看該作者
太牛了,鐵鐵
回復

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 中文字幕 在线观看 | 很很干很很日 | 黄色播放 | 国产精品久久久久久一区二区三区 | 久久久久久久久久久久久91 | 国产精品成人在线 | 日韩成人精品一区二区三区 | 久久久久久国产精品久久 | 中文在线视频 | 亚洲精品久久久久久久久久久久久 | 午夜精品 | 黄色一级大片在线免费看产 | 中文字幕高清 | 一区二区视频在线 | 亚洲国产精品一区二区第一页 | 午夜精品一区二区三区在线观看 | 国产精品99久久久久久久久久久久 | 99这里只有精品 | 国产精品久久久久久久久久久新郎 | 久久国产精品一区 | 国产午夜精品久久久 | 久久美国 | 91av视频在线观看 | 亚洲视频在线播放 | 亚洲永久免费 | 免费久久网站 | 亚洲一区二区三区免费观看 | 久久亚洲精品国产精品紫薇 | 有码在线 | 久久在线看 | 天天玩天天干天天操 | www.97zyz.com| 国产98色在线 | 日韩 | 免费的av | 国产极品粉嫩美女呻吟在线看人 | 天天av天天好逼 | 欧美激情第一区 | 国产在线一 | 欧美a级成人淫片免费看 | 成人小视频在线观看 | 日韩www|