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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 5909|回復: 4
收起左側

單片機溫度控制報警系統程序 當溫度高于25度,繼電器加熱,低于25度,電機正轉

  [復制鏈接]
ID:447331 發表于 2019-12-24 17:33 | 顯示全部樓層 |閱讀模式
設計要求:
利用DS18B20采集溫度,12864顯示,蜂鳴器報警,鍵盤調節控制范圍和設置時間,當溫度高于25度,繼電器加熱,低于25度,電機正轉。

1、利用DS18B20采集溫度
2、12864顯示,蜂鳴器報警
3、鍵盤調節控制范圍和設置時間
4、當溫度高于25度,繼電器加熱;低于25度,電機正轉

2.方案設計
2.1硬件設計說明
本設計由三個模塊構成:AT89C51單片機主控模塊、LCD12864顯示屏模塊、BS18B20溫度傳感器模塊。
AT89C51單片機主控模塊:采用AT89C51單片機作為整個硬件系統的核心,它既是協調整機工作的控制器,又是數據處理器。
LCD12864顯示屏模塊:在微控制器應用系統中,如果需要顯示的內容有漢字,則使用LCD12864是一種較好的選擇。LCD顯示屏顯示清晰,配置靈活,與微控制器的接口簡單易行。
BS18B20溫濕度傳感器模塊:傳感器模塊監測溫度,產生的數字信號,直接交給的AT89C51主控芯片系統模塊處理,判斷。
2.2軟件設計說明
軟件加載后首先進入初始化狀態,包括對主控單片機,LCD12864顯示屏,BS18B20溫度傳感器模塊等的初始化,初始化完成后,建立界面,顯示實時溫度。一切就緒后,進入循環中,不斷循環接收顯示溫度傳感器檢測到的實時溫度。
溫度獲取:變量初始化后,讀取BS18B20溫度傳感器,接收BS18B20溫度傳感器檢測到的溫度,實時顯示到LCD12864顯示屏上。  
設置溫度上下限:通過按鍵調節溫度上下限,顯示到LCD顯示屏上。

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

單片機源程序如下:
  1. #include <reg51.h>
  2. #define uint unsigned int
  3. #define uchar unsigned char           //宏定義
  4. #define LCD1602 P0
  5. sbit SET=P3^1;                            //定義調整鍵
  6. sbit DEC=P3^2;                            //定義減少鍵
  7. sbit ADD=P3^3;                            //定義增加鍵
  8. sbit BUZZ=P3^6;                            //定義蜂鳴器
  9. sbit ALAM=P1^2;                                //定義燈光報警
  10. sbit ALAM1=P1^4;
  11. sbit DQ=P3^7;                             //定義DS18B20總線I/O       
  12. sbit RS = P2^7;
  13. sbit EN = P2^6;
  14. bit shanshuo_st;                            //閃爍間隔標志
  15. bit beep_st;                                     //蜂鳴器間隔標志
  16. uchar x=0;                                      //計數器
  17. //motor
  18. sbit IN1 = P1^3;
  19. sbit IN2 = P1^4;
  20. sbit PWM = P1^5;
  21. uint t = 46082;

  22. uchar code tab1[]={"Now Tem:   .  C "};
  23. uchar code tab2[]={"TH:   C  TL:   C"};
  24. uint c;
  25. uchar Mode=0;                             //狀態標志
  26. signed char TH=25;                  //上限報警溫度,默認值為25
  27. signed char TL=25;                   //下限報警溫度,默認值為25
  28. //============================================================================================
  29. //====================================DS18B20=================================================
  30. //============================================================================================

  31. void delay_ms(uchar t)
  32. {
  33.         uchar x,y;
  34.         for(x = t;x > 0;x--)
  35.                 for(y = 110;y > 0;y--);
  36. }
  37. void Timer0_Init()
  38. {
  39.         TMOD = 0X01;
  40.         TH0 = (65536 - 46082)/256;
  41.         TL0 = (65536 - 46082)%256;
  42.         EA = 1 ;
  43.         ET0 = 1;
  44.         TR0 = 1;
  45. }
  46. void Positive_Rotation()
  47. {
  48.         IN1 = 0;
  49.         IN2 = 1;
  50. }
  51. void Reverse_Rotation()
  52. {
  53.         IN1 = 1;
  54.         IN2 = 0;
  55. }
  56. void Stop_Rotation()
  57. {
  58.         IN1 = 1;
  59.         IN2 = 1;
  60. }
  61. /*****延時子程序*****/
  62. void Delay_DS18B20(int num)
  63. {
  64.   while(num--) ;
  65. }
  66. void delay(uint xms)//延時函數,有參函數
  67. {
  68.         uint x,y;
  69.         for(x=xms;x>0;x--)
  70.          for(y=110;y>0;y--);
  71. }
  72. /*****初始化DS18B20*****/
  73. void Init_DS18B20(void)
  74. {
  75.   unsigned char x=0;
  76.   DQ = 1;         //DQ復位
  77.   Delay_DS18B20(8);    //稍做延時
  78.   DQ = 0;         //單片機將DQ拉低
  79.   Delay_DS18B20(80);   //精確延時,大于480us
  80.   DQ = 1;         //拉高總線
  81.   Delay_DS18B20(14);
  82.   x = DQ;           //稍做延時后,如果x=0則初始化成功,x=1則初始化失敗
  83.   Delay_DS18B20(20);
  84. }
  85. /*****讀一個字節*****/
  86. unsigned char ReadOneChar(void)
  87. {
  88.   unsigned char i=0;
  89.   unsigned char dat = 0;
  90.   for (i=8;i>0;i--)
  91.   {
  92.     DQ = 0;     // 給脈沖信號
  93.     dat>>=1;
  94.     DQ = 1;     // 給脈沖信號
  95.     if(DQ)
  96.     dat|=0x80;
  97.     Delay_DS18B20(4);
  98.   }
  99.   return(dat);
  100. }
  101. /*****寫一個字節*****/
  102. void WriteOneChar(unsigned char dat)
  103. {
  104.   unsigned char i=0;
  105.   for (i=8; i>0; i--)
  106.   {
  107.     DQ = 0;
  108.     DQ = dat&0x01;
  109.     Delay_DS18B20(5);
  110.     DQ = 1;
  111.     dat>>=1;
  112.   }
  113. }
  114. /*****讀取溫度*****/
  115. unsigned int ReadTemperature(void)
  116. {
  117.   unsigned char a=0;
  118.   unsigned char b=0;
  119.   unsigned int t=0;
  120.   float tt=0;
  121.   Init_DS18B20();
  122.   WriteOneChar(0xCC);  //跳過讀序號列號的操作
  123.   WriteOneChar(0x44);  //啟動溫度轉換
  124.   Init_DS18B20();
  125.   WriteOneChar(0xCC);  //跳過讀序號列號的操作
  126.   WriteOneChar(0xBE);  //讀取溫度寄存器
  127.   a=ReadOneChar();     //讀低8位
  128.   b=ReadOneChar();    //讀高8位
  129.   t=b;
  130.   t<<=8;
  131.   t=t|a;
  132.   tt=t*0.0625;
  133. // t= tt*10+0.5;     //放大10倍輸出并四舍五入
  134.   t= tt*10+0.5;
  135.   return(t);
  136. }

  137. /*****讀取溫度*****/
  138. void check_wendu(void)
  139. {
  140.         c=ReadTemperature()-5;                          //獲取溫度值并減去DS18B20的溫漂誤差
  141.         if(c>1200)
  142.         c=1200;
  143. }

  144. /********液晶寫入指令函數與寫入數據函數,以后可調用**************/

  145. void write_1602com(uchar com)//****液晶寫入指令函數****
  146. {
  147.         RS=0;//數據/指令選擇置為指令
  148. //        rw=0; //讀寫選擇置為寫
  149.         LCD1602=com;//送入數據
  150.         delay(1);
  151.         EN=1;//拉高使能端,為制造有效的下降沿做準備
  152.         delay(1);
  153.         EN=0;//en由高變低,產生下降沿,液晶執行命令
  154. }


  155. void write_1602dat(uchar dat)//***液晶寫入數據函數****
  156. {
  157.         RS=1;//數據/指令選擇置為數據
  158. //        rw=0; //讀寫選擇置為寫
  159.         LCD1602=dat;//送入數據
  160.         delay(1);
  161.         EN=1; //en置高電平,為制造下降沿做準備
  162.         delay(1);
  163.         EN=0; //en由高變低,產生下降沿,液晶執行命令
  164. }


  165. void lcd_init()//***液晶初始化函數****
  166. {
  167.         uchar a;
  168.         write_1602com(0x38);//設置液晶工作模式,意思:16*2行顯示,5*7點陣,8位數據
  169.         write_1602com(0x0c);//開顯示不顯示光標
  170.         write_1602com(0x06);//整屏不移動,光標自動右移
  171.         write_1602com(0x01);//清顯示

  172.         write_1602com(0x80);//日歷顯示固定符號從第一行第1個位置之后開始顯示
  173.         for(a=0;a<16;a++)
  174.         {
  175.                 write_1602dat(tab1[a]);//向液晶屏寫日歷顯示的固定符號部分
  176.                 delay(3);
  177.         }
  178.         write_1602com(0x80+0x40);//時間顯示固定符號寫入位置,從第2個位置后開始顯示
  179.         for(a=0;a<16;a++)
  180.         {
  181.                 write_1602dat(tab2[a]);//寫顯示時間固定符號,兩個冒號
  182.                 delay(3);
  183.         }

  184. }

  185. void display()
  186. {
  187.         if(Mode==0)
  188.         {
  189.                 write_1602com(0x80+8);
  190.                 write_1602dat(c/1000+0x30);
  191.                 write_1602dat((c%1000)/100+0x30);
  192.                 write_1602dat(((c%1000)%100)/10+0x30);
  193.                 write_1602com(0x80+12);
  194.                 write_1602dat(((c%1000)%100)%10+0x30);
  195.                 write_1602com(0x80+13);
  196.                 write_1602dat(0xdf);
  197.                 write_1602com(0x80+0x40+3);
  198.                 write_1602dat(TH/10+0x30);
  199.                 write_1602dat(TH%10+0x30);
  200.                 write_1602dat(0xdf);
  201.                 write_1602com(0x80+0x40+12);
  202.                 write_1602dat(TL/10+0x30);
  203.                 write_1602dat(TL%10+0x30);
  204.                 write_1602dat(0xdf);                       
  205.         }                                                                  
  206. }
  207. //=====================================================================================

  208. /*****初始化定時器0*****/
  209. void InitTimer(void)
  210. {
  211.         TMOD=0x1;
  212.         TH0=0x3c;
  213.         TL0=0xb0;     //50ms(晶振12M)
  214.         EA=1;      //全局中斷開關
  215.         TR0=1;
  216.         ET0=1;      //開啟定時器0
  217. }

  218. void KEY()
  219. {
  220.                         //功能鍵
  221.         if(SET==0)
  222.         {
  223.                 BUZZ=0;
  224.                 delay(10);
  225.                 if(SET==0)
  226.                 {
  227.                         Mode++;
  228.                         if(Mode==3)
  229.                         Mode=0;
  230.                         BUZZ=1;
  231.                 }
  232.                 while(SET==0)
  233.                 {
  234.                         if(Mode==0)
  235.                                 {
  236.                                 //        write_1602com(0x80+0x40+6);
  237.                                         write_1602com(0x0c);
  238.                                 }       
  239.                         else if(Mode==1)
  240.                                 {
  241.                                         write_1602com(0x80+0x40+4);
  242.                                         write_1602com(0x0f);
  243.                                 }       
  244.                         else
  245.                                 {
  246.                                         write_1602com(0x80+0x40+13);
  247.                                         write_1602com(0x0f);
  248.                                 }                                                       
  249.                 }
  250.         }
  251.         //增加
  252.         if(ADD==0&&Mode==1)
  253.         {
  254.                 BUZZ=0;
  255.                 delay(10);
  256.                 if(ADD==0)       
  257.                 {
  258.                         TH++;
  259.                         if(TH>=99)       
  260.                         TH=99;
  261.                         write_1602com(0x80+0x40+3);
  262.                         write_1602dat(TH/10+0x30);
  263.                         write_1602dat(TH%10+0x30);
  264.                         write_1602com(0x80+0x40+4);       
  265.                         BUZZ=1;
  266.                 }
  267.                 while(ADD==0);
  268.                
  269.         }
  270.         //減少
  271.         if(DEC==0&&Mode==1)
  272.         {
  273.                 BUZZ=0;
  274.                 delay(10);
  275.                 if(DEC==0)
  276.                 {
  277.                         TH--;
  278.                         if(TH==TL)       
  279.                         TH=TL+1;
  280.                         write_1602com(0x80+0x40+3);
  281.                         write_1602dat(TH/10+0x30);
  282.                         write_1602dat(TH%10+0x30);
  283.                         write_1602com(0x80+0x40+4);       
  284.                         BUZZ=1;
  285.                 }
  286.                 while(DEC==0);
  287.         }
  288.         if(ADD==0&&Mode==2)
  289.         {
  290.                 BUZZ=0;
  291.                 delay(10);
  292.                 if(ADD==0)       
  293.                 {
  294.                         TL++;
  295.                         if(TL==TH)       
  296.                         TL=TH-1;
  297.                         write_1602com(0x80+0x40+12);
  298.                         write_1602dat(TL/10+0x30);
  299.                         write_1602dat(TL%10+0x30);
  300.                         write_1602com(0x80+0x40+13);       
  301.                         BUZZ=1;
  302.                 }
  303.                 while(ADD==0);
  304.                
  305.         }
  306.         //減少
  307.         if(DEC==0&&Mode==2)
  308.         {
  309.                 BUZZ=0;
  310.                 delay(10);
  311.                 if(DEC==0)
  312.                 {
  313.                         TL--;
  314.                         if(TL<=0)       
  315.                         TL=0;
  316.                         write_1602com(0x80+0x40+12);
  317.                         write_1602dat(TL/10+0x30);
  318.                         write_1602dat(TL%10+0x30);
  319.                         write_1602com(0x80+0x40+13);       
  320.                         BUZZ=1;
  321.                 }
  322.                 while(DEC==0);               
  323.         }
  324. }

  325. /*****報警子程序*****/
  326. void Alarm()
  327. {
  328.         if(x>=10){beep_st=~beep_st;x=0;}
  329.         if(Mode==0)
  330.         {
  331.                 if((c/10)>=TH)
  332.                 {
  333.                     Stop_Rotation();
  334.                         ALAM=0;
  335.                         if(beep_st==1)
  336.                         BUZZ=0;
  337.                         else
  338.                         BUZZ=1;
  339.                 }
  340.                 else if((c/10)<TL)
  341.                 {
  342.                         ALAM=1;
  343.             Positive_Rotation();       
  344.                         if(beep_st==1)
  345.                         BUZZ=0;
  346.                         else
  347.                         BUZZ=1;
  348.                 }
  349.                 else
  350. ……………………

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

所有資料51hei提供下載:
Proteus溫度報警系統.zip (1.32 MB, 下載次數: 177)

評分

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

查看全部評分

回復

使用道具 舉報

ID:700463 發表于 2020-3-11 11:31 | 顯示全部樓層
你好,這dsn文件我好像打不開啊?不知道怎么回事
回復

使用道具 舉報

ID:753799 發表于 2020-5-18 22:48 | 顯示全部樓層
怎么把溫度設置為負數啊
回復

使用道具 舉報

ID:885831 發表于 2021-5-15 12:45 來自手機 | 顯示全部樓層
uchar Mode=0;  //狀態標志  求解
回復

使用道具 舉報

ID:517213 發表于 2021-5-26 11:36 | 顯示全部樓層
謝謝樓主提供的資料,學習中
回復

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 亚洲日本免费 | 亚洲精品久久久一区二区三区 | 午夜在线小视频 | 欧美 日韩 视频 | 国产成人精品网站 | 日韩在线免费 | 美女午夜影院 | 国产一区二区久久 | 国产精品久久久久无码av | 午夜羞羞 | 狠狠躁天天躁夜夜躁婷婷老牛影视 | 亚洲国产aⅴ成人精品无吗 亚洲精品久久久一区二区三区 | 在线欧美| 日日夜夜精品 | 狠狠色香婷婷久久亚洲精品 | 福利视频一区二区三区 | 免费精品 | 91色在线| 黄色激情毛片 | 精品美女久久久 | 亚洲激情专区 | 亚洲一区二区在线视频 | 国产精品久久久亚洲 | 欧美区在线 | 九七午夜剧场福利写真 | 国产成人精品在线 | 亚洲午夜精品一区二区三区 | 久久综合久色欧美综合狠狠 | 一本大道久久a久久精二百 欧洲一区二区三区 | 日韩伦理电影免费在线观看 | 九九久久99 | 国产精品视频一区二区三区不卡 | 久久久久国产 | 中文字幕一区二区三区日韩精品 | 欧美成年人视频在线观看 | 综合精品 | 精品欧美乱码久久久久久1区2区 | 三区四区在线观看 | 成人午夜| 国产99久久久久 | 婷婷免费视频 |