找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 2044|回复: 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, 下载次数: 122)


评分

参与人数 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 单片机教程网

快速回复 返回顶部 返回列表