找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 4975|回复: 4
收起左侧

基于51单片机超声波测距带语音播报JQ6500(包含原理图、源程序及参考资料)

  [复制链接]
ID:331717 发表于 2020-12-18 13:48 | 显示全部楼层 |阅读模式
本帖最后由 电子哎嗨 于 2021-1-9 10:01 编辑

原创作品,禁止转载售卖,仅供学习参考!!!
功能说明
1.本设计采用STC89C52单片机作为主控制器;
2.LCD1602液晶显示测量的距离和温度;
3.带有温度补偿功能(DS18B20传感器);
4.测量范围0.02m~4m,精度为0.01m
5.带实时语音播报功能;
6.按键功能:按键2:加报警值按键3:减报警值按键1:设置按键(只有在按下设置的时候才可以加减报警值),在未按下按键1时,按下按键3播报测量距离。
需要设计实物请私聊~
实物制作图:
水印vx.jpg

原理图:
663[~KYON8K0Q3F%~0PRAK1.png

4556666.png

单片机源程序如下:
  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=10;
  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. uchar ONE1[6]={0x7E,0x04,0x03,0x00,0X0D,0xEF};//现在距离为
  33. uchar ONE2[6]={0x7E,0x04,0x03,0x00,0X0C,0xEF};//米
  34. uchar ONE3[6]={0x7E,0x04,0x03,0x00,0X0B,0xEF};//点
  35. uchar ONE4[6]={0x7E,0x04,0x03,0x00,0X00,0xEF};//百位
  36. uchar ONE5[6]={0x7E,0x04,0x03,0x00,0X00,0xEF};//十位
  37. uchar ONE6[6]={0x7E,0x04,0x03,0x00,0X00,0xEF};//个位

  38. void delayms(uint ms)
  39. {
  40.         uchar i=100,j;
  41.         for(;ms;ms--)
  42.         {
  43.                 while(--i)
  44.                 {
  45.                         j=10;
  46.                         while(--j);
  47.                 }
  48.         }
  49. }

  50. /******** UART初始化 波特率:9600 ******/
  51. void UART_init(void)
  52. {
  53.     SCON = 0x50;        // 10位uart,允许串行接受
  54.     TMOD = 0x20;       // 定时器1工作在方式2(自动重装)
  55.     TH1 = 0xFD;
  56.     TL1 = 0xFD;         //设置波特率为9600
  57.     TR1 = 1;
  58. }

  59. /*
  60. * UART 发送一字节
  61. 入口参数uint8的数据类型 即要发送的数据
  62. */
  63. void UART_send_byte(uchar dat)
  64. {
  65.         SBUF = dat;
  66.         while (TI == 0);
  67.         TI = 0;
  68. }

  69. /*
  70. * UART 发送字符串
  71.   第一个参数要发送字符串或数据的首地址
  72.   第二个参数是要发送的数据或字符串的长度
  73. */
  74. void UART_send_string(uchar *buf,uchar len)
  75. {  
  76.     uchar i;
  77.         for(i=0;i<len;i++)
  78.         UART_send_byte(*buf++);
  79. }



  80. //主函数
  81. void main()
  82. {
  83.         UART_init();
  84.         Init_ultrasonic_wave();
  85.         //屏幕初始化
  86.         Init1602();
  87.         //温度初始化
  88.         tmpchange();
  89.         t_=tmp();
  90.         tmpchange();
  91.         t_=tmp();
  92.         tmpchange();
  93.         t_=tmp();

  94.         //循环显示
  95.         while(1)
  96.         {
  97.                 Key();
  98.                 if(yuyin_flag==1)
  99.                 {
  100.                    yuyin_flag=0;

  101.                    ONE4[4]=L_/100;
  102.                    ONE5[4]=L_/10%10;
  103.                    ONE6[4]=L_%10;
  104.                    if(ONE4[4]==0)ONE4[4]=0x0A;
  105.                    if(ONE5[4]==0)ONE5[4]=0x0A;
  106.                    if(ONE6[4]==0)ONE6[4]=0x0A;
  107.                   
  108.                    UART_send_string(ONE1,6);
  109.                    delayms(1);
  110.                    UART_send_string(ONE4,6);
  111.                    delayms(1);
  112.                    UART_send_string(ONE3,6);
  113.                    delayms(1);
  114.                    UART_send_string(ONE5,6);
  115.                    delayms(1);
  116.                    UART_send_string(ONE6,6);
  117.                    delayms(1);
  118.                    UART_send_string(ONE2,6);
  119.                    delayms(1);
  120.                 }
  121.                 //正常显示
  122.                 if(mode==0)
  123.                 {
  124.                         StartModule();//启动超声波
  125.                         while(!RX);          //当RX为零时等待
  126.                         TR0=1;                  //开启计数
  127.                         while(RX);          //当RX为1计数并等待
  128.                         TR0=0;                  //关闭计数
  129.         
  130.                         delayms(20);  //20MS
  131.                         tmpchange();  //温度转换
  132.                         t_=tmp();     //度温度
  133.                         Conut(t_/10); //计算距离
  134.                         if(L_>Max||L_<Min)
  135.                         {
  136.                                 Feng_Start();
  137.                         }
  138.                         else
  139.                         {
  140.                                 if(FW!=1)
  141.                                 Feng_Stop();
  142.                         }
  143.                         Display_1602(t_/10,L_);
  144.                 }
  145.                 //调整显示
  146.                 else if(mode!=0)
  147.                 {
  148.                         //最大最小值
  149.                         Init_MaxMin();
  150.                         while(mode!=0)
  151.                         {
  152.                                 
  153.                                 Key();
  154.                                 if(k==1&&mode==1)
  155.                                 {
  156.                                         Init_MaxMin();        
  157.                                    write_com(0x8d);//设置位置                                       
  158.                                 }
  159.                                 else if(k==1&&mode==2)
  160.                                 {
  161.                                         Init_MaxMin();        
  162.                                    write_com(0x8d+0x40);//设置位置        
  163.                                 }
  164.                                 k=0;
  165.                         }
  166.                         //界面初始化
  167.                         Init1602();
  168.                 }
  169.         }
  170. }


  171. //T0中断用来计数器溢出,超过测距范围
  172. void CJ_T0() interrupt 1
  173. {
  174.     flags=1;                                                         //中断溢出标志
  175. }
复制代码

原理图.rar (169.84 KB, 下载次数: 122)

评分

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

查看全部评分

回复

使用道具 举报

ID:475916 发表于 2021-1-7 18:09 | 显示全部楼层
实时语音播报播放的是距离信息吗
回复

使用道具 举报

ID:331717 发表于 2021-1-8 23:36 | 显示全部楼层
zhang666666 发表于 2021-1-7 18:09
实时语音播报播放的是距离信息吗

是的,播报当前测量距离
回复

使用道具 举报

ID:817506 发表于 2021-1-11 09:38 来自手机 | 显示全部楼层
JQ6500在proteus中怎么找?
回复

使用道具 举报

ID:247623 发表于 2021-3-19 20:59 | 显示全部楼层
你这个资料为啥不能放一个包里面,还分3个,有点不道德
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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