找回密码
 立即注册

QQ登录

只需一步,快速开始

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

蓝侨杯单片机超声波模块程序

[复制链接]
跳转到指定楼层
楼主
ID:841799 发表于 2021-5-27 17:24 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
  1. #include <stc15f2k60s2.h>
  2. #include "intrins.h"

  3. #define uchar unsigned char
  4. #define uint unsigned int
  5.         
  6. sbit TX = P1^0;  //发射引脚
  7. sbit RX = P1^1;  //接收引脚
  8. uchar tab[] = {0xc0, 0xf9, 0xa4, 0xb0, 0x99, 0x92, 0x82, 0xf8, 0x80, 0x90, 0xff,0x8e};
  9. uchar code weixuan[]={0x01,0x02,0x04,0x08,0x10,0x20,0x40,0x80};
  10. uchar dspbuf[] = {10,10,10,10,10,10,10,10};
  11. uint distance,time = 0,intr=0;
  12. uchar s_flag = 0,du=0,moshi;
  13. void display();
  14. void moshi0();
  15. void moshi1();
  16. void xian();
  17. void Delay12us();
  18. void send_wave();
  19. void all_chushihua();
  20. void all_chushihua()
  21. {
  22.         P0 = 0xff;
  23.         P2 = (P2 & 0x1f) | 0x80;
  24.         P2 = 0x1f;
  25.         P0 = 0x00;
  26.         P2 = (P2 & 0x1f) | 0xa0;
  27.         P2 = 0x1f;
  28.         P0=0XFF;
  29.         P2=(P2&0X1F)|0XC0;
  30.         P2=P2&0X1F;
  31.         P0=0XFF;
  32.         P2=(P2&0X1F)|0XE0;
  33.         P2=P2&0X1F;
  34. }
  35. void main(void)
  36. {
  37.   all_chushihua();
  38.         //AUXR = 0x80;
  39.   TMOD = 0x11;  //配置定时器工作模式
  40.   TH0 = (65535-2000)/256;
  41.   TL0 = (65535-2000)/256;  
  42.   TH1 = 0;
  43.   TL1 = 0;  
  44.   TR0 = 1;  //启动定时器
  45.   EA = 1;
  46.   ET0 = 1;  //打开定时器0中断
  47.   while(1)
  48.   {
  49.         /** 200毫秒更新一次数据 */
  50.                 if(s_flag)
  51.     {
  52.       s_flag = 0;
  53.             /** 关闭定时器0中断:计算超声波发送到返回的时间 */
  54. //                         ET0 = 0;
  55.       send_wave();  //发送方波信号
  56.       TR1 = 1;  //启动计时
  57.                         while((RX == 1) && (TF1 == 0));  //等待收到脉冲,没有计满溢出
  58.                         TR1 = 0;  //关闭计时

  59.                         //发生溢出
  60.                         if(TF1 == 1)
  61.                         {
  62.                                 TF1 = 0;
  63.                                 distance = 9999;  //无返回
  64.                                 moshi=0;
  65.                         }
  66.                         else
  67.                         {
  68.                                 /**  计算时间  */
  69.                                 time=TH1*256+TL1;
  70.                                 distance = (unsigned int)(time*0.017);  //计算距离        340 00 /1000 000/2=0.017
  71.         if(distance<10)  distance=10;  //在这规范那个范围内,
  72.         if(distance>50)  distance=50;                                
  73.         moshi=1;                                
  74.                         }
  75.                         TH1 = 0;
  76.                         TL1 = 0;
  77.     }
  78.         }
  79. }

  80. //定时器0中断服务函数
  81. void time0()  interrupt 1  //默认中断优先级 1
  82. {
  83.         TH0 = (65535-2000)/256;
  84.   TL0 = (65535-2000)/256;
  85.         if(++intr == 100){
  86.    
  87.    s_flag = 1;intr = 0;}
  88.         
  89.         display();
  90. }
  91. void Delay12us()//@11.0592MHz
  92. {
  93.         unsigned char i;

  94.         _nop_();
  95.         _nop_();
  96.         _nop_();
  97.         i = 30;
  98.         while (--i);
  99. }

  100. void send_wave()//发送八段脉冲波(40Khz)
  101. {
  102.         unsigned char i = 8;
  103.         
  104.         while(i --)
  105.         {
  106.                 TX = 1;
  107.                 Delay12us();
  108.                 TX = 0;
  109.                 Delay12us();
  110.         }
  111. }
  112. void xianshi0()
  113. {
  114.         switch(du)
  115.         {
  116.                 case 0:P0=tab[11];break;
  117.                 case 1:P0=tab[10];break;
  118.                 case 2:P0=tab[10];break;
  119.                 case 3:P0=tab[10];break;
  120.                 case 4:P0=tab[10];break;
  121.                 case 5:P0=tab[10];break;
  122.                 case 6:P0=tab[10];break;
  123.                 case 7:P0=tab[10];break;
  124.         }
  125. }
  126. void xianshi1()
  127. {
  128.         switch(du)
  129.         {
  130.                 case 0:P0=tab[10];break;
  131.                 case 1:P0=tab[10];break;
  132.                 case 2:P0=tab[10];break;
  133.                 case 3:P0=tab[10];break;
  134.                 case 4:P0=tab[10];break;
  135.                 case 5:P0=tab[distance/100%10];break;
  136.                 case 6:P0=tab[distance/10%10];break;
  137.                 case 7:P0=tab[distance%10]; break;
  138.         }
  139. }
  140. void xian()
  141. {
  142.         switch(moshi)
  143.         {
  144.                 case 0:xianshi0();break;
  145.                 case 1:xianshi1();break;
  146.         }
  147. }
  148. void display()
  149. {
  150.         P0=weixuan[du];
  151.         P2=(P2&0X1F)|0XC0;
  152.         P2=P2&0X1F;
  153.         xian();
  154.         P2=(P2&0X1F)|0XE0;
  155.         P2=P2&0X1F;
  156.   if(++du>7) du=0;
  157. }
复制代码

超声波_DYH.rar (100.26 KB, 下载次数: 11)
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏1 分享淘帖 顶 踩
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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