找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 1702|回復: 1
收起左側

基于51單片機DS18B20溫度檢測報警系統(tǒng)串口設置閥值-仿真及源程序

[復制鏈接]
ID:190577 發(fā)表于 2023-11-15 14:32 | 顯示全部樓層 |閱讀模式
一、系統(tǒng)方案
1、本設計采用51單片機作為主控器。
2、DS18B20采集溫度值送到數(shù)碼管顯示。
3、按鍵報警閥值或串口設置閥值。
4、測量溫度小于下限或大于上限,蜂鳴器報警。
1.png

二、硬件設計
原理圖如下:
2.png
三、單片機軟件設計
1、首先是系統(tǒng)初始化
uint z;
        init_eeprom();  //開始初始化保存的數(shù)據(jù)
        InitTimer();    //初始化定時器
        wendu=ReadTemperature()-5;                          //獲取溫度值并減去DS18B20的溫漂誤差
        for(z=0;z<300;z++)
        {
                Disp_init();        
        }
        Uart_init();
2、顯示程序
  1. /*****顯示報警溫度子程序*****/
  2. void Disp_alarm(uchar baojing)
  3. {
  4.         P0 =LEDData[baojing%10];      //
  5.         P2 = 0xBF;
  6.         Delay(100);
  7.         P2=0xff;

  8.         P0 =LEDData[baojing%100/10]; //顯示十位
  9.         P2 = 0xEF;
  10.         Delay(100);
  11.         P2=0xff;

  12.         if(set_st==1&&H_ZF==0&&baojing/100!=0)
  13.         P0 =LEDData[baojing/100]; //顯示百位
  14.         else if(set_st==1&&H_ZF==0&&baojing/100==0)
  15.         P0=0x00;
  16.         else if(set_st==1&&H_ZF==1)
  17.         P0=0x80;
  18.         else if(set_st==2&&L_ZF==0&&baojing/100!=0)
  19.         P0 =LEDData[baojing/100]; //顯示百位
  20.         else if(set_st==2&&L_ZF==0&&baojing/100==0)
  21.         P0=0x00;
  22.         else if(set_st==2&&L_ZF==1)
  23.         P0=0x80;
  24.         P2 = 0xFB;
  25.         Delay(100);
  26.         P2=0xff;

  27.         if(set_st==1)P0 =0xCE;
  28.         else if(set_st==2)P0 =0x1A; //上限H、下限L標示
  29.         P2 = 0xFE;
  30.         Delay(100);
  31.         P2 = 0xff;         //關閉顯示
  32. }
復制代碼


3、按鍵程序
  1. /*****外部中斷1服務程序*****/
  2. void int1(void) interrupt 2
  3. {
  4.         EX1=0;      //關外部中斷1
  5.         if(ADD==0&&set_st==1)
  6.         {
  7.                 BEEP=0;
  8.                 Delay(2000);
  9.                 BEEP=1;
  10.                 do
  11.                 {
  12.                         Disp_alarm(shangxian);
  13.                 }
  14.                 while(ADD==0);
  15.                 if(H_ZF==0)
  16.                 {
  17.                         shangxian++;
  18.                         if(shangxian>=125)shangxian=125;
  19.                 }
  20.                 else if(H_ZF==1)
  21.                 {
  22.                         shangxian--;
  23.                         if(shangxian<=0)
  24.                         {
  25.                                 shangxian=0;
  26.                                 H_ZF=0;
  27.                         }
  28.                 }
  29.         }                        
  30.         else if(ADD==0&&set_st==2)
  31.         {
  32.                 BEEP=0;
  33.                 Delay(2000);
  34.                 BEEP=1;
  35.                 do
  36.                 {
  37.                         Disp_alarm(xiaxian);
  38.                 }
  39.                 while(ADD==0);
  40.                 if(L_ZF==0)
  41.                 {
  42.                         xiaxian++;
  43.                         if(xiaxian>=shangxian-1)
  44.                                 xiaxian=shangxian-1;        
  45.                 }
  46.                 else if(H_ZF==0&&L_ZF==1)
  47.                 {
  48.                         xiaxian--;
  49.                         if(xiaxian<=0)
  50.                         {
  51.                                 if(shangxian==0)
  52.                                 {
  53.                                         xiaxian=1;
  54.                                         L_ZF=1;
  55.                                 }
  56.                                 else
  57.                                 {
  58.                                         xiaxian=0;
  59.                                         L_ZF=0;
  60.                                 }
  61.                         }
  62.                 }
  63.                 else if(H_ZF==1&&L_ZF==1)
  64.                 {
  65.                         xiaxian--;
  66.                         if(xiaxian<=shangxian+1)
  67.                                 xiaxian=shangxian+1;
  68.                 }
  69.         }  
  70. }
復制代碼


4、核心算法程序
  1. /*****初始化DS18B20*****/
  2. void Init_DS18B20(void)
  3. {
  4.   unsigned char x=0;
  5.   DQ = 1;         //DQ復位
  6.   Delay_DS18B20(8);    //稍做延時
  7.   DQ = 0;         //單片機將DQ拉低
  8.   Delay_DS18B20(80);   //精確延時,大于480us
  9.   DQ = 1;         //拉高總線
  10.   Delay_DS18B20(34);
  11. }
  12. /*****讀一個字節(jié)*****/
  13. unsigned char ReadOneChar(void)
  14. {
  15.   unsigned char i=0;
  16.   unsigned char dat = 0;
  17.   for (i=8;i>0;i--)
  18.   {
  19.     DQ = 0;     // 給脈沖信號
  20.     dat>>=1;
  21.     DQ = 1;     // 給脈沖信號
  22.     if(DQ)
  23.     dat|=0x80;
  24.     Delay_DS18B20(4);
  25.   }
  26.   return(dat);
  27. }
  28. /*****寫一個字節(jié)*****/
  29. void WriteOneChar(unsigned char dat)
  30. {
  31.   unsigned char i=0;
  32.   for (i=8; i>0; i--)
  33.   {
  34.     DQ = 0;
  35.     DQ = dat&0x01;
  36.     Delay_DS18B20(5);
  37.     DQ = 1;
  38.     dat>>=1;
  39.   }
  40. }
  41. /*****讀取溫度*****/
  42. unsigned int ReadTemperature(void)
  43. {
  44.   unsigned char a=0;
  45.   unsigned char b=0;
  46.   unsigned int t=0;
  47.   float tt=0;
  48.   Init_DS18B20();
  49.   WriteOneChar(0xCC);  //跳過讀序號列號的操作
  50.   WriteOneChar(0x44);  //啟動溫度轉(zhuǎn)換
  51.   Init_DS18B20();
  52.   WriteOneChar(0xCC);  //跳過讀序號列號的操作
  53.   WriteOneChar(0xBE);  //讀取溫度寄存器
  54.   a=ReadOneChar();     //讀低8位
  55.   b=ReadOneChar();    //讀高8位
  56.   t=b;
  57.   t<<=8;
  58.   t=t|a;
  59.   if(t&0xf800)
  60.   {
  61.         t=~t+1;
  62.         fuhao=1;
  63.   }
  64.   else
  65.   fuhao=0;
  66.   tt=t*0.0625;
  67.   t= tt*10+0.5;     //放大10倍輸出并四舍五入
  68.   return(t);
  69. }
復制代碼


四、 proteus仿真設計
Proteus軟件是一款應用比較廣泛的工具,它可以在沒有硬件平臺的基礎上通過自身的軟件仿真出硬件平臺的運行情況,這樣就可以通過軟件仿真來驗證我們設計的方案有沒有問題,如果有問題,可以重新選擇器件,連接器件,直到達到我們設定的目的,避免我們搭建實物的時候,如果當初選擇的方案有問題,我們器件都已經(jīng)焊接好了,再去卸載下去,再去焊接新的方案的器件,測試,這樣會浪費人力和物力,也給開發(fā)者帶來一定困惑,Proteus仿真軟件就很好的解決這個問題,我們在設計之初,就使用該軟件進行模擬仿真,測試,選擇滿足我們設計的最優(yōu)方案。最后根據(jù)測試沒問題的仿真圖紙,焊接實物,調(diào)試,最終完成本設計的作品。


評分

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

查看全部評分

回復

使用道具 舉報

ID:226658 發(fā)表于 2023-11-16 09:46 | 顯示全部樓層
好東西值得擁有,樓主,提供源代碼下載嗎?
回復

使用道具 舉報

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

本版積分規(guī)則

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

Powered by 單片機教程網(wǎng)

快速回復 返回頂部 返回列表