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

 找回密碼
 立即注冊(cè)

QQ登錄

只需一步,快速開始

搜索
查看: 4699|回復(fù): 3
打印 上一主題 下一主題
收起左側(cè)

單片機(jī)測(cè)溫測(cè)濕+調(diào)用風(fēng)扇降濕降溫+設(shè)置溫濕上下限+報(bào)警

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主

  1. #include<reg52.h>
  2. #include "intrins.h"
  3. typedef unsigned char uint8;
  4. typedef unsigned int uint16;
  5. sbit rs=P2^6;         // 數(shù)據(jù)命令選擇
  6. sbit rw=P2^5;         //讀寫選擇
  7. sbit e=P2^7;          //使能

  8. sbit k1=P3^1; //模式
  9. sbit k2=P3^0; //加
  10. sbit k3=P3^2; //減

  11. sbit DHT11_DQ_OUT=P2^0;//濕度
  12. sbit bee=P1^5;//蜂鳴器
  13. sbit IRIN=P3^2;

  14. sbit dq=P3^7;//溫度
  15. sbit dj=P1^0;//電機(jī)
  16. uint8 mode=0,xian;
  17. char temph=50,templ=20;//自己可以改
  18. char humih=80,humil=20;
  19. uint8 temp,humi;
  20. uint8 flag;          //設(shè)定報(bào)警標(biāo)志
  21. uint8 a,c,tempvalue;
  22. uint8 code num[10]="0123456789";

  23. uint8 code str1[]="Temp:";  //溫度
  24. uint8 code str2[]="Humi:";  //濕度
  25. uint8 code str3[]="Error";  
  26. uint8 code str4[]="Success    ";
  27. uint8 code str5[]="%RH";
  28. uint8 code str6[]="TempH:";          //設(shè)定溫度上限顯示
  29. uint8 code str7[]="TempL:";          //設(shè)定溫度下限顯示
  30. uint8 code str8[]="HumiH:";           //設(shè)定濕度上限顯示
  31. uint8 code str9[]="HumiL:";           //設(shè)定濕度下限顯示


  32. void delay(uint16 i)
  33. {
  34.         while(i--);
  35. }

  36. void delay_ms(uint16 i)
  37. {
  38.         while(i--)
  39.                 delay(90);
  40. }

  41. void wrc(uint8 c)         //寫命令
  42. {
  43.         delay(1000);
  44.         rs=0;
  45.         rw=0;
  46.         e=0;
  47.         P0=c;
  48.         e=1;
  49.         delay(10);
  50.         e=0;
  51. }
  52. void wrd(uint8 dat)          //寫數(shù)據(jù)
  53. {
  54.         delay(1000);
  55.         rs=1;
  56.         rw=0;
  57.         e=0;
  58.         P0=dat;
  59.         e=1;
  60.         delay(10);
  61.         e=0;
  62.         rs=0;
  63. }
  64. void lcd_init()           // LCD1602初始化
  65. {
  66.         delay(1000);
  67.         wrc(0x38);
  68.         wrc(0x38);         //功能設(shè)置命令,選擇8位總線,雙行顯示  5*7點(diǎn)陣字符
  69.         wrc(0x38);
  70.         wrc(0x06);        //光標(biāo)和顯示模式設(shè)置  光標(biāo)右移  整屏不移動(dòng)
  71.         wrc(0x0c);        //顯示開關(guān)控制  開顯示  無光標(biāo) 光標(biāo)不閃爍
  72.         wrc(0x01);        //清零指令  固定的
  73. }
  74. //復(fù)位DHT11
  75. void DHT11_Rst()           
  76. {                 
  77.     DHT11_DQ_OUT=0;         //拉低DQ
  78.     delay_ms(20);            //拉低至少18ms
  79.     DHT11_DQ_OUT=1;         //DQ=1
  80.         delay(3);             //主機(jī)拉高20~40us
  81. }

  82. //等待DHT11的回應(yīng)
  83. //返回1:未檢測(cè)到DHT11的存在
  84. //返回0:存在
  85. uint8 DHT11_Check()            
  86. {   
  87.         uint8 retry=0;         
  88.     while (DHT11_DQ_OUT&&retry<100)//DHT11會(huì)拉低40~50us
  89.         {
  90.                 retry++;
  91.                 _nop_();
  92.         };         
  93.         if(retry>=100)return 1;
  94.         else retry=0;
  95.     while (!DHT11_DQ_OUT&&retry<100)//DHT11拉低后會(huì)再次拉高40~50us
  96.         {
  97.                 retry++;
  98.                 _nop_();
  99.         };
  100.         if(retry>=100)return 1;            
  101.         return 0;
  102. }


  103. //DHT11初始化
  104. //返回0:初始化成功,1:失敗
  105. uint8 DHT11_Init()
  106. {
  107.         DHT11_Rst();         
  108.         return DHT11_Check();        
  109. }


  110. //從DHT11讀取一個(gè)位
  111. //返回值:1/0
  112. uint8 DHT11_Read_Bit(void)                          
  113. {
  114.          uint8 retry=0;
  115.         while(DHT11_DQ_OUT&&retry<100)//等待變?yōu)榈碗娖?12-14us 開始
  116.         {
  117.                 retry++;
  118.                 _nop_();
  119.         }
  120.         retry=0;
  121.         while((!DHT11_DQ_OUT)&&retry<100)//等待變高電平         26-28us表示0,116-118us表示1
  122.         {
  123.                 retry++;
  124.                 _nop_();
  125.         }
  126.         delay(1);//等待40us
  127.         if(DHT11_DQ_OUT)return 1;
  128.         else return 0;                  
  129. }

  130. //從DHT11讀取一個(gè)字節(jié)
  131. //返回值:讀到的數(shù)據(jù)
  132. uint8 DHT11_Read_Byte(void)   
  133. {        
  134.     uint8 i,dat=0;
  135.         for (i=0;i<8;i++)
  136.         {
  137.                    dat<<=1;
  138.             dat|=DHT11_Read_Bit();
  139.     }                                                   
  140.     return dat;
  141. }

  142. //從DHT11讀取一次數(shù)據(jù)
  143. //temp:溫度值(范圍:0~50°)
  144. //humi:濕度值(范圍:20%~90%)
  145. //返回值:0,正常;1,讀取失敗
  146. uint8 DHT11_Read_Data(uint8 *temp,uint8 *humi)   
  147. {        
  148.          uint8 buf[5];
  149.         uint8 i;
  150.         DHT11_Rst();
  151.         if(DHT11_Check()==0)
  152.         {
  153.                 for(i=0;i<5;i++)//讀取40位數(shù)據(jù)
  154.                 {
  155.                         buf[i]=DHT11_Read_Byte();
  156.                 }
  157.                 if((buf[0]+buf[1]+buf[2]+buf[3])==buf[4])
  158.                 {
  159.                         *humi=buf[0];
  160.                         *temp=buf[2];
  161.                 }
  162.                
  163.         }else return 1;
  164.         return 0;            
  165. }




  166. void ds18b20init()                //18b20的初始化
  167. {
  168.         dq=1;
  169.         delay(1);
  170.         dq=0;
  171.         delay(80);
  172.         dq=1;
  173.         delay(5);
  174.         dq=0;
  175.         delay(20);
  176.         dq=1;
  177.         delay(35);
  178. }
  179. void ds18b20wr(uint8 dat)          //18b20寫數(shù)據(jù)
  180. {
  181.         uint8 i;
  182.         for(i=0;i<8;i++)
  183.         {
  184.                 dq=0;
  185.                 dq=dat&0x01;
  186.                 dat>>=1;
  187.                 delay(8);//在時(shí)序上只有這一塊對(duì)時(shí)序要求最準(zhǔn)確,他的時(shí)間必須大于15us
  188.                 dq=1;
  189.                 delay(1);
  190.         }        
  191. }
  192. uint8 ds18b20rd()                  //18b20讀數(shù)據(jù)
  193. {
  194.         uint8 value,i;
  195.         for(i=0;i<8;i++)        
  196.         {
  197.                 dq=0;
  198.                 value>>=1;
  199.                 dq=1;
  200.                 if(dq==1)value|=0x80;
  201.                 delay(8);//在這一塊也對(duì)時(shí)間要求特別準(zhǔn)確,整段程序必須大于60us               
  202.         }
  203.         return value;
  204. }
  205. uint8 readtemp()                          //讀取溫度內(nèi)需要復(fù)位的
  206. {
  207.         uint8 b;
  208.         ds18b20init();                //初始化
  209.         ds18b20wr(0xcc);   //發(fā)送忽略ROM指令
  210.         ds18b20wr(0x44);   //發(fā)送溫度轉(zhuǎn)換指令
  211.         delay(100);
  212.         ds18b20init();           //初始化
  213.         ds18b20wr(0xcc);   //發(fā)送忽略ROM指令
  214.         ds18b20wr(0xbe);   //發(fā)讀暫存器指令
  215.         a=ds18b20rd();         //溫度的低八位
  216.         b=ds18b20rd();         //溫度的高八位
  217.         b<<=4;                         //ssss s***;s為標(biāo)志位s=0表示溫度值為正數(shù),s=1溫度值為負(fù)數(shù)
  218.         c=b&0x80;                //溫度正負(fù)標(biāo)志位確認(rèn)
  219.         b+=(a&0xf0)>>4;
  220.         a=a&0x0f;          //溫度的小數(shù)部分
  221.         return b;
  222. }


  223. void key_pros()  //按鍵處理函數(shù)
  224. {
  225.         if(k1==0)
  226.         {
  227.                 delay(1000);
  228.                 if(k1==0)
  229.                 {
  230.                         mode++;
  231.                         if(mode==5)mode=0;
  232.                         wrc(0x01);
  233.                 }
  234.                 while(!k1);
  235.         }
  236.         if(mode==1)                  //對(duì)溫度上限設(shè)定
  237.         {
  238.                 if(k2==0)                  //加
  239.                 {
  240.                         delay(1000);
  241.                         if(k2==0)
  242.                         {
  243.                                 temph++;
  244.                                 if(temph>=80)temph=80;
  245.                         }
  246.                         while(!k2);
  247.                 }
  248.                 if(k3==0)           //減
  249.                 {
  250.                         delay(1000);
  251.                         if(k3==0)
  252.                         {
  253.                                 temph--;
  254.                                 if(temph<=0)temph=0;
  255.                         }
  256.                         while(!k3);
  257.                 }
  258.         }
  259.         if(mode==2)                  //對(duì)溫度下限設(shè)定
  260.         {
  261.                 if(k2==0)                  //加
  262.                 {
  263.                         delay(1000);
  264.                         if(k2==0)
  265.                         {
  266.                                 templ++;
  267.                                 if(templ>=80)templ=80;
  268.                         }
  269.                         while(!k2);
  270.                 }
  271.                 if(k3==0)           //減
  272.                 {
  273.                         delay(1000);
  274.                         if(k3==0)
  275.                         {
  276.                                 templ--;
  277.                                 if(templ<=0)templ=0;
  278.                         }
  279.                         while(!k3);
  280.                 }
  281.         }
  282.         if(mode==3)                  //對(duì)濕度上限設(shè)定
  283.         {
  284.                 if(k2==0)                  //加
  285.                 {
  286.                         delay(1000);
  287.                         if(k2==0)
  288.                         {
  289.                                 humih++;
  290.                                 if(humih>=80)humih=80;
  291.                         }
  292.                         while(!k2);
  293.                 }
  294.                 if(k3==0)           //減
  295.                 {
  296.                         delay(1000);
  297.                         if(k3==0)
  298.                         {
  299.                                 humih--;
  300.                                 if(humih<=0)humih=0;
  301.                         }
  302.                         while(!k3);
  303.                 }
  304.         }
  305.         if(mode==4)                  //對(duì)濕度下限設(shè)定
  306.         {
  307.                 if(k2==0)                  //加
  308.                 {
  309.                         delay(1000);
  310.                         if(k2==0)
  311.                         {
  312.                                 humil++;
  313.                                 if(humil>=80)humil=80;
  314.                         }
  315.                         while(!k2);
  316.                 }
  317.                 if(k3==0)           //減
  318.                 {
  319.                         delay(1000);
  320.                         if(k3==0)
  321.                         {
  322.                                 humil--;
  323.                                 if(humil<=0)humil=0;
  324.                         }
  325.                         while(!k3);
  326.                 }
  327.         }
  328. }

  329. void lcd_init_display()           //LCD初始化顯示
  330. {
  331.         uint8 i;
  332.         for(i=0;i<5;i++)
  333.         {
  334.                 wrc(0x80+i);
  335.                 wrd(str1[i]);        
  336.         }

  337.         for(i=0;i<5;i++)
  338.         {
  339.                 wrc(0xc0+i);
  340.                 wrd(str2[i]);        
  341.         }
  342. }

  343. void data_pros()        //數(shù)據(jù)處理函數(shù)
  344. {
  345.         uint8 i;              
  346.         uint8 temp_buf[2],humi_buf[2];
  347.         uint8 temphbuf[2],templbuf[2],humihbuf[2],humilbuf[2];
  348.         float dio;
  349.         uint16 k;

  350.         tempvalue=readtemp();
  351.         DHT11_Read_Data(&temp,&humi);
  352.         temp_buf[0]=temp/10+0x30;        
  353.         temp_buf[1]=temp%10+0x30;

  354.         humi_buf[0]=humi/10+0x30;        
  355.         humi_buf[1]=humi%10+0x30;
  356.         
  357.         dio=a*0.0625;
  358.         k=dio*10000;//取小數(shù)點(diǎn)后兩位有效數(shù)字

  359.         temphbuf[0]=temph/10+0x30;
  360.         temphbuf[1]=temph%10+0x30;
  361.         templbuf[0]=templ/10+0x30;
  362.         templbuf[1]=templ%10+0x30;

  363.         humihbuf[0]=humih/10+0x30;
  364.         humihbuf[1]=humih%10+0x30;
  365.         humilbuf[0]=humil/10+0x30;
  366.         humilbuf[1]=humil%10+0x30;

  367.         if(mode==0)
  368.         {
  369.                 lcd_init_display();
  370.                 wrc(0x85);
  371.                 wrd(num[tempvalue%100/10]);
  372.                 wrd(num[tempvalue%100%10]);
  373.                 wrd('.');
  374.                 wrd(num[k/1000]);
  375.                 wrd(0xdf);
  376.                 wrd('C');
  377.         
  378.                 for(i=0;i<2;i++)
  379.                 {
  380.                         wrc(0Xc5+i);
  381.                         wrd(humi_buf[i]);                  
  382.                 }        
  383.                 for(i=0;i<3;i++)
  384.                 {
  385.                         wrc(0Xc7+i);
  386.                         wrd(str5[i]);                  
  387.                 }        
  388.         }
  389.         if(mode==1)                          //溫度上限顯示
  390.         {
  391.                 wrc(0x80);
  392.                 for(i=0;i<6;i++)
  393.                 {
  394.                         wrd(str6[i]);                  
  395.                 }
  396.                 wrd(temphbuf[0]);
  397.                 wrd(temphbuf[1]);                        
  398.         }
  399.         if(mode==2)                          //溫度下限顯示
  400.         {
  401.                 wrc(0x80);
  402.                 for(i=0;i<6;i++)
  403.                 {
  404.                         wrd(str7[i]);                  
  405.                 }
  406.                 wrd(templbuf[0]);
  407.                 wrd(templbuf[1]);                        
  408.         }
  409.         if(mode==3)                          //濕度上限顯示
  410.         {
  411.                 wrc(0x80);
  412.                 for(i=0;i<6;i++)
  413.                 {
  414.                         wrd(str8[i]);                  
  415.                 }
  416.                 wrd(humihbuf[0]);
  417.                 wrd(humihbuf[1]);                        
  418.         }
  419.         if(mode==4)                          //濕度下限顯示
  420.         {
  421.                 wrc(0x80);
  422.                 for(i=0;i<6;i++)
  423.                 {
  424.                         wrd(str9[i]);                  
  425.                 }
  426.                 wrd(humilbuf[0]);
  427.                 wrd(humilbuf[1]);                        
  428.         }
  429. }

  430. void baojinpros()        //報(bào)警處理
  431. {
  432.         if(tempvalue>=temph||humi>=humih)         //檢測(cè)溫度或者濕度高于設(shè)定上限值 降溫濕
  433.         {
  434.         bee=~bee;        //降溫濕指示燈
  435. dj=~dj;
  436.         }
  437.         if(tempvalue<=templ||humi<=humil)        //檢測(cè)溫度或者濕度低于設(shè)定下限值  升溫濕
  438.         {
  439.                 bee=~bee;        //升高溫濕指示燈
  440.                 dj=~dj;
  441.         }
復(fù)制代碼

        詳細(xì)可以看附件,不懂可以咨詢。我也萌新互相學(xué)習(xí)。

設(shè)計(jì).7z

24.04 KB, 下載次數(shù): 71, 下載積分: 黑幣 -5

這是我一次小制作大神見笑了希望能幫當(dāng)一些初學(xué)者參考

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

使用道具 舉報(bào)

沙發(fā)
ID:582867 發(fā)表于 2019-7-12 21:15 | 只看該作者
有問題大佬指點(diǎn)小弟。
回復(fù)

使用道具 舉報(bào)

板凳
ID:89286 發(fā)表于 2019-7-15 10:51 | 只看該作者
thanks for sharing
回復(fù)

使用道具 舉報(bào)

地板
ID:880098 發(fā)表于 2021-1-24 15:50 | 只看該作者
里面只有一個(gè)仿真文件和這個(gè)網(wǎng)頁上面的代碼哦,還能再分享點(diǎn)資料嗎?
回復(fù)

使用道具 舉報(bào)

本版積分規(guī)則

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

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

快速回復(fù) 返回頂部 返回列表
主站蜘蛛池模板: www国产精品| 天堂视频免费 | 一区二区三区国产 | 自拍偷拍第一页 | 99国产精品久久久 | 国产高清在线精品一区二区三区 | 国产成人久久精品一区二区三区 | 美国一级毛片a | 久久久免费电影 | 亚洲一区二区三区久久久 | www.成人.com | 亚洲性视频 | 欧美精品一区免费 | www.色综合| 蜜臀网 | 国产在线一区二区 | 青青草视频免费观看 | 精品国产一区二区三区久久久久久 | 国产精品九九九 | 色综合久久久 | 中文字幕在线精品 | 亚洲一区二区三区在线 | 九九热视频这里只有精品 | 久久之精品 | 一级黄色淫片 | 亚洲成av人片在线观看 | 成人亚洲性情网站www在线观看 | 丝袜美腿一区 | 免费毛片网站在线观看 | 国产视频中文字幕在线观看 | 欧美日韩中文字幕在线 | 国产在线一级片 | 波多野结衣电影一区 | 天天操人人干 | 亚洲免费在线视频 | 国产亚洲一区二区三区 | 日批的视频 | 国产精品一区二区av | 日韩中文字幕在线播放 | 麻豆国产一区二区三区四区 | 天天天操天天天干 |