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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

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

為DHT11+LCD1602數(shù)字溫濕度測量儀添加溫度矯正

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
ID:1142591 發(fā)表于 2025-1-6 16:39 | 只看該作者 回帖獎勵 |倒序?yàn)g覽 |閱讀模式
現(xiàn)有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');                             }}

本文計(jì)劃對源代碼進(jìn)行改進(jìn),實(shí)現(xiàn)兩個(gè)功能,一是修改溫濕度值的顯示位數(shù),使其能夠顯示溫濕度值小數(shù)點(diǎn)后一位,二是實(shí)現(xiàn)對溫濕度的手動校正。

修改后的代碼如下所示。

#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');        

        

   }

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

使用道具 舉報(bào)

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

本版積分規(guī)則

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

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

快速回復(fù) 返回頂部 返回列表
主站蜘蛛池模板: 国产精品久久久久久久三级 | 久久亚洲一区二区三区四区 | 91最新入口 | 91亚洲一区 | av在线一区二区三区 | 欧美一区二区久久 | 黄色三级免费 | 国产中文字幕网 | 国精产品一区二区三区 | 国产精品久久久久久久久久尿 | 精品少妇一区二区三区日产乱码 | av网址在线 | 羞羞的视频在线看 | 国产精品成人一区二区 | 日本精品久久久久久久 | 伊人久久综合影院 | 午夜男人天堂 | 免费一区二区三区 | 不卡一区二区三区四区 | 中文字幕成人 | 亚洲国产精品一区二区三区 | 伊人久久伊人 | 亚洲综合色视频在线观看 | 欧美在线视频不卡 | 欧美一区二区在线免费观看 | 中文在线а√在线8 | 日韩在线观看网站 | 艹逼网 | 日韩色在线 | 色综合久 | 中文字幕在线人 | 日韩视频 中文字幕 | 一区二区三区av夏目彩春 | 日韩精品久久久久 | 国产在线一区二区三区 | 久久久久久国产精品久久 | 免费一区二区 | 日韩精品一区二区三区中文字幕 | 欧美日韩精品久久久免费观看 | 天天干精品 | 国产精品一区二区三区在线 |