久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 3968|回復: 1
打印 上一主題 下一主題
收起左側

單片機超聲波測距程序原理圖

[復制鏈接]
跳轉到指定樓層
樓主
·       1.本設計采用STC89C51/52(與AT89S51/52、AT89C51/52通用,可任選)單片機作為主控制器
·       2.數碼管顯示測量的距離,74hc573和三極管驅動數碼管
·       3.HC-SR04超聲波模塊測距,測量范圍0.02m~5.5m以上
·       4.本設計可用作汽車的倒車雷達,報警距離可以用過按鍵設定和更改
·       5.附加功能:報警頻率可以隨著距離變化,距離越小頻率越快。(使用說明:
本設計共3個按鍵,一個設置鍵,一個加,一個減鍵,只有按下設置鍵的時候才可以加減。)



單片機源程序如下:
  1. #include <reg52.H>//器件配置文件
  2. #include <intrins.h>
  3. #include "eeprom52.h"
  4. //傳感器接口
  5. sbit RX  = P2^3;
  6. sbit TX  = P2^2;
  7. //按鍵聲明
  8. sbit S1  = P1^4;
  9. sbit S2  = P1^5;
  10. sbit S3  = P1^6;

  11. sbit DIAN=P0^5;                        //小數點引腳
  12. //蜂鳴器
  13. sbit Feng= P2^0;

  14. //變量聲明
  15. unsigned int  time=0;
  16. unsigned int  timer=0;
  17. unsigned char posit=0;
  18. unsigned long S=0;
  19. unsigned long BJS;//報警距離
  20. char num=0;
  21. //模式 0正常模式 1調整
  22. char Mode=0;
  23. bit  flag=0;

  24. unsigned char const discode[] ={0x5F,0x44,0x9D,0xD5,0xC6,0xD3,0xDB,0x47,0xDF,0xD7,0x80};        //數碼管顯示碼0123456789-和不顯示

  25. unsigned char disbuff[4]           ={0,0,0,0};                 //數組用于存放距離信息
  26. unsigned char disbuff_BJ[4]        ={0,0,0,0};//報警信息

  27. void Display(void);

  28. sbit W0=P2^4;
  29. sbit W1=P2^5;
  30. sbit W2=P2^6;
  31. sbit W3=P2^7;                                                                  //數碼管的位選引腳

  32. /******************把數據保存到單片機內部eeprom中******************/
  33. void write_eeprom()
  34. {
  35.         SectorErase(0x2000);                          //先清除
  36.         byte_write(0x2000, BJS);                  //寫數據
  37.         byte_write(0x2060, a_a);        
  38. }

  39. /******************把數據從單片機內部eeprom中讀出來*****************/
  40. void read_eeprom()
  41. {
  42.         BJS   = byte_read(0x2000);
  43.         a_a      = byte_read(0x2060);
  44. }

  45. /**************開機自檢eeprom初始化*****************/
  46. void init_eeprom()
  47. {
  48.         read_eeprom();                //先讀
  49.         if(a_a != 1)                //新的單片機初始單片機內問eeprom
  50.         {
  51.                 BJS   = 25;
  52.                 a_a = 1;
  53.                 write_eeprom();           //保存數據
  54.         }        
  55. }
  56. //延時1ms(不精確)
  57. void delay(unsigned int x)
  58. {
  59.     unsigned int i,j;
  60.     for(i=0;i<x;i++)
  61.         for(j=0;j<121;j++);
  62. }

  63. //按鍵掃描
  64. void Key_()
  65. {
  66.         unsigned char DIS_I;
  67.         //+
  68.         if(S1==0&&Mode==1)
  69.         {
  70.                 for(DIS_I=0;DIS_I<100;DIS_I++)
  71.                 Display();           //延時去抖
  72.                 if(S1==0)
  73.                 {
  74.                         Feng=0;
  75.                         for(DIS_I=0;DIS_I<200;DIS_I++)
  76.                         Display();           //延時
  77.                         Feng=1;
  78.                         BJS++;         //報警值加
  79.                         if(BJS>=151) //最大151
  80.                         {
  81.                                 BJS=0;
  82.                         }
  83.                         disbuff_BJ[0]=BJS%1000/100;
  84.                         disbuff_BJ[1]=BJS%1000%100/10;
  85.                         disbuff_BJ[2]=BJS%1000%10 %10;
  86.                         while(S1==0) Display();
  87.                 }
  88.         }
  89.         //-
  90.         else if(S2==0&&Mode==1)
  91.         {
  92.                 for(DIS_I=0;DIS_I<100;DIS_I++)
  93.                 Display();           //延時去抖
  94.                 if(S2==0)
  95.                 {
  96.                         Feng=0;
  97.                         for(DIS_I=0;DIS_I<200;DIS_I++)
  98.                         Display();           //延時
  99.                         Feng=1;
  100.                         BJS--;         //報警值減
  101.                         if(BJS<=1)         //最小1
  102.                         {
  103.                                 BJS=150;
  104.                         }
  105.                         disbuff_BJ[0]=BJS%1000/100;
  106.                         disbuff_BJ[1]=BJS%1000%100/10;
  107.                         disbuff_BJ[2]=BJS%1000%10 %10;
  108.                         while(S2==0) Display();
  109.                 }
  110.         }
  111.         //功能
  112.         else if(S3==0)                //設置鍵
  113.         {
  114.                 for(DIS_I=0;DIS_I<100;DIS_I++)
  115.                 Display();           //延時去抖
  116.                 if(S3==0)
  117.                 {
  118.                         Feng=0;
  119.                         for(DIS_I=0;DIS_I<200;DIS_I++)
  120.                         Display();           //延時
  121.                         Feng=1;
  122.                         Mode=!Mode;                //模式加
  123.                         num=0;
  124.                         Feng=1;
  125.                         disbuff_BJ[0]=BJS%1000/100;
  126.                         disbuff_BJ[1]=BJS%1000%100/10;
  127.                         disbuff_BJ[2]=BJS%1000%10 %10;
  128.                         while(S3==0) Display();
  129.                         if(Mode==0)
  130.                         write_eeprom();                           //保存數據
  131.                 }
  132.         }
  133. }
  134. /**********************************************************************************************************/
  135. //掃描數碼管
  136. void Display(void)                                 
  137. {
  138.         //正常顯示
  139.         if(Mode==0)                           //正常測距模式
  140.         {
  141.                 num++;                                                           //計數切換不同顯示數碼管
  142.                 if(num==1)                                                   //第一個數碼管
  143.                 {
  144.                         W3=1;                                                   //關閉第二位
  145.                         W0=1;                                                   //關閉第二位
  146.                         P0=~discode[disbuff[0]];           //顯示整數位,因為段碼數組為共陰數碼管碼表,所以在使用時要取反
  147.                         DIAN=0;                                                   //點亮小數點
  148.                         W1=0;                                                   //打開位
  149.                 }
  150.                 else if(num==2)                                           //第二位
  151.                 {
  152.                         W1=1;                                                   //關閉第一位
  153.                         P0=~discode[disbuff[1]];           //顯示小數點后一位
  154.                         W2=0;                                                   //打開第二位
  155.                 }
  156.                 else if(num>=3)                                           //第三個位置
  157.                 {
  158.                         W2=1;                                                   //關閉第二位
  159.                         P0=~discode[disbuff[2]];           //顯示小數點后二位
  160.                         W3=0;                                                   //打開第三位
  161.                         num=0;                                                   //清零
  162.                 }
  163.         }
  164.         //報警顯示
  165.         else
  166.         {
  167.                 num++;
  168.                 if(num==1)
  169.                 {
  170.                         W3=1;
  171.                         P0=~0xCE;                  //11001110 顯示字母H
  172.                         W0=0;
  173.                 }
  174.                 else if(num==2)
  175.                 {
  176.                         W0=1;
  177.                         P0=~discode[disbuff_BJ[0]];                   //顯示報警值
  178.                         DIAN=0;
  179.                         W1=0;        
  180.                 }
  181.                 else if(num==3)
  182.                 {
  183.                         W1=1;
  184.                         P0=~discode[disbuff_BJ[1]];
  185.                         W2=0;
  186.                 }
  187.                 else if(num>=4)
  188.                 {
  189.                         W2=1;
  190.                         P0=~discode[disbuff_BJ[2]];
  191.                         W3=0;
  192.                         num=0;
  193.                 }
  194.         }
  195. }
  196. /**********************************************************************************************************/
  197. //計算
  198. void Conut(void)
  199. {
  200.         time=TH0*256+TL0;          //讀出T0的計時數值
  201.         TH0=0;
  202.         TL0=0;                                  //清空計時器
  203.         S=(time*1.7)/100;     //算出來是CM
  204.         //聲音的速度是340m/s,時間的單位是us,計算到秒需要將時間數據/1000000,
  205.         //長度=速度*時間,340*time/1000000,長度數據單位是m轉換成cm需要乘以100得到340*time/10000,
  206.         //小數點都向左移兩位得到3.4*time/100,因為超聲波是往返了,所以再除以2,得到距離數據(time*1.7)/100
  207.         if(Mode==0)                          //非設置狀態時
  208.         {
  209.                 if((S>=700)||flag==1) //超出測量范圍顯示“-”
  210.                 {        
  211.                         Feng=0;                    //蜂鳴器報警
  212.                         flag=0;
  213.                         disbuff[0]=10;           //“-”
  214.                         disbuff[1]=10;           //“-”
  215.                         disbuff[2]=10;           //“-”
  216.                 }
  217.                 else
  218.                 {
  219.                         //距離小于報警距
  220.                         if(S<=BJS)
  221.                         {
  222.                                 Feng=0;        //報警
  223.                         }
  224.                         else  //大于
  225.                         {
  226.                                 Feng=1;                //關閉報警        
  227.                         }
  228.                         disbuff[0]=S%1000/100;                 //將距離數據拆成單個位賦值
  229.                         disbuff[1]=S%1000%100/10;
  230.                         disbuff[2]=S%1000%10 %10;
  231.                 }
  232.         }
  233.         else
  234.         {
  235.                         Feng=1;
  236.                         disbuff_BJ[0]=BJS%1000/100;
  237.                         disbuff_BJ[1]=BJS%1000%100/10;
  238.                         disbuff_BJ[2]=BJS%1000%10 %10;
  239.         }
  240. }
  241. /**********************************************************************************************************/
  242. //定時器0
  243. void zd0() interrupt 1                  //T0中斷用來計數器溢出,超過測距范圍
  244. {
  245. ……………………

  246. …………限于本文篇幅 余下代碼請從51黑下載附件…………
復制代碼

Keil程序下載:
程序原理圖.7z (257.67 KB, 下載次數: 52)

評分

參與人數 1黑幣 +50 收起 理由
admin + 50 共享資料的黑幣獎勵!

查看全部評分

分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏5 分享淘帖 頂 踩
回復

使用道具 舉報

沙發
ID:616633 發表于 2022-11-6 18:22 | 只看該作者
哥我想問一下驗證過了嗎?

回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

手機版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 无人区国产成人久久三区 | 亚洲国产一区二区三区四区 | 日韩欧美一级片 | 久久91精品国产 | h在线免费观看 | 91国内精精品久久久久久婷婷 | 亚洲 中文 欧美 | 日韩欧美大片 | 国产精品一区二区三区在线 | 激情五月婷婷在线 | www久久 | 国产日韩久久 | 国产视频精品在线观看 | 一级看片 | 亚洲精品乱码久久久久久按摩观 | 亚洲高清成人 | 久久久久久艹 | 久久久久亚洲精品 | 免费亚洲一区二区 | 日韩精品在线观看一区二区 | 97色在线视频 | 欧美精品啪啪 | 福利精品 | 国产精品久久久久久久久免费高清 | 日韩无 | 欧美一级电影免费 | 婷婷综合久久 | 中国美女一级黄色片 | 欧美精品欧美精品系列 | 久草网址 | 国产精品免费一区二区三区四区 | 中文字幕一区二区三区四区五区 | 欧美性大战久久久久久久蜜臀 | 亚洲国产成人一区二区 | 四虎影院免费在线 | 日本免费黄色一级片 | 久久99精品久久久久子伦 | 日本精品视频一区二区 | 日日夜夜精品视频 | 亚洲中午字幕 | 91伊人 |