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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

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

基于DS18B20的單片機溫度控制系統 帶加熱降溫模塊 仿真+代碼+原理圖

  [復制鏈接]
跳轉到指定樓層
樓主
仿真圖:


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

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

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

  145. /*****讀取溫度*****/
  146. void check_wendu(void)
  147. {
  148.         c=ReadTemperature()-5;                          //獲取溫度值并減去DS18B20的溫漂誤差
  149.         if(c>1200)
  150.         c=1200;
  151. }

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

  153. void write_1602com(uchar com)//****液晶寫入指令函數****
  154. {
  155.         RS=0;//數據/指令選擇置為指令
  156. //        rw=0; //讀寫選擇置為寫
  157.         LCD1602=com;//送入數據
  158.         delay(1);
  159.         EN=1;//拉高使能端,為制造有效的下降沿做準備
  160.         delay(1);
  161.         EN=0;//en由高變低,產生下降沿,液晶執行命令
  162. }


  163. void write_1602dat(uchar dat)//***液晶寫入數據函數****
  164. {
  165.         RS=1;//數據/指令選擇置為數據
  166. //        rw=0; //讀寫選擇置為寫
  167.         LCD1602=dat;//送入數據
  168.         delay(1);
  169.         EN=1; //en置高電平,為制造下降沿做準備
  170.         delay(1);
  171.         EN=0; //en由高變低,產生下降沿,液晶執行命令
  172. }


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

  180.         write_1602com(0x80);//日歷顯示固定符號從第一行第1個位置之后開始顯示
  181.         for(a=0;a<16;a++)
  182.         {
  183.                 write_1602dat(tab1[a]);//向液晶屏寫日歷顯示的固定符號部分
  184.                 delay(3);
  185.         }
  186.         write_1602com(0x80+0x40);//時間顯示固定符號寫入位置,從第2個位置后開始顯示
  187.         for(a=0;a<16;a++)
  188.         {
  189.                 write_1602dat(tab2[a]);//寫顯示時間固定符號,兩個冒號
  190.                 delay(3);
  191.         }

  192. }

  193. void display()
  194. {
  195.         if(Mode==0)
  196.         {
  197.                 write_1602com(0x80+8);
  198.                 write_1602dat(c/1000+0x30);
  199.                 write_1602dat((c%1000)/100+0x30);
  200.                 write_1602dat(((c%1000)%100)/10+0x30);
  201.                 write_1602com(0x80+12);
  202.                 write_1602dat(((c%1000)%100)%10+0x30);
  203.                 write_1602com(0x80+13);
  204.                 write_1602dat(0xdf);
  205.                 write_1602com(0x80+0x40+3);
  206.                 write_1602dat(TH/10+0x30);
  207.                 write_1602dat(TH%10+0x30);
  208.                 write_1602dat(0xdf);
  209.                 write_1602com(0x80+0x40+12);
  210.                 write_1602dat(TL/10+0x30);
  211.                 write_1602dat(TL%10+0x30);
  212.                 write_1602dat(0xdf);                       
  213.         }                                                                  
  214. }
  215. //=====================================================================================

  216. /*****初始化定時器0*****/
  217. void InitTimer(void)
  218. {            AUXR = 0x40;                //定時器1為1T模式
  219.         TMOD=0x1;
  220.         TH0=0x3c;
  221.         TL0=0xb0;     //50ms(晶振12M)
  222.         EA=1;      //全局中斷開關
  223.         TR0=1;
  224.         ET0=1;      //開啟定時器0
  225. }

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

  333. /*****報警子程序*****/
  334. void Alarm()
  335. {
  336.         if(x>=10){beep_st=~beep_st;x=0;}
  337.         if(Mode==0)
  338.         {
  339.                 if((c/10)>=TH)
  340.                 {
  341.                   ALAM=1;
  342.       Positive_Rotation();                       
  343.                         if(beep_st==1)
  344.                         BUZZ=0;
  345.                         else
  346.                         BUZZ=1;
  347.                 }
  348.                 else if((c/10)<TL)
  349.                 {
  350.                        
  351.                         Stop_Rotation();
  352.                         ALAM=0;
  353.                         if(beep_st==1)
  354.                         BUZZ=0;
  355.                         else
  356.                         BUZZ=1;
  357.                 }
  358.                 else
  359.                 {
  360. ……………………

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

所有資料51hei提供下載:
基于單片機的溫度控制系統.zip (705.13 KB, 下載次數: 375)

評分

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

查看全部評分

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

使用道具 舉報

沙發
ID:255559 發表于 2020-12-13 13:44 | 只看該作者
這個資料太好了,好好學習一下
回復

使用道具 舉報

板凳
ID:861646 發表于 2020-12-16 19:47 | 只看該作者
升溫用加熱絲,降溫用的是什么,圖有點糊,看不清
回復

使用道具 舉報

地板
ID:795717 發表于 2020-12-22 15:02 | 只看該作者
太乙t 發表于 2020-12-16 19:47
升溫用加熱絲,降溫用的是什么,圖有點糊,看不清

風扇
回復

使用道具 舉報

5#
ID:830831 發表于 2020-12-22 19:25 | 只看該作者
如何加入PID
回復

使用道具 舉報

6#
ID:893241 發表于 2021-5-19 21:39 | 只看該作者
這個可不可以加一個PID
回復

使用道具 舉報

7#
ID:932859 發表于 2021-6-6 20:20 | 只看該作者
兄弟有沒有pcb和原理圖啊
回復

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 免费在线观看av网站 | 99精品免费久久久久久久久日本 | 日韩精品免费视频 | 国产欧美一区二区久久性色99 | 久久国产精品视频 | 久久婷婷色 | 久夜精品 | 亚洲高清视频在线观看 | 中文视频在线 | 精品亚洲视频在线 | 免费观看毛片 | 91视频进入 | 国产精品高潮呻吟久久 | 国产精品久久国产精品 | 少妇一级淫片aaaaaaaaa | 超碰97人人人人人蜜桃 | 狠狠干美女 | 偷拍亚洲色图 | 亚洲国产成人在线视频 | 久色网| 一区视频 | 精品美女 | 成人免费观看视频 | 日韩成人精品 | 在线成人福利 | 福利社午夜影院 | 超碰精品在线观看 | 九九热在线免费观看 | 欧美精品中文字幕久久二区 | 国产一级片免费在线观看 | 六月成人网 | 精品国产不卡一区二区三区 | 精品久久电影 | 久久久精品一区二区三区 | 免费看黄色小视频 | 免费看av大片 | 日本精品裸体写真集在线观看 | www.日韩在线 | 国产一区二区在线免费观看 | 久久久久国色av免费观看性色 | 日韩一区二区在线视频 |