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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

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

單片機超聲波測距Proteus仿真及源程序

  [復制鏈接]
跳轉到指定樓層
樓主
ID:541528 發表于 2019-5-18 16:52 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
keil程序  不懂得可以聯系我 哈哈

超聲波測距仿真原理圖如下(proteus仿真工程文件可到本帖附件中下載)


超聲波模塊加載HC-SR04.hex
單片機加載    程序.hex

電路原理圖如下:


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

  12. sbit W1=P1^0;
  13. sbit W2=P1^1;
  14. sbit W3=P1^2;
  15. sbit W4=P1^3;
  16. //變量聲明
  17. unsigned int  time=0;
  18. unsigned int  timer=0;
  19. unsigned char posit=0;
  20. unsigned long S=0;
  21. unsigned long BJS=50;//報警距離80CM
  22. //模式 0正常模式 1調整
  23. char Mode=0;
  24. bit  flag=0;
  25. bit flag_KEY=0;
  26. unsigned char const discode[] ={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,0x40,0xff/*-*/};        //數碼管顯示碼0123456789-和不顯示
  27. //unsigned char const positon[4]={0xfd,0xfb,0xf7,0xfe};        //位選
  28. unsigned char disbuff[4]           ={0,0,0,0};                 //數組用于存放距離信息
  29. unsigned char disbuff_BJ[4]        ={0,0,0,0};//報警信息
  30. void Display();
  31. //延時20ms(不精確)
  32. void delay(void)
  33. {
  34.     unsigned char a,b,c;
  35.     for(c=2;c>0;c--)
  36.         for(b=38;b>0;b--)
  37.             for(a=60;a>0;a--);
  38. }

  39. //按鍵掃描
  40. void Key_()
  41. {
  42.         if(flag_KEY==0)
  43.         {
  44.                 if(Mode!=0)
  45.                 {
  46.                         //+
  47.                         if(S1==0)
  48.                         {
  49.                                 delay();           //延時去抖
  50.                                 if(S1==0)
  51.                                 {
  52.                                         BJS++;         //報警值加
  53.                                         flag_KEY=1;
  54.                                         if(BJS>=151) //最大151
  55.                                         {
  56.                                                 BJS=0;
  57.                                         }
  58. //                                        while(S1==0)
  59. //                                        Display();
  60.                                 }
  61.                                 
  62.                         }
  63.                         //-
  64.                         if(S2==0)
  65.                         {
  66.                                 delay();
  67.                                 if(S2==0)
  68.                                 {
  69.                                         BJS--;         //報警值減
  70.                                         flag_KEY=1;
  71.                                         if(BJS<=1)         //最小1
  72.                                         {
  73.                                                 BJS=150;
  74.                                         }        
  75. //                                        while(S2==0)
  76. //                                        Display();
  77.                                 }
  78.                                 
  79.                         }
  80.                 }
  81.                 //功能
  82.                 if(S3==0)                //設置鍵
  83.                 {
  84.                         delay();
  85.                         if(S3==0)
  86.                         {
  87.                                 Mode++;                //模式加
  88.                                 flag_KEY=1;
  89.                                 if(Mode>=2)                //加到2時清零
  90.                                 {
  91.                                         Mode=0;
  92.                                 }
  93. //                                while(S3==0)
  94. //                                Display();
  95.                         }
  96.                 }
  97.         }
  98.         if((P1&0x70)==0x70)
  99.         {
  100.                 flag_KEY=0;
  101.         }
  102. }
  103. /**********************************************************************************************************/
  104. //掃描數碼管
  105. void Display(void)                                 
  106. {
  107.         //正常顯示
  108.         if(Mode==0)
  109.         {
  110.                 P0=0x00;  //關閉顯示
  111.                 if(posit==1)//數碼管的小數點
  112.                 {
  113.                         P0=0xff;
  114.                         P0=(discode[disbuff[posit]])|0x80;
  115.                         
  116.                         //按位或,最高位變為1,顯示小數點
  117.                 }
  118.                 else if(posit==0)
  119.                 {
  120.                         P0=0xff;
  121.                         P0=~discode[11];

  122.                 }
  123.                 else
  124.                 {
  125.                         P0=0xff;
  126.                         P0=discode[disbuff[posit]];
  127.                         
  128.                 }
  129.                 switch(posit)
  130.                 {
  131.                         case 0 : W1=0;W2=1;W3=1;W4=1; break;
  132.                         case 1 : W1=1;W2=0;W3=1;W4=1; break;
  133.                         case 2 : W1=1;W2=1;W3=0;W4=1; break;
  134.                         case 3 : W1=1;W2=1;W3=1;W4=0; break;
  135.                 }
  136.                 posit++;
  137.                 if(posit>3)                //每進一次顯示函數,變量加1
  138.                         posit=0;                //加到3時清零
  139.         }
  140.         //報警顯示
  141.         else
  142.         {
  143.                 P0=0x00;
  144.                 if(posit==1)//數碼管的小數點
  145.                 {
  146.                         P0=(discode[disbuff_BJ[posit]])|0x80;
  147.                 }
  148.                 else if(posit==0)
  149.                 {
  150.                         P0=0x76;        //顯示字母               
  151.                 }
  152.                 else
  153.                 {
  154.                         P0=discode[disbuff_BJ[posit]];
  155.                 }
  156.                 switch(posit)
  157.                 {
  158.                         case 0 : W1=0;W2=1;W3=1;W4=1; break;
  159.                         case 1 : W1=1;W2=0;W3=1;W4=1; break;
  160.                         case 2 : W1=1;W2=1;W3=0;W4=1; break;
  161.                         case 3 : W1=1;W2=1;W3=1;W4=0; break;
  162.                 }
  163.                 posit++;
  164.                 if(posit>3)
  165.                         posit=0;
  166.         }
  167. }
  168. /**********************************************************************************************************/
  169. //計算
  170. void Conut(void)
  171. {
  172.         time=TH0*256+TL0;          //讀出T0的計時數值
  173.         TH0=0;
  174.         TL0=0;                                  //清空計時器
  175.         S=(time*1.7)/100;     //算出來是CM
  176.         //聲音的速度是340m/s,時間的單位是us,計算到秒需要將時間數據/1000000,
  177.         //長度=速度*時間,340*time/1000000,長度數據單位是m轉換成cm需要乘以100得到340*time/10000,
  178.         //小數點都向左移兩位得到3.4*time/100,因為超聲波是往返了,所以再除以2,得到距離數據(time*1.7)/100
  179.         if(Mode==0)                          //非設置狀態時
  180.         {
  181.                 if((S>=700)||flag==1) //超出測量范圍顯示“-”
  182.                 {        
  183.                         Feng=0;                    //蜂鳴器報警
  184.                         flag=0;
  185.                         disbuff[1]=10;           //“-”
  186.                         disbuff[2]=10;           //“-”
  187.                         disbuff[3]=10;           //“-”
  188.                 }
  189.                 else
  190.                 {
  191.                         //距離小于報警距
  192.                         if(S<=BJS)
  193.                         {
  194.                                 Feng=0;        //報警
  195.                         }
  196.                         else  //大于
  197.                         {
  198.                                 Feng=1;                //關閉報警        
  199.                         }
  200.                         disbuff[1]=S%1000/100;                 //將距離數據拆成單個位賦值
  201.                         disbuff[2]=S%1000%100/10;
  202.                         disbuff[3]=S%1000%10 %10;
  203.                 }
  204.         }
  205.         else
  206.         {
  207.                         Feng=1;
  208.                         disbuff_BJ[1]=BJS%1000/100;
  209.                         disbuff_BJ[2]=BJS%1000%100/10;
  210.                         disbuff_BJ[3]=BJS%1000%10 %10;
  211.         }
  212. }
  213. /**********************************************************************************************************/
  214. //定時器0
  215. void zd0() interrupt 1                  //T0中斷用來計數器溢出,超過測距范圍
  216. {
  217.         flag=1;                                                 //中斷溢出標志
  218. }
  219. /**********************************************************************************************************/
  220. //定時器1
  221. void zd3() interrupt 3                  //T1中斷用來掃描數碼管和計800MS啟動模塊
  222. {
  223.         TH1=0xf8;
  224.         TL1=0x30;                                 //定時2ms
  225.         Key_();                                        //掃描按鍵
  226.         Display();                                //掃描顯示
  227.         timer++;                                //變量加
  228.         if(timer>=400)                        //400次就是800ms
  229.         {
  230.                 timer=0;
  231.                 TX=1;                                  //800MS  啟動一次模塊
  232.                 _nop_();
  233.                 _nop_();
  234.                 _nop_();
  235.                 _nop_();
  236.                 _nop_();
  237.                 _nop_();
  238.                 _nop_();
  239.                 _nop_();
  240.                 _nop_();
  241.                 _nop_();
  242.                 _nop_();
  243.                 _nop_();
  244.                 _nop_();
  245.                 _nop_();
  246.                 _nop_();
  247.                 _nop_();
  248.                 _nop_();
  249.                 _nop_();
  250.                 _nop_();
  251.                 _nop_();
  252.                 _nop_();
  253.                 TX=0;
  254.         }
  255. }
  256. /**********************************************************************************************************/
  257. //主函數
  258. void main(void)
  259. {  
  260.         TMOD=0x11;                   //設T0為方式1
  261.         TH0=0;
  262.         TL0=0;         
  263.         TH1=0xf8;                   //2MS定時
  264.         TL1=0x30;
  265.         ET0=1;                                //允許T0中斷
  266.         ET1=1;                           //允許T1中斷
  267.         TR1=1;                           //開啟定時器
  268.         EA=1;                                        //開啟總中斷        
  269.         while(1)
  270.         {
  271.                 while(!RX);                //當上次接收完波后,RX引腳是低電平,取反就是1,此while成立,反復判斷RX狀態。當RX沒有接收到返回波時是高電平,取反就是0,此while不成立,跳出
  272.                 TR0=1;                        //開啟計數
  273.                 while(RX);                //當RX沒有接收到返回波,此while成立,程序停在這里一直判斷RX狀態。當RX接收到返回波,RX引腳變為低電平,此while不成立,跳出
  274.                 TR0=0;                        //停止計數
  275.                 Conut();                        //計算
  276.         }
  277. }
復制代碼

所有資料51hei提供下載:
超聲波測距.zip (11.65 MB, 下載次數: 521)


評分

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

查看全部評分

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

使用道具 舉報

沙發
ID:89286 發表于 2019-5-19 11:09 | 只看該作者
thanks for sharing
回復

使用道具 舉報

板凳
ID:468227 發表于 2019-6-25 15:09 | 只看該作者
請問超聲波模塊的源程序在哪邊呀  做硬件仿真需要… 哭唧唧
回復

使用道具 舉報

地板
ID:576149 發表于 2019-7-2 10:23 | 只看該作者
贊一個
回復

使用道具 舉報

5#
ID:599601 發表于 2019-8-13 15:36 | 只看該作者
值得下載
回復

使用道具 舉報

6#
ID:719691 發表于 2020-3-31 17:58 | 只看該作者

請問超聲波模塊的源程序在哪邊呀  做硬件仿真需要… 哭唧唧
回復

使用道具 舉報

7#
ID:383061 發表于 2020-4-6 20:43 | 只看該作者
有超聲波這塊的源程序嗎
回復

使用道具 舉報

8#
ID:582255 發表于 2020-4-8 21:15 | 只看該作者
請問怎么添加超聲波模塊啊
回復

使用道具 舉報

9#
ID:730612 發表于 2020-4-22 13:45 | 只看該作者
原理怎么分析呢
回復

使用道具 舉報

10#
ID:737750 發表于 2020-4-27 21:35 | 只看該作者
13962992850 發表于 2019-6-25 15:09
請問超聲波模塊的源程序在哪邊呀  做硬件仿真需要… 哭唧唧

我也蹲一個,難道不是在下載里面嗎?
回復

使用道具 舉報

11#
ID:328014 發表于 2020-7-5 15:55 | 只看該作者
飛葉1007 發表于 2020-3-31 17:58
請問超聲波模塊的源程序在哪邊呀  做硬件仿真需要… 哭唧唧

那280行程序,不是已經在網頁上面看到了嗎?壓縮包里面也有 還有hex
回復

使用道具 舉報

12#
ID:797980 發表于 2020-7-6 23:00 來自手機 | 只看該作者
到4以上依然能顯示
回復

使用道具 舉報

13#
ID:802754 發表于 2020-7-13 20:45 | 只看該作者
蹲一個超聲波模塊的源程序
回復

使用道具 舉報

14#
ID:887623 發表于 2021-3-2 13:14 | 只看該作者
不錯的 仿真文件 感謝
回復

使用道具 舉報

15#
ID:830448 發表于 2021-3-18 11:50 | 只看該作者

水貼來拿黑必
回復

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 午夜在线免费观看 | 龙珠z国语版在线观看 | 欧美性网 | 草草视频在线播放 | 国产日韩一区二区三免费 | 久久69精品久久久久久国产越南 | 欧美激情在线精品一区二区三区 | 国产精品伦理一区 | 色视频网站在线观看 | 亚洲欧美一区二区三区国产精品 | 精品日本中文字幕 | 亚洲精品久久 | 久久久久无码国产精品一区 | 久久久久免费 | 国产精品区二区三区日本 | 国产午夜精品一区二区三区四区 | 久久久久se| 免费观看黄网站 | 毛片黄| 免费午夜剧场 | 精品一区二区三区在线观看国产 | 亚洲高清在线观看 | 久久99精品久久久久久 | 国产成人精品免费视频大全最热 | 欧美视频一区二区三区 | 国产精品成人在线 | 99在线播放 | 亚洲男人网 | 九九亚洲 | 国产精品1区2区3区 中文字幕一区二区三区四区 | 在线欧美小视频 | 精品欧美一区二区精品久久久 | 成人激情视频免费在线观看 | 国产精品色综合 | 欧美一级在线 | 黄色片在线网站 | 国产精品久久久久久久久久 | 国产精品美女久久久久久久久久久 | 国产在视频一区二区三区吞精 | 久久精品国产精品青草 | 国产色婷婷久久99精品91 |