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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

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

51單片機超聲波液位儀Proteus仿真原理圖程序PCB文件 帶溫度補償

[復制鏈接]
跳轉到指定樓層
樓主
全套51單片機超聲波液位儀資料,含程序、仿真、PCB文件,做出來的實物能實現功能。利用超聲波測液位,用LCD1602現實,帶溫度補償,帶報警指示。PCB蜂鳴器處忘加驅動,電流不夠,聲音不夠大,可換成燈。
初始零液位距離為15CM,報警液位為低于5CM,低于5CM時大燈點亮。
如需要校準改變零液位:
點擊設置,設置指示燈亮起
點擊液位歸零
再次點擊設置,指示燈熄滅,開始正常工作。
如需改變報警液位:
點擊設置
點擊加或者減
換位可以改變按加減時改變個位還是十分位的值,默認為十分位。
仿真說明:
仿真需要先校準歸零。
如第一次仿真失敗,方法如下:
停止仿真;
雙擊MCU,出現對話框;
點擊program file欄目后的文件夾圖標,出現文件選擇框;
選擇chengxu--output--雙擊HC-SR04.hex
點擊確定

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


Altium Designer畫的原理圖和PCB圖如下:(51hei附件中可下載工程文件)


單片機源程序如下:
  1. #include "config.h"
  2. #include "Lcd1602.h"
  3. #include "Ultrasonic.h"
  4. #include <reg52.h>

  5. uint8 flag;   //定義定時標志
  6. uint16 set_s;  //設定值
  7. uint16 lv_0;   //零位
  8. uint16 length;
  9. uint16 lv_n;

  10. bit flag1s = 0;          //1s定時標志
  11. bit fusu = 0;          //1s定時標志
  12. bit setflag= 0;          //進入設置模式標志
  13. bit changewei=0;
  14. unsigned char T0RH = 0;  //T0重載值的高字節
  15. unsigned char T0RL = 0;  //T0重載值的低字節
  16. //
  17. void ConfigTimer0(unsigned int ms);
  18. unsigned char IntToString(unsigned char *str, int dat);
  19. extern bit Start18B20();
  20. extern bit Get18B20Temp(int *temp);

  21. sbit led=P2^0;
  22. sbit bz=P1^5;
  23. sbit k3=P1^7;         //更換十位和百位
  24. sbit k1=P3^0;         //加
  25. sbit k2=P3^1;         //減
  26. sbit k4=P1^6;         //設置零位
  27. void ShowDistance();
  28. void ShowSets();
  29. void delayms(unsigned int ms);

  30. /* 主函數 */
  31. void main()
  32. {        
  33.            bit res;
  34.                
  35.     int temp;        //讀取到的當前溫度值
  36.     int intT, decT;  //溫度值的整數和小數部分
  37.     unsigned char len;
  38.     unsigned char str[12];
  39.     set_s=50;//mm
  40.         lv_0=150;//mm
  41.     EA = 1;            //開啟總中斷
  42.     TMOD &= 0Xf0;
  43.     TMOD |= 0X01;      //設置T0為方式1
  44.     TH0 = 0xFC;        //為T0賦初值0xFC67,定時1ms
  45.     TL0 = 0x67;
  46.     ET0 = 1;           //使能T0中斷
  47.     TR0 = 1;           //啟動T0
  48.         IT0=1;        //設置外部中斷0的觸發方式為下降沿
  49.         EX0=1;        //開啟外部中斷
  50.     InitUltrasonic();  //超聲波模塊初始化
  51.     InitLcd1602();     //1602初始化
  52.         Start18B20();      //啟動DS18B20
  53.         LcdShowStr(0, 0,"SETD:");  //顯示距離單位
  54.         LcdShowStr(0, 1,"LV:");  //顯示距離單位
  55.         LcdShowStr(10, 1,"T:");  //顯示距離單位
  56.         k1=1;

  57.     while(1)
  58.     {
  59.         if(flag == 1)
  60.         {
  61.             flag = 0;
  62.                         ShowSets();
  63.             ShowDistance();
  64.                     if (1)  //每秒更新一次溫度
  65.         {
  66.             res = Get18B20Temp(&temp);  //讀取當前溫度
  67.             if (res)                    //讀取成功時,刷新當前溫度顯示
  68.             {
  69.                 intT = temp >> 4;             //分離出溫度值整數部分
  70.                 decT = temp & 0xF;            //分離出溫度值小數部分
  71.                 len = IntToString(str, intT); //整數部分轉換為字符串
  72.                 str[len++] = '.';             //添加小數點
  73.                 decT = (decT*10) / 16;        //二進制的小數部分轉換為1位十進制位
  74.                 str[len++] = decT + '0';      //十進制小數位再轉換為ASCII字符
  75.                 while (len < 6)               //用空格補齊到6個字符長度
  76.                 {
  77.                     str[len++] = ' ';
  78.                 }
  79.                 str[len] = '\0';              //添加字符串結束符
  80.                 LcdShowStr(12, 1, str);        //顯示到液晶屏上
  81.             }
  82.             else                        //讀取失敗時,提示錯誤信息
  83.             {
  84.                 LcdShowStr(12, 1, "error!");
  85.             }
  86.             Start18B20();               //重新啟動下一次轉換
  87.         }
  88.         }
  89.                 while(setflag){//按下設置鍵,進入設置模式,循環直到再一次按下設置鍵

  90.                         if(k1==0)                  //檢測按鍵K1是否按下
  91.                                 {        
  92.                                         delayms(5);   //消除抖動 一般大約10ms
  93.                                         if(k1==0)         //再次判斷按鍵是否按下
  94.                                         {  
  95.                                                 if(changewei==0)set_s++;
  96.                                                 else set_s+=10;
  97.                                         }
  98.                                         while(!k1);         //檢測按鍵是否松開
  99.                                 }
  100.                         if(k2==0)                  //檢測按鍵K1是否按下
  101.                                 {        
  102.                                         delayms(5);   //消除抖動 一般大約10ms
  103.                                         if(k2==0)         //再次判斷按鍵是否按下
  104.                                         {
  105.                                                 if(changewei==0)set_s--;
  106.                                                         else set_s-=10;
  107.                                         }
  108.                                         while(!k2);         //檢測按鍵是否松開
  109.                                 }
  110.                         if(k3==0)                  //檢測按鍵K1是否按下
  111.                                 {        
  112.                                         delayms(5);   //消除抖動 一般大約10ms
  113.                                         if(k3==0)         //再次判斷按鍵是否按下
  114.                                         {
  115.                                                 changewei=~changewei;
  116.                                         }
  117.                                         while(!k3);         //檢測按鍵是否松開
  118.                                 }
  119.                         if(k4==0)                  //檢測按鍵K1是否按下
  120.                                 {        
  121.                                         delayms(5);   //消除抖動 一般大約10ms
  122.                                         if(k4==0)         //再次判斷按鍵是否按下
  123.                                         {
  124.                                          lv_0=length;
  125.                                         }
  126.                                         while(!k4);         //檢測按鍵是否松開
  127.                                 }
  128.                                 ShowSets();
  129.                 }
  130.                 if(lv_n>set_s) bz=1;
  131.                 else bz=0;
  132.     }
  133. }
  134. unsigned char IntToString(unsigned char *str, int dat)
  135. {
  136.     signed char i = 0;
  137.     unsigned char len = 0;
  138.     unsigned char buf[6];
  139.    
  140.     if (dat < 0)  //如果為負數,首先取絕對值,并在指針上添加負號
  141.     {
  142.         dat = -dat;
  143.         *str++ = '-';
  144.         len++;
  145.     }
  146.     do {          //先轉換為低位在前的十進制數組
  147.         buf[i++] = dat % 10;
  148.         dat /= 10;
  149.     } while (dat > 0);
  150.     len += i;     //i最后的值就是有效字符的個數
  151.     while (i-- > 0)   //將數組值轉換為ASCII碼反向拷貝到接收指針上
  152.     {
  153.         *str++ = buf[i] + '0';
  154.     }
  155.     *str = '\0';  //添加字符串結束符
  156.    
  157.     return len;   //返回字符串長度
  158. }




  159. /* 執行測距并顯示結果 */
  160. void ShowDistance()
  161. {   
  162.     uint8 i;
  163.     uint8 buff[4];
  164.         uint8 buff2[5];
  165.     uint16 Distance ;   //暫存距離值
  166.     Distance = GetDistance();
  167.         length = Distance;//mm
  168.         if (Distance < lv_0)
  169.                 {
  170.                 Distance = lv_0-Distance;
  171.                 lv_n= Distance;
  172.                 fusu=0;
  173.                 }
  174.         else
  175.          {
  176.                  Distance =Distance- lv_0;
  177.                  lv_n=0;
  178.                  fusu=1;
  179.          }
  180.         if((Distance<999)&&(fusu==0)){
  181.             buff[3] = Distance%10 + '0';   //將數據轉換為字符形式
  182.             buff[2] ='.';
  183.             buff[1] = (Distance/10)%10 + '0';
  184.             buff[0] = (Distance/100)%10 + '0';
  185.             for(i = 0; i <= 0; i++)  //整數部分高位的0轉換為空白符
  186.             {
  187.                 if(buff[i] == '0')   //判斷是不是字符0
  188.                     buff[i] = ' ';   //將字符0 轉換為空格 即不顯示
  189.                 else
  190.                     break;
  191.             }
  192.             LcdShowStr(3, 1, &buff); //顯示距離值
  193.             LcdShowStr(7, 1, "cm");  //顯示距離單位
  194.         }
  195.                 if((Distance<99)&&(fusu==1)){
  196.             buff[3] =' ';   //將數據轉換為字符形式
  197.             buff[2] =Distance%10 + '0';
  198.             buff[1] ='.';
  199.             buff[0] = (Distance/10)%10 + '0';
  200. //            for(i = 0; i <= 0; i++)  //整數部分高位的0轉換為空白符
  201. //            {
  202. //                if(buff[i] == '0')   //判斷是不是字符0
  203. //                    buff[i] = ' ';   //將字符0 轉換為空格 即不顯示
  204. //                else
  205. //                    break;
  206. //            }
  207.                         LcdShowStr(3, 1, "-");  //顯示距離單位
  208.             LcdShowStr(4, 1, &buff); //顯示距離值
  209.             LcdShowStr(7, 1, "cm");  //顯示距離單位
  210.         }
  211.         if(Distance>999||((Distance>99)&&(fusu==1))){
  212.                 LcdShowStr(3, 1, "ERROR");  //顯示距離單位
  213. //            else {
  214. //                        buff2[4] = Distance%10 + '0';   //將數據轉換為字符形式
  215. //                    buff2[3] ='.';
  216. //                    buff2[2] = (Distance/10)%10 + '0';
  217. //                    buff2[1] = (Distance/100)%10 + '0';
  218. //                        buff2[0] = (Distance/1000)%10 + '0';
  219. //                    for(i = 0; i <= 3; i++)  //整數部分高位的0轉換為空白符
  220. //                    {
  221. //                        if(buff2[i] == '0')   //判斷是不是字符0
  222. //                            buff2[i] = ' ';   //將字符0 轉換為空格 即不顯示
  223. //                        else
  224. //                            break;
  225. //                    }
  226. //                    LcdShowStr(3, 1, &buff2); //顯示距離值
  227. //                    LcdShowStr(8, 1, "cm");  //顯示距離單位
  228.         //        }
  229.         }
  230. }
  231. void ShowSets()
  232. {   
  233.     uint8 i;
  234.     uint8 buff[4];

  235.         if(set_s>999)set_s=999;
  236.     buff[3] = set_s%10 + '0';   //將數據轉換為字符形式
  237.     buff[2] ='.';
  238.     buff[1] = (set_s/10)%10 + '0';
  239.     buff[0] = (set_s/100)%10 + '0';
  240.     for(i = 0; i <= 3; i++)  //整數部分高位的0轉換為空白符
  241.     {
  242.         if(buff[i] == '0')   //判斷是不是字符0
  243.             buff[i] = ' ';   //將字符0 轉換為空格 即不顯示
  244.         else
  245.             break;
  246.     }
  247.     LcdShowStr(6, 0, &buff); //顯示距離值
  248.     LcdShowStr(10, 0, "cm");  //顯示距離單位
  249. }

  250. /* 定時器0中斷服務函數 */
  251. ……………………

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

所有資料51hei附件下載:
超聲波液位儀.7z (131.92 KB, 下載次數: 131)

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

使用道具 舉報

沙發
ID:328014 發表于 2021-8-7 16:18 | 只看該作者
好資料,51黑有你更精彩!!!
回復

使用道具 舉報

板凳
ID:66328 發表于 2021-8-9 13:11 | 只看該作者
大神牛啊,那個超聲波的仿真模塊在哪里下的
回復

使用道具 舉報

地板
ID:1076417 發表于 2023-5-9 19:30 | 只看該作者
hnqylgq 發表于 2021-8-9 13:11
大神牛啊,那個超聲波的仿真模塊在哪里下的

Proteus8.9里面自帶
回復

使用道具 舉報

5#
ID:1113285 發表于 2024-3-20 14:50 | 只看該作者
好資料,加個電機驅動就完美了
回復

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 中文字幕免费在线 | 国精产品一区二区三区 | 国产第一页在线播放 | 视频三区| 大学生a级毛片免费视频 | 91久久久久久久久久久久久 | 国产精品视频一二三区 | 精品欧美一区二区三区久久久 | 国产一区二区三区久久久久久久久 | 中文字幕在线视频免费视频 | 欧美a在线 | 自拍偷拍3p| 91精品免费 | 国产精品区一区二 | 色性av | 免费一级片| 午夜影院黄 | www久久久| 欧美在线观看一区 | 午夜免费在线 | 在线观看亚洲 | 久久精品视频在线观看 | 中文字幕一级毛片视频 | 二区三区视频 | 成人在线精品视频 | 日韩午夜网站 | 国产一区二区 | 综合色导航| 午夜精品久久 | 国产日韩欧美精品一区二区 | 国产午夜精品一区二区三区嫩草 | 日韩精品一区二区在线观看 | 国产综合久久 | 亚洲欧美视频在线观看 | 国产精品a一区二区三区网址 | 亚洲国产精品久久 | 日日操av | 国产在线一区二区三区 | 欧美一区 | 91pao对白在线播放 | 天天操夜夜爽 |