|
基于51單片機(jī)和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進(jìn)行讀操作
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的補(bǔ)償算法
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單片機(jī)和Proteus仿真的遠(yuǎn)程倉庫濕度監(jiān)測系統(tǒng).zip
(67.69 KB, 下載次數(shù): 26)
2019-5-9 17:26 上傳
點(diǎn)擊文件名下載附件
|
|