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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

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

用1602讀取溫濕度,如有不足還請多多包含

[復(fù)制鏈接]
回帖獎勵 2 黑幣 回復(fù)本帖可獲得 2 黑幣獎勵! 每人限 1 次(中獎概率 20%)
跳轉(zhuǎn)到指定樓層
樓主
ID:836515 發(fā)表于 2021-10-11 15:26 | 只看該作者 |只看大圖 回帖獎勵 |倒序瀏覽 |閱讀模式
  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^3; //模式
  9. sbit k2=P2^1; //加
  10. sbit k3=P2^2; //減


  11. sbit DHT11_DQ_OUT=P3^2;
  12. sbit led1=P3^6;
  13. sbit led2=P3^7;


  14. sbit dq=P2^0;


  15. uint8 mode=0,xian;
  16. char temph=50,templ=20;
  17. char humih=80,humil=20;
  18. uint8 temp,humi;
  19. uint8 flag;          //設(shè)定報警標志
  20. uint8 a,c,tempvalue;
  21. uint8 code num[10]="0123456789";


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




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


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


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


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




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




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


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


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








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




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


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


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


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


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


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


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


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


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


  429. void baojinpros()        //報警處理
  430. {
  431.         if(tempvalue>=temph||humi>=humih)         //檢測溫度或者濕度高于設(shè)定上限值 降溫濕
  432.         {
  433.                 led1=1;                //降溫濕指示燈
  434.                 led2=0;
  435.         }
  436.         if(tempvalue<=templ||humi<=humil)        //檢測溫度或者濕度低于設(shè)定下限值  升溫濕
  437.         {
  438.                 led1=0;
  439.                 led2=1;           //升高溫濕指示燈
  440.         }
  441.         if((tempvalue>templ&&tempvalue<temph)&&(humi>humil&&humi<humih))
  442.         {
  443.                 led1=0;
  444.                 led2=0;        
  445.         }
  446. }


  447. void main()
  448. {
  449.         uint8 i=0;
  450.         led1=0;
  451.         led2=0;
  452.         lcd_init();
  453.         while(DHT11_Init())        //檢測DHT11是否純在
  454.         {
  455.                 for(i=0;i<5;i++)
  456.                 {
  457.                         wrc(0x80+i);
  458.                         wrd(str3[ i]);        [ i]
  459.                 }                        
  460.         }
  461.         wrc(0x01);
  462.         lcd_init_display();           //LCD初始化顯示
  463.         i=0;
  464.         while(1)
  465.         {        
  466.                 i++;
  467.                 key_pros();
  468.                 baojinpros();        //報警處理
  469.                 if(i==15)
  470.                 {
  471.                         i=0;
  472.                         data_pros();           //讀取一次DHT11數(shù)據(jù)最少要大于100ms
  473.                 }
  474.                 delay(1000);
  475.                
  476.         }        
  477. }
復(fù)制代碼



原理圖截圖.png (45.71 KB, 下載次數(shù): 131)

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

使用道具 舉報

沙發(fā)
ID:836515 發(fā)表于 2021-10-11 16:55 | 只看該作者
希望大家多多指點
回復(fù)

使用道具 舉報

板凳
ID:836515 發(fā)表于 2021-11-1 09:11 | 只看該作者
都沒人來康康嗎?
回復(fù)

使用道具 舉報

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

本版積分規(guī)則

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

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

快速回復(fù) 返回頂部 返回列表
主站蜘蛛池模板: 最新中文在线视频 | 国产精品免费在线 | 四虎影院一区二区 | 成人免费观看视频 | 国产在线精品一区二区三区 | 午夜在线视频 | 日韩a在线 | 亚洲黄色一级 | 日韩在线成人 | 国产精品一区二区久久 | 国产一级一级 | 欧美精品一二三 | 精品久久久久久久久久久久 | 天天搞夜夜操 | 国产精品精品3d动漫 | 国产视频久久 | 中文字幕在线一区 | 亚洲国产一区二区三区四区 | 成人一区二区三区在线观看 | 色伊人网 | 日本超碰在线 | 国产精品亚洲一区二区三区在线 | 超碰8 | 成人区精品 | 成人激情视频在线播放 | 在线免费观看视频你懂的 | 国产精品一区在线 | 91精品国产综合久久久久 | 欧美猛交| 亚洲精品乱码久久久久久蜜桃91 | 国产精品免费视频一区 | 黄色大片观看 | 天天操天天操 | 91国语清晰打电话对白 | 伊人婷婷 | 日韩二区三区 | 亚洲精品字幕 | 久久国产精品偷 | 久久国产一区二区 | 色婷婷精品 | 爱爱小视频 |