DHT11+LCD1602显示温湿度采集Proteus仿真——添加小数点和温度矫正

原有DHT11+LCD1602显示温湿度采集代码,如下:

#include<reg51.h>
#include<intrins.h>
#define uchar unsigned char
#define uint unsigned int
sbit Data=P1^6;   
uchar rec_dat[9];   
sbit lcdrs=P2^0;
sbit lcdrw=P2^1;
sbit lcden=P2^2;
void delay(uint n)
{  uint x,y; 
   for(x=n;x>0;x--) 
       for(y=110;y>0;y--); 
} 
void write_com(uchar com)
{
        lcdrs=0;                        
        P0=com;
        delay(5);
        lcden=1;                        
        delay(5);
        lcden=0;                      
}
void write_dat(uchar dat)
{
        lcdrs=1;                         
        P0=dat;
        delay(5);
        lcden=1;
        delay(5);
        lcden=0;
}
void init_lcd()
{
        lcden=0;
        lcdrw=0;
        write_com(0x38);          
        write_com(0x0c);         
        write_com(0x06);         
        write_com(0x01);
}
void DHT11_delay_us(uchar n)
{
    while(--n);
}
void DHT11_delay_ms(uint z)
{
   uint i,j;
   for(i=z;i>0;i--)
      for(j=110;j>0;j--);
}
void DHT11_start()
{
   Data=1;
   DHT11_delay_us(2);
   Data=0;
   DHT11_delay_ms(30);   
   Data=1;
   DHT11_delay_us(30);
}
uchar DHT11_rec_byte()      
{
   uchar i,dat=0;
  for(i=0;i<8;i++)    
   {          
      while(!Data);   
      DHT11_delay_us(8);    
      dat<<=1;           
      if(Data==1)    
         dat+=1;
      while(Data);     
    }  
    return dat;
}
void DHT11_receive()     
{
    uchar R_H,R_L,T_H,T_L,RH,RL,TH,TL,revise; 
    DHT11_start();
    if(Data==0)
    {
        while(Data==0);       
        DHT11_delay_us(40);  
        R_H=DHT11_rec_byte();      
        R_L=DHT11_rec_byte();     
        T_H=DHT11_rec_byte();     
        T_L=DHT11_rec_byte();    
        revise=DHT11_rec_byte(); 
        DHT11_delay_us(25);    
        if((R_H+R_L+T_H+T_L)==revise)      
        {
            RH=R_H;
            RL=R_L;
            TH=T_H;
            TL=T_L;
        }  
        rec_dat[0]='0'+(RH/10);
        rec_dat[1]='0'+(RH%10);
        rec_dat[2]='%';
        rec_dat[3]=' ';
        rec_dat[4]=' ';
        rec_dat[5]='0'+(TH/10);
        rec_dat[6]='0'+(TH%10); 
    }
}
void main()
{
   uchar i;   
   init_lcd();   
   while(1)
   {   
       DHT11_delay_ms(100);    
       DHT11_receive();
       write_com(0x80);   
       for(i=0;i<9;i++)
       write_dat(rec_dat[i]);   
       write_dat(rec_dat[7]);
    write_dat(0xdf);
    write_dat('C');                          
   }
}

  原本的代码为整数显示,接下来修改代码使其有一位小数显示,因为存在时间漂移和温度漂移,所以添加4个按键k1~k4,可对设备进行手动校正。

修改后的代码如下:

#include<regx52.h>
#include<intrins.h>
#define uchar unsigned char
#define uint unsigned int
sbit Data=P1^6;   
uchar rec_dat[9];   
sbit lcdrs=P2^0;
sbit lcdrw=P2^1;
sbit lcden=P2^2;
sbit k1=P2^3;
sbit k2=P2^4;
sbit k3=P2^5;
sbit k4=P2^6;
void delay(uint n)
{  uint x,y; 
   for(x=n;x>0;x--) 
       for(y=110;y>0;y--); 
} 
void write_com(uchar com)
{
        lcdrs=0;                        
        P0=com;
        delay(5);
        lcden=1;                        
        delay(5);
        lcden=0;                      
}
void write_dat(uchar dat)
{
        lcdrs=1;                         
        P0=dat;
        delay(5);
        lcden=1;
        delay(5);
        lcden=0;
}
void init_lcd()
{
        lcden=0;
        lcdrw=0;
        write_com(0x38);          
        write_com(0x0c);         
        write_com(0x06);         
        write_com(0x01);
}
void DHT11_delay_us(uchar n)
{
    while(--n);
}
void DHT11_delay_ms(uint z)
{
   uint i,j;
   for(i=z;i>0;i--)
      for(j=110;j>0;j--);
}
void DHT11_start()
{
   Data=1;
   DHT11_delay_us(2);
   Data=0;
   DHT11_delay_ms(30);   
   Data=1;
   DHT11_delay_us(30);
}
uchar DHT11_rec_byte()      
{
   uchar i,dat=0;
  for(i=0;i<8;i++)    
   {          
      while(!Data);   
      DHT11_delay_us(8);    
      dat<<=1;           
      if(Data==1)    
         dat+=1;
      while(Data);     
    }  
    return dat;
}
uchar R_H,R_L,T_H,T_L,RH,RL,TH,TL,revise;
int flag1=0,flag2=0;
void DHT11_receive()     
{
    
    DHT11_start();
    if(Data==0)
    {
        while(Data==0);       
        DHT11_delay_us(40);  
        R_H=DHT11_rec_byte();      
        R_L=DHT11_rec_byte();     
        T_H=DHT11_rec_byte();     
        T_L=DHT11_rec_byte();    
        revise=DHT11_rec_byte(); 
        DHT11_delay_us(25);    
        if((R_H+R_L+T_H+T_L)==revise)      
        {
            RH=R_H;
            RL=R_L;
            TH=T_H;
            TL=T_L;
        }  
        rec_dat[0]='0'+((RH*10+flag1)/100);
        rec_dat[1]='0'+((RH*10+flag1)%100/10);
                rec_dat[2]=0x2e;
                rec_dat[3]=(RH*10+flag1)%10+'0';
                rec_dat[4]='%';
        rec_dat[5]=' ';
        rec_dat[6]='0'+((TH*10+flag2)/100);
        rec_dat[7]='0'+((TH*10+flag2)%100/10); 
                rec_dat[8]=0x2e;
                rec_dat[9]=(TH*10+flag2)%10+'0';
    }
}
void main()
{
   uchar i;   
   init_lcd();   
   while(1)
   {   
      
            if(k1==0)
    {
        DHT11_delay_ms(30);
        flag1=flag1+1;
    }
        if(k2==0)
    {
        DHT11_delay_ms(30);
        flag1=flag1-1;
    }
    
        if(k3==0)
    {
        DHT11_delay_ms(30);
        flag2=flag2+1;
    }
        if(k4==0)
    {
        DHT11_delay_ms(30);
        flag2=flag2-1;
        
    }              
             DHT11_delay_ms(100);    
       DHT11_receive();
       write_com(0x80);
    
             for(i=0;i<=9;i++)
       write_dat(rec_dat[i]);      
             write_dat(0xdf);
             write_dat('C');    
    
   }
}

下面是最后仿真的结果:

  • 9
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值