找回密码
 立即注册

QQ登录

只需一步,快速开始

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

STC89C52单片机+超声波测距传感器程序

[复制链接]
跳转到指定楼层
楼主
ID:318489 发表于 2023-12-12 15:54 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
超声波测量距离,并且距离越近蜂鸣器报警的频率越高

单片机源程序如下:
  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.                                 TR1=1;

  67.                         }
  68.                         else
  69.                         {
  70.                                 Feng=1;
  71.                                 TR1=0;
  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. }
  118. //定时器1
  119. void zd3() interrupt 3                  //T1中断用来扫描数码管和计800MS启动模块
  120. {
  121.         unsigned int m;
  122.         TH1=0xf8;
  123.         TL1=0x30;                                          //定时器赋初值2ms

  124.                 m++;                                          //2ms  m加一次
  125.                 if(m>=(L_+10))                          //m的值大于等于距离加10
  126.                 {
  127.                         m=0;                                  //m清零
  128.                         Feng=!Feng;                          //蜂鸣器取反
  129.                 }
  130. }
复制代码

原理图: 见附件
仿真: 无
代码: 超声波测距.zip (49.02 KB, 下载次数: 33)
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖 顶 踩
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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