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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 1896|回復: 0
打印 上一主題 下一主題
收起左側

農業大棚溫濕度監控系統設計

[復制鏈接]
跳轉到指定樓層
樓主
ID:484960 發表于 2020-3-21 16:14 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
#include<reg52.h>
#include "intrins.h"
typedef unsigned char uint8;
typedef unsigned int uint16;
sbit rs=P2^6;         // 數據命令選擇
sbit rw=P2^5;         //讀寫選擇
sbit e=P2^7;          //使能

sbit k1=P3^3; //模式
sbit k2=P2^1; //加
sbit k3=P2^2; //減

sbit DHT11_DQ_OUT=P3^2;
sbit led1=P3^6;
sbit led2=P3^7;

sbit dq=P2^0;

uint8 mode=0,xian;
char temph=50,templ=20;
char humih=80,humil=20;
uint8 temp,humi;
uint8 flag;          //設定報警標志
uint8 a,c,tempvalue;
uint8 code num[10]="0123456789";

uint8 code str1[]="Temp:";  //溫度
uint8 code str2[]="Humi:";  //濕度
uint8 code str3[]="Error";  
uint8 code str4[]="Success    ";
uint8 code str5[]="%RH";
uint8 code str6[]="TempH:";          //設定溫度上限顯示
uint8 code str7[]="TempL:";          //設定溫度下限顯示
uint8 code str8[]="HumiH:";           //設定濕度上限顯示
uint8 code str9[]="HumiL:";           //設定濕度下限顯示


void delay(uint16 i)
{
        while(i--);
}

void delay_ms(uint16 i)
{
        while(i--)
                delay(90);
}

void wrc(uint8 c)         //寫命令
{
        delay(1000);
        rs=0;
        rw=0;
        e=0;
        P0=c;
        e=1;
        delay(10);
        e=0;
}
void wrd(uint8 dat)          //寫數據
{
        delay(1000);
        rs=1;
        rw=0;
        e=0;
        P0=dat;
        e=1;
        delay(10);
        e=0;
        rs=0;
}
void lcd_init()           // LCD1602初始化
{
        delay(1000);
        wrc(0x38);
        wrc(0x38);         //功能設置命令,選擇8位總線,雙行顯示  5*7點陣字符
        wrc(0x38);
        wrc(0x06);        //光標和顯示模式設置  光標右移  整屏不移動
        wrc(0x0c);        //顯示開關控制  開顯示  無光標 光標不閃爍
        wrc(0x01);        //清零指令  固定的
}
//復位DHT11
void DHT11_Rst()          
{                 
    DHT11_DQ_OUT=0;         //拉低DQ
    delay_ms(20);            //拉低至少18ms
    DHT11_DQ_OUT=1;         //DQ=1
        delay(3);             //主機拉高20~40us
}

//等待DHT11的回應
//返回1:未檢測到DHT11的存在
//返回0:存在
uint8 DHT11_Check()           
{   
        uint8 retry=0;         
    while (DHT11_DQ_OUT&&retry<100)//DHT11會拉低40~50us
        {
                retry++;
                _nop_();
        };         
        if(retry>=100)return 1;
        else retry=0;
    while (!DHT11_DQ_OUT&&retry<100)//DHT11拉低后會再次拉高40~50us
        {
                retry++;
                _nop_();
        };
        if(retry>=100)return 1;            
        return 0;
}


//DHT11初始化
//返回0:初始化成功,1:失敗
uint8 DHT11_Init()
{
        DHT11_Rst();          
        return DHT11_Check();       
}


//從DHT11讀取一個位
//返回值:1/0
uint8 DHT11_Read_Bit(void)                          
{
        uint8 retry=0;
        while(DHT11_DQ_OUT&&retry<100)//等待變為低電平 12-14us 開始
        {
                retry++;
                _nop_();
        }
        retry=0;
        while((!DHT11_DQ_OUT)&&retry<100)//等待變高電平         26-28us表示0,116-118us表示1
        {
                retry++;
                _nop_();
        }
        delay(1);//等待40us
        if(DHT11_DQ_OUT)return 1;
        else return 0;                  
}

//從DHT11讀取一個字節
//返回值:讀到的數據
uint8 DHT11_Read_Byte(void)   
{        
    uint8 i,dat=0;
        for (i=0;i<8;i++)
        {
                   dat<<=1;
            dat|=DHT11_Read_Bit();
    }                                                    
    return dat;
}

//從DHT11讀取一次數據
//temp:溫度值(范圍:0~50°)
//humi:濕度值(范圍:20%~90%)
//返回值:0,正常;1,讀取失敗
uint8 DHT11_Read_Data(uint8 *temp,uint8 *humi)   
{        
        uint8 buf[5];
        uint8 i;
        DHT11_Rst();
        if(DHT11_Check()==0)
        {
                for(i=0;i<5;i++)//讀取40位數據
                {
                        buf[i]=DHT11_Read_Byte();
                }
                if((buf[0]+buf[1]+buf[2]+buf[3])==buf[4])
                {
                        *humi=buf[0];
                        *temp=buf[2];
                }
               
        }else return 1;
        return 0;            
}




void ds18b20init()                //18b20的初始化
{
        dq=1;
        delay(1);
        dq=0;
        delay(80);
        dq=1;
        delay(5);
        dq=0;
        delay(20);
        dq=1;
        delay(35);
}
void ds18b20wr(uint8 dat)          //18b20寫數據
{
        uint8 i;
        for(i=0;i<8;i++)
        {
                dq=0;
                dq=dat&0x01;
                dat>>=1;
                delay(8);//在時序上只有這一塊對時序要求最準確,他的時間必須大于15us
                dq=1;
                delay(1);
        }       
}
uint8 ds18b20rd()                  //18b20讀數據
{
        uint8 value,i;
        for(i=0;i<8;i++)       
        {
                dq=0;
                value>>=1;
                dq=1;
                if(dq==1)value|=0x80;
                delay(8);//在這一塊也對時間要求特別準確,整段程序必須大于60us               
        }
        return value;
}
uint8 readtemp()                          //讀取溫度內需要復位的
{
        uint8 b;
        ds18b20init();                //初始化
        ds18b20wr(0xcc);   //發送忽略ROM指令
        ds18b20wr(0x44);   //發送溫度轉換指令
        delay(100);
        ds18b20init();           //初始化
        ds18b20wr(0xcc);   //發送忽略ROM指令
        ds18b20wr(0xbe);   //發讀暫存器指令
        a=ds18b20rd();         //溫度的低八位
        b=ds18b20rd();         //溫度的高八位
        b<<=4;                         //ssss s***;s為標志位s=0表示溫度值為正數,s=1溫度值為負數
        c=b&0x80;                //溫度正負標志位確認
        b+=(a&0xf0)>>4;
        a=a&0x0f;          //溫度的小數部分
        return b;
}


void key_pros()  //按鍵處理函數
{
        if(k1==0)
        {
                delay(1000);
                if(k1==0)
                {
                        mode++;
                        if(mode==5)mode=0;
                        wrc(0x01);
                }
                while(!k1);
        }
        if(mode==1)                  //對溫度上限設定
        {
                if(k2==0)                  //加
                {
                        delay(1000);
                        if(k2==0)
                        {
                                temph++;
                                if(temph>=80)temph=80;
                        }
                        while(!k2);
                }
                if(k3==0)           //減
                {
                        delay(1000);
                        if(k3==0)
                        {
                                temph--;
                                if(temph<=0)temph=0;
                        }
                        while(!k3);
                }
        }
        if(mode==2)                  //對溫度下限設定
        {
                if(k2==0)                  //加
                {
                        delay(1000);
                        if(k2==0)
                        {
                                templ++;
                                if(templ>=80)templ=80;
                        }
                        while(!k2);
                }
                if(k3==0)           //減
                {
                        delay(1000);
                        if(k3==0)
                        {
                                templ--;
                                if(templ<=0)templ=0;
                        }
                        while(!k3);
                }
        }
        if(mode==3)                  //對濕度上限設定
        {
                if(k2==0)                  //加
                {
                        delay(1000);
                        if(k2==0)
                        {
                                humih++;
                                if(humih>=80)humih=80;
                        }
                        while(!k2);
                }
                if(k3==0)           //減
                {
                        delay(1000);
                        if(k3==0)
                        {
                                humih--;
                                if(humih<=0)humih=0;
                        }
                        while(!k3);
                }
        }
        if(mode==4)                  //對濕度下限設定
        {
                if(k2==0)                  //加
                {
                        delay(1000);
                        if(k2==0)
                        {
                                humil++;
                                if(humil>=80)humil=80;
                        }
                        while(!k2);
                }
                if(k3==0)           //減
                {
                        delay(1000);
                        if(k3==0)
                        {
                                humil--;
                                if(humil<=0)humil=0;
                        }
                        while(!k3);
                }
        }
}

void lcd_init_display()           //LCD初始化顯示
{
        uint8 i;
        for(i=0;i<5;i++)
        {
                wrc(0x80+i);
                wrd(str1[i]);       
        }

        for(i=0;i<5;i++)
        {
                wrc(0xc0+i);
                wrd(str2[i]);       
        }
}

void data_pros()        //數據處理函數
{
        uint8 i;              
        uint8 temp_buf[2],humi_buf[2];
        uint8 temphbuf[2],templbuf[2],humihbuf[2],humilbuf[2];
        float dio;
        uint16 k;

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

        humi_buf[0]=humi/10+0x30;       
        humi_buf[1]=humi%10+0x30;
       
        dio=a*0.0625;
        k=dio*10000;//取小數點后兩位有效數字

        temphbuf[0]=temph/10+0x30;
        temphbuf[1]=temph%10+0x30;
        templbuf[0]=templ/10+0x30;
        templbuf[1]=templ%10+0x30;

        humihbuf[0]=humih/10+0x30;
        humihbuf[1]=humih%10+0x30;
        humilbuf[0]=humil/10+0x30;
        humilbuf[1]=humil%10+0x30;

        if(mode==0)
        {
                lcd_init_display();
                wrc(0x85);
                wrd(num[tempvalue%100/10]);
                wrd(num[tempvalue%100%10]);
                wrd('.');
                wrd(num[k/1000]);
                wrd(0xdf);
                wrd('C');
       
                for(i=0;i<2;i++)
                {
                        wrc(0Xc5+i);
                        wrd(humi_buf[i]);                  
                }       
                for(i=0;i<3;i++)
                {
                        wrc(0Xc7+i);
                        wrd(str5[i]);                  
                }       
        }
        if(mode==1)                          //溫度上限顯示
        {
                wrc(0x80);
                for(i=0;i<6;i++)
                {
                        wrd(str6[i]);                  
                }
                wrd(temphbuf[0]);
                wrd(temphbuf[1]);                       
        }
        if(mode==2)                          //溫度下限顯示
        {
                wrc(0x80);
                for(i=0;i<6;i++)
                {
                        wrd(str7[i]);                  
                }
                wrd(templbuf[0]);
                wrd(templbuf[1]);                       
        }
        if(mode==3)                          //濕度上限顯示
        {
                wrc(0x80);
                for(i=0;i<6;i++)
                {
                        wrd(str8[i]);                  
                }
                wrd(humihbuf[0]);
                wrd(humihbuf[1]);                       
        }
        if(mode==4)                          //濕度下限顯示
        {
                wrc(0x80);
                for(i=0;i<6;i++)
                {
                        wrd(str9[i]);                  
                }
                wrd(humilbuf[0]);
                wrd(humilbuf[1]);                       
        }
}

void baojinpros()        //報警處理
{
        if(tempvalue>=temph||humi>=humih)         //檢測溫度或者濕度高于設定上限值 降溫濕
        {
                led1=1;                //降溫濕指示燈
                led2=0;
        }
        if(tempvalue<=templ||humi<=humil)        //檢測溫度或者濕度低于設定下限值  升溫濕
        {
                led1=0;
                led2=1;           //升高溫濕指示燈
        }
        if((tempvalue>templ&&tempvalue<temph)&&(humi>humil&&humi<humih))
        {
                led1=0;
                led2=0;       
        }
}

void main()
{
        uint8 i=0;
        led1=0;
        led2=0;
        lcd_init();
        while(DHT11_Init())        //檢測DHT11是否純在
        {
                for(i=0;i<5;i++)
                {
                        wrc(0x80+i);
                        wrd(str3[i]);       
                }                       
        }
        wrc(0x01);
        lcd_init_display();           //LCD初始化顯示
        i=0;
        while(1)
        {       
                i++;
                key_pros();
                baojinpros();        //報警處理
                if(i==15)
                {
                        i=0;
                        data_pros();           //讀取一次DHT11數據最少要大于100ms
                }
                delay(1000);
               
        }       
}


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

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 亚洲午夜久久久 | 噜啊噜在线 | 亚洲日本中文 | 91精品中文字幕一区二区三区 | 国产福利资源在线 | 蜜臀网 | 国产美女视频 | 精品一区二区在线观看 | 九九热精品视频 | www久久久| 精品久久成人 | 亚洲精品一 | 亚洲国产成人精品女人久久久 | www.黄色在线观看 | 国产成人免费一区二区60岁 | 成人午夜免费福利视频 | 色接久久 | a级大片免费观看 | 日本一区二区三区在线观看 | 狠狠操狠狠干 | 91高清免费 | 国产日韩欧美二区 | 狠狠夜夜 | 成人欧美一区二区三区黑人孕妇 | 国产精品精品视频一区二区三区 | 日本午夜网 | 日韩精品专区在线影院重磅 | 国产黄色精品 | 天天操天天射天天舔 | 欧美在线日韩 | 精品99久久久久久 | 99视频免费在线观看 | 成人在线视频观看 | 黄色大片免费网站 | 久久精品免费 | 日韩欧美在线一区 | 美女在线视频一区二区三区 | 久久综合色综合 | 精品无码久久久久久国产 | 日韩黄色小视频 | 久操伊人 |