找回密码
 立即注册

QQ登录

只需一步,快速开始

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

51单片机+LCD1602超声波测距仪Proteus仿真设计(含源程序)

[复制链接]
跳转到指定楼层
楼主
功能描述:
1.本设计采用STC89C52单片机作为主控制器;
2.LCD1602液晶显示测量的距离和温度;
3.带有温度补偿功能(DS18B20传感器);
4.测量范围0.02m~4m,精度为0.01m;
5.按键功能:按键1:加报警值按键2:减报警值按键3:设置按键(只有在设置的时候才可以加减报警值)

仿真截图(Proteus8.13):


单片机源程序如下:
  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. }
复制代码

Keil代码与Proteus8.13仿真下载:
仿真和程序.7z (165.41 KB, 下载次数: 163)

评分

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

查看全部评分

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

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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