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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

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

單片機智能溫控器設計 帶proteus仿真 原理圖 源碼

[復制鏈接]
跳轉到指定樓層
樓主
單片機智能溫控的原理圖


單片機源碼:
  1. /************************************************************************
  2.            煙葉烘烤過程溫濕度報警系統

  3. 系統描述:在LCD1602上實時顯示時鐘,溫度,濕度,系統運行時間。利用ds18b20
  4.                   檢測當前溫度,通過和設定參數的比較,給ISD1420發出報警脈沖,通過
  5.           功率放大器LM386 驅動喇叭報警。




  6. *************************************************************************/

  7. #include<reg51.h>
  8. #include<intrins.h>
  9. #include <absacc.h>
  10. #define uchar unsigned char
  11. #define uint   unsigned int

  12. #define BUSY  0x80                               //lcd忙檢測標志
  13. #define DATAPORT P0                              //定義P0口為LCD通訊端口
  14. #define PLAYE_ADDR XBYTE[0XBFFF]                 //語音報警地址

  15. sbit RED_ALARM=P1^0;                                                    //紅色指示燈
  16. sbit WRITE_ALARM=P1^1;                                          //白色指示燈
  17. sbit GREEN_ALARM=P1^2;                                          //綠色指示燈
  18. sbit P1_4=P1^4;                                                    //時鐘調整
  19. sbit P1_5=P1^5;                                                 //時鐘加
  20. sbit P1_6=P1^6;                                                 //時鐘減

  21. sbit DQ = P1^7;                                                 //定義ds18b20通信端口
  22. sbit LCM_RS=P2^0;                                                                //數據/命令端
  23. sbit LCM_RW=P2^1;                                                                //讀/寫選擇端
  24. sbit LCM_EN=P2^2;                                               //LCD使能信號
  25. sbit ad_busy=P3^2;                                              //adc中斷方式接口
  26. sbit RECLED_EOC=P3^5;                                           //ISD1420放音結束查詢標志
  27. sbit OUT=P3^7;

  28. uchar ad_data;                                                  //ad采樣值存儲                                               
  29. uchar seconde=0;                                                //定義并初始化時鐘變量
  30. uchar minite=0;
  31. uchar hour=12;
  32. uchar mstcnt=0;
  33. uchar temp1,temp2,temp;                                     //溫度顯示變量
  34. uchar t,set;
  35. uchar T;
  36. bit ON_OFF;
  37. bit outflag;

  38. uchar code str0[]={"---  :  :  ---OF"};
  39. uchar code str1[]={"SET:  C SA:  . C"};

  40. void delay_LCM(uint);                                                                                                     //LCD延時子程序
  41. void initLCM( void);                                                                                                       //LCD初始化子程序
  42. void lcd_wait(void);                                                                                                      //LCD檢測忙子程序
  43. void WriteCommandLCM(uchar WCLCM,uchar BusyC);                              //寫指令到ICM子函數
  44. void WriteDataLCM(uchar WDLCM);                                             //寫數據到LCM子函數
  45. void DisplayOneChar(uchar X,uchar Y,uchar DData);                           //顯示指定坐標的一個字符子函數
  46. void DisplayListChar(uchar X,uchar Y,uchar code *DData);                    //顯示指定坐標的一串字符子函數
  47. void init_timer0(void);                                                                                               //定時器初始化
  48. void displayfun1(void);
  49. void displayfun2(void);
  50. void displayfun3(void);
  51. void displayfun4(void);
  52. void keyscan(void );                                                                                            //鍵盤掃描子程序
  53. void set_adj(void);
  54. void inc_key(void);
  55. void dec_key(void);
  56. void delay_18B20(unsigned int i);
  57. void Init_DS18B20(void) ;
  58. uchar ReadOneChar(void);
  59. void WriteOneChar(unsigned char dat);
  60. void ReadTemperature(void);
  61. void ad0809(void);
  62. void playalarm(void);


  63. /*********延時K*1ms,12.000mhz**********/

  64. void delay_LCM(uint k)
  65. {
  66.     uint i,j;
  67.     for(i=0;i<k;i++)
  68.     {
  69.         for(j=0;j<60;j++)
  70.                 {;}
  71.     }
  72. }   
  73. /**********寫指令到ICM子函數************/

  74. void WriteCommandLCM(uchar WCLCM,uchar BusyC)
  75. {
  76.     if(BusyC)lcd_wait();
  77.         DATAPORT=WCLCM;
  78.     LCM_RS=0;                   // 選中指令寄存器
  79.     LCM_RW=0;                       // 寫模式       
  80.     LCM_EN=1;   
  81.         _nop_();   
  82.         _nop_();
  83.         _nop_();
  84.     LCM_EN=0;  
  85. }

  86. /**********寫數據到LCM子函數************/

  87. void WriteDataLCM(uchar WDLCM)
  88. {
  89.     lcd_wait( );            //檢測忙信號   
  90.         DATAPORT=WDLCM;
  91.     LCM_RS=1;               // 選中數據寄存器
  92.     LCM_RW=0;                   // 寫模式
  93.     LCM_EN=1;
  94.     _nop_();
  95.         _nop_();
  96.         _nop_();
  97.     LCM_EN=0;
  98. }

  99. /***********lcm內部等待函數*************/

  100. void lcd_wait(void)
  101. {
  102.     DATAPORT=0xff;             
  103.         LCM_EN=1;
  104.     LCM_RS=0;                          
  105.     LCM_RW=1;                          
  106.     _nop_();
  107.     while(DATAPORT&BUSY)
  108.         {  LCM_EN=0;
  109.            _nop_();
  110.            _nop_();
  111.            LCM_EN=1;
  112.            _nop_();
  113.            _nop_();
  114.            }
  115.            LCM_EN=0;
  116.        
  117. }

  118. /**********LCM初始化子函數***********/

  119. void initLCM( )
  120. {   
  121.         DATAPORT=0;       
  122.         delay_LCM(15);
  123.         WriteCommandLCM(0x38,0);    //三次顯示模式設置,不檢測忙信號
  124.     delay_LCM(5);
  125.     WriteCommandLCM(0x38,0);
  126.     delay_LCM(5);
  127.     WriteCommandLCM(0x38,0);
  128.     delay_LCM(5);

  129.     WriteCommandLCM(0x38,1);    //8bit數據傳送,2行顯示,5*7字型,檢測忙信號
  130.     WriteCommandLCM(0x08,1);    //關閉顯示,檢測忙信號
  131.     WriteCommandLCM(0x01,1);    //清屏,檢測忙信號
  132.     WriteCommandLCM(0x06,1);    //顯示光標右移設置,檢測忙信號
  133.     WriteCommandLCM(0x0c,1);    //顯示屏打開,光標不顯示,不閃爍,檢測忙信號
  134. }

  135. /****************顯示指定坐標的一個字符子函數*************/

  136. void DisplayOneChar(uchar X,uchar Y,uchar DData)
  137. {
  138.     Y&=1;
  139.     X&=15;
  140.     if(Y)X|=0x40;               //若y為1(顯示第二行),地址碼+0X40
  141.     X|=0x80;                    //指令碼為地址碼+0X80
  142.     WriteCommandLCM(X,0);
  143.     WriteDataLCM(DData);
  144. }

  145. /***********顯示指定坐標的一串字符子函數***********/

  146. void DisplayListChar(uchar X,uchar Y,uchar code *DData)
  147. {
  148.     uchar ListLength=0;
  149.     Y&=0x01;
  150.     X&=0x0f;
  151.     while(X<16)
  152.     {
  153.         DisplayOneChar(X,Y,DData[ListLength]);
  154.         ListLength++;
  155.         X++;
  156.     }
  157. }

  158. /***********ds18b20延遲子函數(晶振12MHz )*******/

  159. void delay_18B20(unsigned int i)
  160. {
  161.         while(i--);
  162. }

  163. /**********ds18b20初始化函數**********************/

  164. void Init_DS18B20(void)
  165. {
  166.          unsigned char x=0;
  167.          DQ = 1;          //DQ復位
  168.          delay_18B20(8);  //稍做延時
  169.          DQ = 0;          //單片機將DQ拉低
  170.          delay_18B20(80); //精確延時 大于 480us
  171.          DQ = 1;          //拉高總線
  172.          delay_18B20(14);
  173.          x=DQ;            //稍做延時后 如果x=0則初始化成功 x=1則初始化失敗
  174.          delay_18B20(20);
  175. }

  176. /***********ds18b20讀一個字節**************/  

  177. unsigned char ReadOneChar(void)
  178. {
  179.         uchar i=0;
  180.         uchar dat = 0;
  181.         for (i=8;i>0;i--)
  182.          {
  183.                   DQ = 0; // 給脈沖信號
  184.                   dat>>=1;
  185.                   DQ = 1; // 給脈沖信號
  186.                   if(DQ)
  187.                   dat|=0x80;
  188.                   delay_18B20(4);
  189.          }
  190.         return(dat);
  191. }

  192. /*************ds18b20寫一個字節****************/  

  193. void WriteOneChar(uchar dat)
  194. {
  195.         unsigned char i=0;
  196.         for (i=8; i>0; i--)
  197.         {
  198.                   DQ = 0;
  199.                 DQ = dat&0x01;
  200.             delay_18B20(5);
  201.                 DQ = 1;
  202.             dat>>=1;
  203. }
  204. }

  205. /**************讀取ds18b20當前溫度************/

  206. void ReadTemperature(void)
  207. {
  208.         unsigned char a=0;
  209.         unsigned char b=0;
  210.         unsigned char t=0;

  211.         Init_DS18B20();
  212.         WriteOneChar(0xCC);            // 跳過讀序號列號的操作
  213.         WriteOneChar(0x44);         // 啟動溫度轉換

  214.         delay_18B20(100);       // this message is wery important

  215.         Init_DS18B20();
  216.         WriteOneChar(0xCC);         //跳過讀序號列號的操作
  217.         WriteOneChar(0xBE);         //讀取溫度寄存器等(共可讀9個寄存器) 前兩個就是溫度

  218.         delay_18B20(100);

  219.         a=ReadOneChar();            //讀取溫度值低位
  220.         b=ReadOneChar();                   //讀取溫度值高位
  221.         temp1=b<<4;
  222.         temp1+=(a&0xf0)>>4;
  223.         temp2=a&0x0f;

  224.     temp=((b*256+a)>>4);    //當前采集溫度值除16得實際溫度值


  225. }

  226. /***************液晶顯示子函數1正常顯示*****************/

  227. void displayfun1(void)
  228. {       
  229.         WriteCommandLCM(0x0c,1);                                            //顯示屏打開,光標不顯示,不閃爍,檢測忙信號       
  230.         DisplayListChar(0,0,str0);       
  231.         DisplayListChar(0,1,str1);       
  232.                                                                                                       
  233.         DisplayOneChar(3,0,hour/10+0x30);                    //液晶上顯示小時
  234.         DisplayOneChar(4,0,hour%10+0x30);

  235.         DisplayOneChar(6,0,minite/10+0x30);                        //液晶上顯示分
  236.         DisplayOneChar(7,0,minite%10+0x30);
  237.        
  238.         DisplayOneChar(9,0,seconde/10+0x30);            //液晶上顯示秒
  239.         DisplayOneChar(10,0,seconde%10+0x30);

  240.         DisplayOneChar(4,1,T/10+0x30);                            //液晶上顯示設定的溫度
  241.         DisplayOneChar(5,1,T%10+0x30);

  242.            DisplayOneChar(11,1,temp1/10+0x30);         //液晶上顯示測得的溫度  
  243.         DisplayOneChar(12,1,temp1%10+0x30);
  244.         DisplayOneChar(14,1,temp2/10+0x30);

  245.         if(ON_OFF==0)                                                      //若溫控標志為0
  246.         {
  247.                 DisplayOneChar(14,0,0x4f);                           // 液晶上顯示不控溫的標志
  248.                 DisplayOneChar(15,0,0x46);
  249.         }
  250.         else
  251.         {
  252.                 DisplayOneChar(14,0,0x4f);                           // 液晶上顯示控溫的標志
  253.                 DisplayOneChar(15,0,0x4e);
  254.                 if(outflag==1)
  255.                     DisplayOneChar(0,0,0x7c);                          
  256.             else
  257.                         DisplayOneChar(0,0,0xef);
  258.         }

  259.        
  260. }
  261. /************液晶顯示子函數2***************/

  262. void displayfun2(void)
  263. {
  264.         WriteCommandLCM(0x0c,1);                     //顯示屏打開,光標不顯示,不閃爍,檢測忙信號       
  265.         DisplayListChar(0,0,str0);       
  266.         DisplayListChar(0,1,str1);       
  267.                
  268.         DisplayOneChar(6,0,minite/10+0x30);
  269.         DisplayOneChar(7,0,minite%10+0x30);
  270.        
  271.         DisplayOneChar(9,0,seconde/10+0x30);
  272.         DisplayOneChar(10,0,seconde%10+0x30);

  273.         DisplayOneChar(4,1,T/10+0x30);                          
  274.         DisplayOneChar(5,1,T%10+0x30);

  275.            DisplayOneChar(11,1,temp1/10+0x30);         
  276.         DisplayOneChar(12,1,temp1%10+0x30);
  277.         DisplayOneChar(14,1,temp2/10+0x30);

  278.            WriteCommandLCM(0x0f,1);                                            //顯示屏打開,光標顯示,閃爍,檢測忙信號       
  279.     DisplayOneChar(3,0,hour/10+0x30);
  280.         DisplayOneChar(4,0,hour%10+0x30);
  281. }

  282. /**************液晶顯示子函數3*****************/

  283. void displayfun3(void)
  284. {
  285.         WriteCommandLCM(0x0c,1);                                    //顯示屏打開,光標不顯示,不閃爍,檢測忙信號       
  286.         DisplayListChar(0,0,str0);       
  287.         DisplayListChar(0,1,str1);       
  288.        
  289.         DisplayOneChar(3,0,hour/10+0x30);
  290.         DisplayOneChar(4,0,hour%10+0x30);

  291.         DisplayOneChar(9,0,seconde/10+0x30);
  292.         DisplayOneChar(10,0,seconde%10+0x30);

  293.         DisplayOneChar(4,1,T/10+0x30);                          
  294.         DisplayOneChar(5,1,T%10+0x30);

  295.            DisplayOneChar(11,1,temp1/10+0x30);         
  296.         DisplayOneChar(12,1,temp1%10+0x30);
  297.         DisplayOneChar(14,1,temp2/10+0x30);

  298.    
  299.         WriteCommandLCM(0x0f,1);                                            //顯示屏打開,光標顯示,閃爍,檢測忙信號
  300.         DisplayOneChar(6,0,minite/10+0x30);
  301.         DisplayOneChar(7,0,minite%10+0x30);

  302. }

  303. /**************液晶顯示子函數4 *****************/

  304. void displayfun4(void)
  305. {
  306.         WriteCommandLCM(0x0c,1);                                    //顯示屏打開,光標不顯示,不閃爍,檢測忙信號       
  307.         DisplayListChar(0,0,str0);       
  308.         DisplayListChar(0,1,str1);       
  309.        
  310.         DisplayOneChar(3,0,hour/10+0x30);
  311.         DisplayOneChar(4,0,hour%10+0x30);

  312.         DisplayOneChar(6,0,minite/10+0x30);
  313.         DisplayOneChar(7,0,minite%10+0x30);

  314.         DisplayOneChar(9,0,seconde/10+0x30);
  315.         DisplayOneChar(10,0,seconde%10+0x30);

  316.        
  317.            DisplayOneChar(11,1,temp1/10+0x30);         
  318.         DisplayOneChar(12,1,temp1%10+0x30);
  319.         DisplayOneChar(14,1,temp2/10+0x30);

  320.    
  321.         WriteCommandLCM(0x0f,1);                                            //顯示屏打開,光標顯示,閃爍,檢測忙信號
  322.         DisplayOneChar(4,1,T/10+0x30);                          
  323.         DisplayOneChar(5,1,T%10+0x30);

  324. }

  325. /**************鍵盤掃描子函數******************/

  326. void keyscan(void)
  327. {
  328.         uchar xx;                                           //局部變量
  329.         P1=0xff;
  330.         if(P1!=0xff)
  331.           {
  332.             delay_LCM(30);
  333.                 if(P1!=0xff)
  334.                   {       
  335.                         xx=P1;
  336.                         switch(xx)                                                       // 根據按鍵狀態,調用不同的子函數
  337.                         {
  338.                                 case 0xfe:set_adj();       break;               
  339.                                 case 0xfd:inc_key();       break;               
  340.                                 case 0xfb:dec_key();       break;               
  341.                                 case 0xf7:ON_OFF=!ON_OFF;  break;
  342.                                 default:break;
  343.                         }
  344.                   }
  345.                
  346.           }
  347.   
  348. }

  349. /**************設定工作模式子函數****************/

  350. void set_adj(void)
  351. {
  352.         delay_LCM(100);
  353.         set++;
  354.     if(set>=4)set=0;
  355.                
  356. }

  357. /****************按鍵加法子函數******************/

  358. void inc_key(void)
  359. {
  360.         delay_LCM(100);
  361.                
  362.         switch(set)
  363.         {
  364.                 case 0:if(P2==0xf7)ON_OFF=!ON_OFF;       break;
  365.                 case 1:hour++;   if(hour>=23)hour=23;    break;
  366.                 case 2:minite++; if(minite>=59)minite=59;break;
  367.                 case 3:T++;if(T>=99)T=99;                                 break;
  368.                 default:break;
  369.         }
  370.                
  371. }

  372. /****************按鍵減法子函數*****************/

  373. void dec_key(void)
  374. {
  375.         delay_LCM(100);
  376.        
  377.         switch(set)
  378.         {
  379.                    case 0:if(P2==0xf7)ON_OFF=!ON_OFF;    break;
  380.                 case 1:hour--;  if(hour<=0)hour=0;    break;
  381.                 case 2:minite--;if(minite<=0)minite=0;break;
  382.                 case 3:T--;if(T<=1)T=1;                                  break;
  383.                 default:break;
  384.         }
  385.                
  386. }

  387. /***************定時器t0初始化*******************/

  388. void init_timer0(void)
  389. {
  390.          TMOD=0x01;                                  //time0為定時器,方式1
  391.      TH0=0x3c;                                   //預置計數初值
  392.      TL0=0xb0;
  393.      EA=1;                                                                  
  394.      ET0=1;                                                                                                 
  395.      TR0=1;                         
  396. }

  397. /***********定時器t0中斷子函數**************/

  398. void timer0(void) interrupt 1 using 0          //定時器0方式1,50ms中斷一次
  399. {
  400.      TH0=0x3c;
  401.      TL0=0xb0;
  402.      mstcnt++;
  403.      if(mstcnt>=20 )  {seconde++; mstcnt=0; }
  404.          if(seconde>=60)  {minite++;  seconde=0;}
  405.          if(minite>=60 )  {hour++;    minite=0; }
  406.          if(hour>=24   )  {hour=0;}
  407.          keyscan( );                               //按鍵掃描
  408. }

  409. /*****************系統報警子函數***************************/
  410. /*查詢ISD1420_RECLED管腳的放音結束標志EOC,瞬間的低電平*/
  411. /*調試時基本正確,但是,會發生突發的不穩定的報警*/
  412. /**********************************************************/

  413. void playalarm(void)                        //語音提示溫度上升過快
  414. {
  415.        
  416.     if(temp>25&&temp<30)              
  417.         {   
  418.        delay_LCM(10);
  419.        if(temp>20&&temp<22)
  420.         {
  421.                         RED_ALARM=0;
  422.                         PLAYE_ADDR=0x11;
  423.                         _nop_();
  424.                          _nop_();
  425.                         PLAYE_ADDR=0x10;
  426.                         while(RECLED_EOC==1);            //等待放音結束
  427.                         RED_ALARM=1;
  428.                 }
  429.         }
  430.        
  431.         if(temp>30&&temp<35)                    //語音提示溫度上升過慢
  432.         {
  433.                 delay_LCM(10);
  434.         if(temp>22&&temp<25)
  435.                 {
  436.                         GREEN_ALARM=0;
  437.                         PLAYE_ADDR=0x21;
  438.                          _nop_();
  439.                         _nop_();
  440.                         PLAYE_ADDR=0x20;
  441.                        while(RECLED_EOC==1);
  442.                         GREEN_ALARM=1;
  443.                 }
  444.         }
  445.        
  446.         if(temp>35&&temp<40)                   //語音提示恒溫控制
  447.         {
  448.                 delay_LCM(10);
  449.                 if(temp>25&&temp<30)
  450.                 {
  451.                         WRITE_ALARM=0;
  452.                         PLAYE_ADDR=0x31;
  453.                         _nop_();
  454.                         _nop_();
  455.                         PLAYE_ADDR=0x30;
  456.                         while(RECLED_EOC==1);
  457.                         WRITE_ALARM=1;
  458.                 }
  459.         }   
  460. }

  461. /***********the main funtion*************/
  462.    
  463. void main(void)
  464. {
  465.         ad_data=0;                                                                          //采樣值存儲單元初始化為0
  466.     P1=0xff;                                                                   //初始化p1口,全設為1      
  467.         delay_LCM(500);                                                //延時500ms啟動
  468.         initLCM( );                                                               //LCD初始化
  469.         init_timer0( );                                                                   //時鐘定時器0初始化       
  470.     Init_DS18B20( ) ;                                                          //DS18B20初始化
  471.         DisplayListChar(0,0,str0);       
  472.         DisplayListChar(0,1,str1);  
  473.                             
  474.     while (1)
  475.     {   
  476.                keyscan();                                            //按鍵掃描
  477.             ReadTemperature();                                    //溫度采集
  478.                 playalarm();
  479.         switch(set)                                           //LCD根據工作模式顯示
  480.                 {
  481.                         case 0:displayfun1();delay_LCM(1000);break;       //正常工作顯示
  482.                         case 1:displayfun2();delay_LCM(1000);break;       //調整時顯示
  483.                         case 2:displayfun3();delay_LCM(1000);break;       //調整分顯示
  484.                         case 3:displayfun4();delay_LCM(1000);break;
  485.                         default:break;
  486.                 }        
  487.                 keyscan( );                                              //相當于延時
  488.                 if(ON_OFF==1)                                                                          //若溫控標志位1, 控制LAMP動作
  489.                 {
  490.                         if(temp1>=T+1){outflag=1;OUT=0;}
  491.                         if(temp1<T)
  492.                         {
  493.                                 delay_LCM(1000);
  494.                                 if(temp1<T){outflag=0;OUT=1;}
  495.                         }
  496.                 }
  497.                 else{outflag=0;OUT=1;}
  498.     }
  499.        
  500. }


復制代碼


完整資料下載:
智能溫控器.rar (132.56 KB, 下載次數: 38)
分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏2 分享淘帖 頂1 踩
回復

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 一区二区三区四区av | 亚洲一区导航 | 国产一区免费 | 国产精品欧美一区二区三区 | 国产精品片aa在线观看 | 亚洲精品在线91 | 成人精品国产免费网站 | 亚洲精品在线看 | 国产成人短视频在线观看 | 亚洲高清成人在线 | 红色av社区 | 欧美一区二区免费 | 精品91久久 | 另类专区成人 | 免费看国产精品视频 | 精品乱子伦一区二区三区 | 午夜视频在线观看一区二区 | 中文字幕国产精品视频 | 在线看免费的a | 华丽的挑战在线观看 | 99久久亚洲 | 日日爱av| 九九爱这里只有精品 | 成人午夜视频在线观看 | 欧美国产亚洲一区二区 | 国产视频精品视频 | 国产精品a免费一区久久电影 | 韩国精品一区 | 日韩精品一区二区三区久久 | 91婷婷韩国欧美一区二区 | 午夜男人免费视频 | 亚洲性在线 | 成人黄在线观看 | 精品久久免费 | 亚洲精品中文字幕在线观看 | 国产九九九 | 久久精品97| 久久99网 | 中文字幕国产一区 | 超碰av在线 | 午夜在线免费观看视频 |