找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

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

單片機遠(yuǎn)程倉庫濕度監(jiān)測系統(tǒng)代碼+Proteus仿真

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
ID:517871 發(fā)表于 2019-5-9 17:27 | 只看該作者 |只看大圖 回帖獎勵 |倒序瀏覽 |閱讀模式
基于51單片機和Proteus仿真的遠(yuǎn)程倉庫濕度監(jiān)測系統(tǒng)

#include <AT89X52.h>
#include <intrins.h>
#include <stdio.h>

sbit SCK=P2^4;
sbit DATA=P2^5;
sbit LCD_RS=P2^0;
sbit LCD_EN=P2^2;


unsigned char RH_H,RH_L;                        //接收的濕度的高位數(shù)據(jù)和低位數(shù)據(jù)
unsigned int i,j;
unsigned char dispbuf[4];


void delay(unsigned int z)
{
        unsigned int x,y;
        for(x=z;x>0;x--)
                for(y=110;y>0;y--);
}
void write_GETRH(unsigned char GETRH)
{
        LCD_RS=0;
        P0=GETRH;
        delay(1);
        LCD_EN=1;
        delay(1);
        LCD_EN=0;
}

void write_DATA(unsigned char *date)
{
        unsigned char n;
        for(n=0;n<0x40;n++)
        {
                if(date[n]=='*')break;                //檢測,如果字符輸入"*",就終止
                LCD_RS=1;
                P0=date[n];
                delay(5);
                LCD_EN=1;
                delay(5);
                LCD_EN=0;
        }
}

void init()
{
        LCD_EN=0;
        write_GETRH(0x38);
        write_GETRH(0x0c);
        write_GETRH(0x06);
        write_GETRH(0x01);
}

//在SCK上發(fā)送n個脈沖信號
void nSCKPulse(unsigned int n)                        
{
        for(i=n;i>0;i--)
        {
                SCK=0;
                SCK=1;
        }
}
//啟動SHT11
void STARTSHT11()                                       
{
        SCK=1;
        DATA=0;
        SCK=0;
        SCK=1;
        DATA=1;
        SCK=0;
}
//獲得濕度數(shù)據(jù)
void GETRH(unsigned char GETRH)                                //測量濕度
{
        unsigned char bei=0x80;
        DATA=1;
        SCK=0;        //下面可以開始
        for(i=8;i>0;i--)
        {
                if(GETRH&bei)
                {
                        DATA=1;
                        SCK=1;
                        SCK=0;
                }
                else
                {
                        DATA=0;
                        SCK=1;
                        SCK=0;
                }
                bei=bei/2;
        }
}
//對SHT11進行讀操作
void READSHT11()                                                
{
        unsigned char temp;
        RH_H=0;
        RH_L=0;
        for(i=0;i<4;i++)        //4個脈沖沒數(shù)據(jù)
        {
                SCK=1;
                SCK=0;
        }
        for(i=4;i>0;i--)        //接收RH高4位數(shù)據(jù)
        {
                SCK=1;
                temp=0x01;
                if(DATA==1)
                {
                        temp=(temp<<(i-1));        //右移動
                        RH_H=RH_H+temp;        
                }
                SCK=0;
        }
        DATA=0;                                //拉低
        SCK=1;
        SCK=0;
        DATA=1;                                //釋放
        for(i=8;i>0;i--)        //接收RH低4位數(shù)據(jù)
        {
                SCK=1;
                temp=0x01;
                if(DATA==1)
                {
                        temp=(temp<<(i-1));        //右移動
                        RH_L=RH_L+temp;        
                }
                SCK=0;
        }
        P1=RH_H;
        P3=RH_L;
        DATA=0;                                //拉低
        SCK=1;
        SCK=0;
        DATA=1;                                //釋放(不做CRC校驗,就此結(jié)束)
}
//階乘函數(shù)
long FACTORIAL(int n)
{        
        long nn=1;
        for(;n>0;n--)
        {
                nn=10*nn;
        }
        return(nn);
}
//SHT11的補償算法
void COMPENSATIONSHT()                                       
{
        unsigned long ii;
        char m;
        ii=((((RH_H*256+RH_L)-221)*318878)/100000);

        if(ii>5000)
        {
                ii=ii+((10000-ii)*620/5000);
        }
        else
        {
                ii=ii+ii*620/5000;
        }
//  printf("%f\n",ii);
        for(m=4;m>=0;m--)
        {
                if(m==1)
                {
                        write_DATA(".*");
                }
                LCD_RS=1;
                P0=(int)(ii/FACTORIAL(m))+0x30;
                if(m==4&P0==0x30)
                {
                        P0=0x20;
                }
                if(m==4&P0==0x31)
                {
                        write_DATA("100.00*");
                        break;
                }
                if(m==3&P0==0x30)
                {
                        P0=0x20;
                }
                delay(5);
                LCD_EN=1;
                delay(5);
                LCD_EN=0;
                ii=ii-((int)(ii/FACTORIAL(m)))*FACTORIAL(m);
        }
        write_DATA("%*");
}

void InitUart(void)
{
        SCON = 0x50;                                  //工作方式1
        TMOD = 0x21;
        PCON = 0x00;
        TH1 = 0xfd;                                   //使用T1作為波特率發(fā)生器
        TL1 = 0xfd;
        TI = 1;
        TR1 = 1;                                      //啟動T1                                                //啟動T1  
}
void main()
{                  
        init();
  InitUart();
        write_GETRH(0x80+0x03);                        //放第一行字符的位置
        write_DATA("Humidity*");
        write_GETRH(0x80+0x42);                        //放第二行字符的位置
        write_DATA("%RH*");
        while(1)
        {
                nSCKPulse(10);                                //復(fù)位
                STARTSHT11();                                //啟動
                GETRH(0x05);                                //測濕度命令
                SCK=1;
                while(DATA);                        //ack為低成功,繼續(xù)
                SCK=0;                                        //一直都為低
                DATA=1;
                while(DATA);                        //等待300毫秒
                READSHT11();
                write_GETRH(0x80+0x47);        //放第二行字符的位置
                COMPENSATIONSHT();                                //數(shù)值轉(zhuǎn)換+顯示
    putchar(0x02);
        }
}

全部資料51hei下載地址:
基于51單片機和Proteus仿真的遠(yuǎn)程倉庫濕度監(jiān)測系統(tǒng).zip (67.69 KB, 下載次數(shù): 26)
分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復(fù)

使用道具 舉報

沙發(fā)
ID:47652 發(fā)表于 2019-5-11 08:09 | 只看該作者
謝謝LZ的分享!收藏
回復(fù)

使用道具 舉報

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

本版積分規(guī)則

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

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

快速回復(fù) 返回頂部 返回列表