欧美极品高清xxxxhd,国产日产欧美最新,无码AV国产东京热AV无码,国产精品人与动性XXX,国产传媒亚洲综合一区二区,四库影院永久国产精品,毛片免费免费高清视频,福利所导航夜趣136

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 2708|回復: 1
收起左側(cè)

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

[復制鏈接]
ID:679189 發(fā)表于 2022-4-25 08:52 | 顯示全部樓層 |閱讀模式
HCSR04+DS18B20+LCD1602+51單片機集成系統(tǒng),文件包含keil工程和proteus仿真結(jié)果
仿真原理圖如下(proteus仿真工程文件可到本帖附件中下載)
51hei.gif

單片機源程序如下:
  1. //頭函數(shù)
  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. //數(shù)值有誤
  25. uchar FW=0;





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


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



  32. //主函數(shù)
  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.         //循環(huán)顯示
  46.         while(1)
  47.         {
  48.                 Key();
  49.                
  50.                         StartModule();//啟動超聲波
  51.                         while(!RX);          //當RX為零時等待
  52.                         TR0=1;                  //開啟計數(shù)
  53.                         while(RX);          //當RX為1計數(shù)并等待
  54.                         TR0=0;                  //關(guān)閉計數(shù)
  55.         
  56.                         delayms(20);  //20MS
  57.                         tmpchange();  //溫度轉(zhuǎn)換
  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中斷用來計數(shù)器溢出,超過測距范圍
  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;                           //關(guān)閉發(fā)射
  8.          TMOD=0x01;                   //設(shè)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, 下載次數(shù): 125)


評分

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

查看全部評分

回復

使用道具 舉報

ID:487807 發(fā)表于 2022-5-23 18:21 來自觸屏版 | 顯示全部樓層
仿真有,但是程序好像不算
回復

使用道具 舉報

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

本版積分規(guī)則

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

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

快速回復 返回頂部 返回列表