找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 4916|回复: 9
打印 上一主题 下一主题
收起左侧

51单片机超声波测距_液位检测_温度检测原理图PCB仿真代码

  [复制链接]
跳转到指定楼层
楼主
主控为stc89c52,听过ds18b20进行温度采集,超声波测距,距离不可以超过1m,通过按键可以设置距离上下限阈值

制作出来的实物图如下:


Altium Designer画的原理图和PCB图如下:(51hei附件中可下载工程文件)


仿真原理图如下(proteus仿真工程文件可到本帖附件中下载)


单片机源程序如下:
  1. //宏定义
  2. #define uchar unsigned char
  3. #define uint unsigned int
  4. #define ULint unsigned long int
  5. //温度零上与零下的标志位
  6. char flag=0;
  7. //超声波
  8. char flags=0;
  9. //超声波距离
  10. char flag1s=0;
  11. //计算定时间
  12. uint time=0;
  13. //计算距离
  14. ULint L_=0;
  15. //温度
  16. uint t_=0;
  17. //显示模式  0正常  1最大值调整  2最小值调整
  18. uchar mode=0;

  19. uint Max=490;
  20. uint Min=30;
  21. //按键标志
  22. uchar k=0;
  23. //数值有误
  24. uchar FW=0;
  25. //头函数
  26. #include <reg52.h>
  27. #include <intrins.h>
  28. #include "BJ_Key.h"                    //报警按键
  29. #include "display.h"                         //显示头函数
  30. #include "ultrasonic_wave.h"//超声波头函数
  31. #include "DS18B20.h"                    //温度传感器头函数


  32. //函数声明
  33. void delayms(uint ms);
  34. //主函数
  35. void main()
  36. {
  37.         Init_ultrasonic_wave();
  38.         //屏幕初始化
  39.         Init1602();
  40.         //温度初始化
  41.         tmpchange();
  42.         t_=tmp();
  43.         tmpchange();
  44.         t_=tmp();
  45.         tmpchange();
  46.         t_=tmp();

  47.         //循环显示
  48.         while(1)
  49.         {
  50.                 Key();
  51.                 //正常显示
  52.                 if(mode==0)
  53.                 {
  54.                         StartModule();//启动超声波
  55.                         while(!RX);          //当RX为零时等待
  56.                         TR0=1;                  //开启计数
  57.                         while(RX);          //当RX为1计数并等待
  58.                         TR0=0;                  //关闭计数
  59.        
  60.                         delayms(20);  //20MS
  61.                         tmpchange();  //温度转换
  62.                         t_=tmp();     //度温度
  63.                         Conut(t_/10); //计算距离
  64.                         if(L_>Max||L_<Min)
  65.                         {
  66.                                 Feng_Start();
  67.                         }
  68.                         else
  69.                         {
  70.                                 if(FW!=1)
  71.                                 Feng_Stop();
  72.                         }
  73.                         Display_1602(t_/10,L_);
  74.                 }
  75.                 //调整显示
  76.                 else if(mode!=0)
  77.                 {
  78.                         //最大最小值
  79.                         Init_MaxMin();
  80.                         while(mode!=0)
  81.                         {
  82.                                
  83.                                 Key();
  84.                                 if(k==1&&mode==1)
  85.                                 {
  86.                                         Init_MaxMin();       
  87.                                    write_com(0x8d);//设置位置                                       
  88.                                 }
  89.                                 else if(k==1&&mode==2)
  90.                                 {
  91.                                         Init_MaxMin();       
  92.                                    write_com(0x8d+0x40);//设置位置       
  93.                                 }
  94.                                 k=0;
  95.                         }
  96.                         //界面初始化
  97.                         Init1602();
  98.                 }
  99.         }
  100. }

  101. void delayms(uint ms)
  102. {
  103.         uchar i=100,j;
  104.         for(;ms;ms--)
  105.         {
  106.                 while(--i)
  107.                 {
  108.                         j=10;
  109.                         while(--j);
  110.                 }
  111.         }
  112. }


  113. //T0中断用来计数器溢出,超过测距范围
  114. void CJ_T0() interrupt 1
  115. {
  116.     flags=1;                                                         //中断溢出标志
  117. }
复制代码

所有资料51hei提供下载:
仿真程序.7z (3.93 MB, 下载次数: 264)

评分

参与人数 1黑币 +80 收起 理由
admin + 80 共享资料的黑币奖励!

查看全部评分

分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏11 分享淘帖 顶 踩
回复

使用道具 举报

沙发
ID:74293 发表于 2021-5-25 19:05 | 只看该作者
楼主,这个起始距离怎么是200多CM??
回复

使用道具 举报

板凳
ID:315554 发表于 2021-6-1 17:29 | 只看该作者
谢谢分享,距离警报不错,不是液位也可吧,看到楼主要工作台上测试了,
回复

使用道具 举报

地板
ID:541089 发表于 2021-6-16 09:55 | 只看该作者
john0317 发表于 2021-5-25 19:05
楼主,这个起始距离怎么是200多CM??

不是哦,是不是你模块不对
回复

使用道具 举报

5#
ID:541089 发表于 2021-6-16 09:56 | 只看该作者
ak333 发表于 2021-6-1 17:29
谢谢分享,距离警报不错,不是液位也可吧,看到楼主要工作台上测试了,

嗯嗯,对的
回复

使用道具 举报

6#
ID:495287 发表于 2021-6-16 16:26 | 只看该作者
谢谢楼主分享
回复

使用道具 举报

7#
ID:1009236 发表于 2022-3-11 16:59 | 只看该作者
error C202: 'RX': undefined identifier  什么意思
回复

使用道具 举报

8#
ID:262 发表于 2022-3-12 01:26 | 只看该作者
QQ1160775071 发表于 2022-3-11 16:59
error C202: 'RX': undefined identifier  什么意思

因为你缺少头文件  你补充后 用Keil5编译 我这里提示0错误
回复

使用道具 举报

9#
ID:541089 发表于 2022-3-30 10:26 | 只看该作者
QQ1160775071 发表于 2022-3-11 16:59
error C202: 'RX': undefined identifier  什么意思

没有定义RX
回复

使用道具 举报

10#
ID:1117272 发表于 2024-4-19 19:33 | 只看该作者
用它控制物料高低也可以吧
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

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