单片机论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 77|回复: 1
收起左侧

单片机远程仓库湿度监测系统代码+Proteus仿真

[复制链接]
futao 发表于 2019-5-9 17:27 | 显示全部楼层 |阅读模式
基于51单片机和Proteus仿真的远程仓库湿度监测系统
仓库监控.png
#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;                        //接收的湿度的高位数据和低位数据
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上发送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;
}
//获得湿度数据
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个脉冲没数据
        {
                SCK=1;
                SCK=0;
        }
        for(i=4;i>0;i--)        //接收RH高4位数据
        {
                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位数据
        {
                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校验,就此结束)
}
//阶乘函数
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作为波特率发生器
        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);                                //复位
                STARTSHT11();                                //启动
                GETRH(0x05);                                //测湿度命令
                SCK=1;
                while(DATA);                        //ack为低成功,继续
                SCK=0;                                        //一直都为低
                DATA=1;
                while(DATA);                        //等待300毫秒
                READSHT11();
                write_GETRH(0x80+0x47);        //放第二行字符的位置
                COMPENSATIONSHT();                                //数值转换+显示
    putchar(0x02);
        }
}

全部资料51hei下载地址:
基于51单片机和Proteus仿真的远程仓库湿度监测系统.zip (67.69 KB, 下载次数: 4)
回复

使用道具 举报

榆林上校 发表于 2019-5-11 08:09 | 显示全部楼层
谢谢LZ的分享!收藏
回复

使用道具 举报

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

本版积分规则

QQ|手机版|小黑屋|单片机论坛 |51黑电子论坛5群 联系QQ:125739409;技术交流QQ群174280738

Powered by 单片机教程网

快速回复 返回顶部 返回列表