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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

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

Proteus仿真HCSR04超聲波+DS18B20+LCD1602+51單片機集成系統程序

[復制鏈接]
跳轉到指定樓層
樓主
HCSR04+DS18B20+LCD1602+51單片機集成系統,文件包含keil工程和proteus仿真結果
仿真原理圖如下(proteus仿真工程文件可到本帖附件中下載)


單片機源程序如下:
  1. //頭函數
  2. #include <reg52.h>
  3. #include <intrins.h>
  4. //宏定義
  5. #define uchar unsigned char
  6. #define uint unsigned int
  7. #define ULint unsigned long int
  8. //溫度零上與零下的標志位
  9. char flag=0;
  10. //超聲波
  11. char flags=0;
  12. //超聲波距離
  13. char flag1s=1;
  14. //計算定時間
  15. uint time=0;
  16. //計算距離
  17. ULint L_=0;

  18. ULint Mini=20;
  19. //溫度
  20. uint t_=0;

  21. bit xsflag=1;




  22. //按鍵標志
  23. uchar k=0;
  24. //數值有誤
  25. uchar FW=0;





  26. #include "BJ_Key.h"                    //報警按鍵
  27. #include "display.h"                         //顯示頭函數
  28. #include "ultrasonic_wave.h"//超聲波頭函數
  29. #include "DS18B20.h"                    //溫度傳感器頭函數


  30. //函數聲明
  31. void delayms(uint ms);



  32. //主函數
  33. void main()
  34. {
  35.         Init_ultrasonic_wave();
  36.         //屏幕初始化
  37.         Init1602();
  38.         //溫度初始化
  39.         tmpchange();
  40.         t_=tmp();
  41.         tmpchange();
  42.         t_=tmp();
  43.         tmpchange();
  44.         t_=tmp();

  45.         //循環顯示
  46.         while(1)
  47.         {
  48.                 Key();
  49.                
  50.                         StartModule();//啟動超聲波
  51.                         while(!RX);          //當RX為零時等待
  52.                         TR0=1;                  //開啟計數
  53.                         while(RX);          //當RX為1計數并等待
  54.                         TR0=0;                  //關閉計數
  55.         
  56.                         delayms(20);  //20MS
  57.                         tmpchange();  //溫度轉換
  58.                         t_=tmp();     //度溫度
  59.                         Conut(t_/10); //計算距離

  60.                         if(L_<Mini && xsflag==1)
  61.                         {
  62.                                 Feng_Start();
  63.                         }else{
  64.                                 Feng_Stop();
  65.                         }
  66.                         
  67.                         if(L_<5&&  xsflag==1)
  68.                         {
  69.                                 motor_en();
  70.                         }
  71.                         else{
  72.                                 motor_off();
  73.                         }
  74.                         Display_1602(t_/10,L_,Mini);
  75.         
  76.         }
  77. }

  78. void delayms(uint ms)
  79. {
  80.         uchar i=100,j;
  81.         for(;ms;ms--)
  82.         {
  83.                 while(--i)
  84.                 {
  85.                         j=10;
  86.                         while(--j);
  87.                 }
  88.         }
  89. }
  90. //T0中斷用來計數器溢出,超過測距范圍
  91. void CJ_T0() interrupt 1
  92. {
  93.     flags=1;                                                         //中斷溢出標志
  94. }
復制代碼

ULTRASONIC_WAVE.H
  1. //超聲波管腳定義
  2. sbit RX=P1^3;
  3. sbit TX=P1^2;

  4. //超聲波初始化
  5. void Init_ultrasonic_wave()
  6. {
  7.          TX=0;                           //關閉發射
  8.          TMOD=0x01;                   //設T0為方式1,GATE=1;
  9.          TH0=0;
  10.          TL0=0;
  11.         // TH1=0x3c;
  12.         // TL0=0xb0;         
  13.          ET0=1;           //允許T0中斷
  14.         // ET1=0;
  15.         // TR1=0;
  16.          EA=1;                           //開啟總中斷        
  17. }

  18. //啟動超聲波
  19. void StartModule()         //啟動模塊
  20. {
  21.         TX=1;                              //啟動一次模塊
  22.         _nop_();
  23.         _nop_();
  24.         _nop_();
  25.         _nop_();
  26.         _nop_();
  27.         _nop_();
  28.         _nop_();
  29.         _nop_();
  30.         _nop_();
  31.         _nop_();
  32.         _nop_();
  33.         _nop_();
  34.         _nop_();
  35.         _nop_();
  36.         _nop_();
  37.         _nop_();
  38.         _nop_();
  39.         _nop_();
  40.         _nop_();
  41.         _nop_();
  42.         _nop_();
  43.         TX=0;
  44. }
  45. //計算不同溫度下的速度
  46. void JS_(uchar WD)
  47. {
  48.         //大于-30
  49.         if(WD>=30&&flag==1)
  50.         {
  51.                 L_=(time*3.13)/200;     //算出來是CM;               
  52.         }
  53.         //大于-20<-30
  54.         else if(WD>=20&&WD<30&&flag==1)
  55.         {
  56.                 L_=(time*3.19)/200;     //算出來是CM;               
  57.         }
  58.         //大于-10<-20
  59.         else if(WD>=10&&WD<20&&flag==1)
  60.         {
  61.                 L_=(time*3.25)/200;     //算出來是CM;               
  62.         }
  63.         //大于0<-10
  64.         else if(WD>=0&&WD<10&&flag==1)
  65.         {
  66.                 L_=(time*3.23)/200;     //算出來是CM;               
  67.         }

  68.         //大于0<10
  69.         else if(WD<=10&&WD>0&&flag==0)
  70.         {
  71.                 L_=(time*3.38)/200;     //算出來是CM;               
  72.         }
  73.         //大于10<20
  74.         else if(WD<=20&&WD>10&&flag==0)
  75.         {
  76.                 L_=(time*3.34)/200;     //算出來是CM;               
  77.         }
  78.         //大于20<30
  79.         else if(WD<=30&&WD>20&&flag==0)
  80.         {
  81.                 L_=(time*3.49)/200;     //算出來是CM;               
  82.         }
  83.         //大于30
  84.         else if(WD>30&&flag==0)
  85.         {
  86.                 L_=(time*3.86)/200;     //算出來是CM;               
  87.         }
  88. }
  89. //距離計算 SD為當時的超聲速度
  90. void Conut(uchar WD)
  91. {
  92.          time=TH0*256+TL0;
  93.          TH0=0;
  94.          TL0=0;
  95.          JS_(WD);

  96.          //距離大于200或者超時
  97.          if(L_>500||flags==1)
  98.          {
  99.                 flags=0;
  100.                 //無效顯示
  101.                 flag1s=0;
  102.                 L_=500;
  103.                 FW=1;        
  104. //                Feng_Start();        
  105.          }        
  106.          //距離小于100
  107.          else if(L_<=500)
  108.          {
  109.                 flag1s=1;
  110.                 FW=0;        
  111. //                Feng_Stop();
  112.          }

  113. }
復制代碼
Keil代碼與Proteus7.5和8.8仿真下載:
HCSR04 DS18B20 LCD1602 51單片機.zip (310.5 KB, 下載次數: 125)


評分

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

查看全部評分

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

使用道具 舉報

沙發
ID:487807 發表于 2022-5-23 18:21 來自觸屏版 | 只看該作者
仿真有,但是程序好像不算
回復

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 天天操天天干天天透 | 久久精品国产免费 | 91精品一区| 欧美成人一区二区三区 | 欧美日韩成人 | 日韩一区二区三区视频 | 黄色在线播放视频 | 91一区二区| 9191av| 亚洲视频一区 | 久久久久国产精品一区二区 | 久久久久亚洲精品中文字幕 | 一区二区国产在线 | 欧美一区二区三区精品 | 一区二区三区视频在线观看 | 精品日本中文字幕 | 日韩成人在线播放 | 人人看人人干 | 久久99久久| 成人三级视频在线观看 | 国产精品v | 午夜性色a√在线视频观看9 | 欧美福利在线 | 久久亚洲美女 | 欧美日韩在线精品 | 成人午夜电影在线观看 | 亚洲一区国产 | 亚洲97| 亚洲精品黄色 | 国产一区二区视频免费在线观看 | 韩国av一区二区 | av电影手机版 | 亚洲交性| 一区二区三区四区在线免费观看 | 久久亚洲高清 | 精区3d动漫一品二品精区 | 午夜影视在线观看 | 日日人人| 免费国产一区 | 欧美精品免费观看二区 | 日韩网站在线 |