AT89C52单片机DHT11温湿度控制和光电计数代码Proteus仿真

[复制链接]
查看6 | 回复0 | 2021-4-17 01:54:41 | 显示全部楼层 |阅读模式
以AT89C52为主控芯片,以DHT11为温湿度传感器,用LCD1602显示数值,当湿度过高时,启动电风扇(用L298N驱动直流电机模拟),当温度过低时,启动电热管(用OVEN器件模拟)

仿真原理图如下(proteus仿真工程文件可到本帖附件中下载)
205406d00o8pyw0opd8aox.jpg
单片机部分源程序如下:
  1. #include <reg52.h>      /////////////头文件

  2. sbit IN1 = P2^3;
  3. sbit IN2 = P2^4;
  4. sbit ENA = P2^5;
  5. sbit Res = P2^6;     //电热丝控制口
  6. sbit Key = P2^7;    //模拟光电门

  7. ////////////////////////////////////////////////////////////////////////////
  8. void LcdShowStr(unsigned char x, unsigned char y, unsigned char *str);
  9. void ConfigTimer0(unsigned int ms);
  10. unsigned char IntToString(unsigned char *str, int dat);
  11. extern void LcdWriteCmd(unsigned char cmd);
  12. extern void LcdWriteDat(unsigned char dat);
  13. extern bit Start18B20();
  14. extern bit Get18B20Temp(int *temp);
  15. extern void InitLcd1602();     
  16. bit DHT_Start();   
  17. bit DHT_ByteRead(unsigned char *dat);


  18. /////////////////////////////  数组命名
  19. int Humity,Tempature,x;
  20. int Count = 0;    //工具计数值
  21. bit flag1s = 0;          //1s定时标志
  22. unsigned char T0RH = 0;  //T0重载值的高字节
  23. unsigned char T0RL = 0;  //T0重载值的低字节


  24.   /////////////////////////////////    延时子程序
  25. void delay()
  26. {
  27.     x=99999;
  28.     while(x--);
  29. }


  30. void Key_Scan( void )
  31. {
  32.     if( Key == 0 )
  33.     {
  34.         delay();
  35.         if( Key == 0 )
  36.         {
  37.             Count++;
  38.             if( Count > 20 )
  39.             {
  40.                 Count = 0;
  41.             }   
  42.         }
  43.         while(!Key);
  44.     }   
  45. }

  46.    /////////////////////////////////
  47. void main()      ////////////////主程序
  48. {
  49.     int Tempature = 0;
  50.     int Humidy = 0;         
  51.     bit tmp;
  52.     unsigned char Decade = 0;
  53.     unsigned char Digtal = 0;
  54.     unsigned char str[12];
  55.     unsigned char DHT[5];
  56.     ////初始化///////////////////////
  57.     EA = 1;            //开总中断
  58.     ConfigTimer0(10);  //T0定时10ms
  59.     InitLcd1602();     //初始化液晶

  60.     ////////////////////////////////////
  61.     DHT_Start();
  62.     delay();
  63.     delay();
  64.     delay();
  65.    
  66.     delay();

  67.     ENA = 0;
  68.     IN1 = 1;
  69.     IN2 = 0;
  70.     Res = 0;

  71.     LcdShowStr(0, 0, "Temp:");        //显示到液晶屏上
  72.     LcdShowStr(0, 1, "Humi:");        //显示到液晶屏上
  73.     LcdShowStr(8, 0, "Num:");        //显示到液晶屏上

  74.     while (1)
  75.     {   
  76.         if (flag1s)  //每秒更新一次温度
  77.         {            
  78.             DHT_Start();
  79.             tmp=DHT_ByteRead(&DHT);
  80.             if(tmp==1)
  81.             {
  82.                 str[0] = (DHT[0]/10)%10 + '0';  //十位转为ASCII码
  83.                 str[1] = (DHT[0]%10) + '0';  //个位转为ASCII
  84.                 LcdShowStr(5, 1, str);
  85.                
  86.                 str[0] = (DHT[2]/10)%10 + '0';  //十位转为ASCII码
  87.                 str[1] = (DHT[2]%10) + '0';  //个位转为ASCII
  88.                 str[2] = '\0';
  89.                 LcdShowStr(5,0, str);
  90.                
  91.                 Tempature= DHT[2];
  92.                 Humity=DHT[0];

  93.                 if( Tempature >= 24 )
  94.                 {
  95.                     Res = 0;               
  96.                 }
  97.                 else if ( Tempature < 24 )
  98.                 {
  99.                     Res = 1;
  100.                 }

  101.                 /*********************************/

  102.                 if( Humity >= 60 )
  103.                 {
  104.                     ENA = 1;               
  105.                 }
  106.                 else if ( Humity < 60 )
  107.                 {
  108.                     ENA = 0;
  109.                 }
  110.             }
  111.         }
  112.         Key_Scan();
  113.         Decade = Count/10;
  114.         Digtal = Count%10;
  115.         LcdWriteCmd(0x80+12);
  116.         LcdWriteDat(0x30+Decade);
  117.         LcdWriteDat(0x30+Digtal);
  118.      }
  119. }


  120. /* 整型数转换为字符串,str-字符串指针,dat-待转换数,返回值-字符串长度 */
  121. unsigned char IntToString(unsigned char *str, int dat)
  122. {
  123.     signed char i = 0;
  124.     unsigned char len = 0;
  125.     unsigned char buf[6];
  126.    
  127.     if (dat < 0)  //如果为负数,首先取绝对值,并在指针上添加负号
  128.     {
  129.         dat = -dat;
  130.         *str++ = '-';
  131.         len++;
  132.     }
  133.     do {          //先转换为低位在前的十进制数组
  134.         buf[i++] = dat % 10;
  135.         dat /= 10;
  136.     } while (dat > 0);
  137.     len += i;     //i最后的值就是有效字符的个数
  138.     while (i-- > 0)   //将数组值转换为ASCII码反向拷贝到接收指针上
  139.     {
  140.         *str++ = buf[i] + '0';
  141.     }
  142.     *str = '\0';  //添加字符串结束符
  143.    
  144.     return len;   //返回字符串长度
  145. }

  146. /* 配置并启动T0,ms-T0定时时间 */
  147. void ConfigTimer0(unsigned int ms)
  148. {
  149.     unsigned long tmp;  //临时变量
  150.    
  151.     tmp = 11059200 / 12;      //定时器计数频率
  152.     tmp = (tmp * ms) / 1000;  //计算所需的计数值
  153.     tmp = 65536 - tmp;        //计算定时器重载值
  154.     tmp = tmp + 12;           //补偿中断响应延时造成的误差
  155.     T0RH = (unsigned char)(tmp>>8);  //定时器重载值拆分为高低字节
  156.     T0RL = (unsigned char)tmp;
  157.     TMOD &= 0xF0;   //清零T0的控制位
  158.     TMOD |= 0x01;   //配置T0为模式1
  159.     TH0 = T0RH;     //加载T0重载值
  160.     TL0 = T0RL;
  161.     ET0 = 1;        //使能T0中断
  162.     TR0 = 1;        //启动T0
  163. }
  164. /* T0中断服务函数,完成1秒定时 */
  165. void InterruptTimer0() interrupt 1
  166. {
  167.     static unsigned char tmr1s = 0;
  168.    
  169.     TH0 = T0RH;  //重新加载重载值
  170.     TL0 = T0RL;
  171.     tmr1s++;
  172.     if (tmr1s >= 100)  //定时1s
  173.     {
  174.         tmr1s = 0;
  175.         flag1s = 1;
  176.     }

  177.    
  178. }
复制代码
温度检测仿真电路.zip (136.49 KB, 售价: 2 工控币)
温度检测C语言程序.zip (76.76 KB, 售价: 2 工控币)

回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则