- 1、本文档共6页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
和电脑通信的温湿度传感器c程序
#includereg52.h
#includeintrins.h
#includestdio.h
typedef unsigned char uchar;
typedef unsigned int uint;
void unit();
void delay2ms(uint M);
void delay2xus(uchar m);
uchar read_onebyte();
void Read();
void write_com(uchar com);
void write_data(uchar D);
void LCD1602_unit(); //初始化lcd1602
void LCD1602_display();
void uart_unit();
void sent_byte();
uchar DATA[5];
sbit led=P0^3;
sbit led3=P0^0;
uchar D=1;
sbit DQ=P2^7;
sbit lcd_rs=P3^3;
sbit lcd_rw=P3^4;
sbit lcd_en=P3^5;
uchar RH_H,RH_L,T_H,T_L,CHECK;
float RH,T;
/*---------------------微秒延时函数--------------------------------------*/
void delay2xus(uchar m)
{while(--m);
}
/*--------------------毫秒延时函数---------------------------------------*/
void delay2ms(uint M)
{
uint i,j,k;
for(k=0;kM;++k)
{for(i=0;i9;i++)
{for(j=0;j32;j++);
}
}
}
/*--------------------------DHT11初始化函数---------------------------*/
void unit()
{ led3=1;
led3=0;
DQ=1;
DQ=0;
delay2ms(12);
DQ=1;
delay2xus(12); //检测DHT11响应信号是否开始
while(DQ); //DQ=1时跳过
while(!DQ); //检测DHT11响应信号是否结束
while(DQ);
led3=1; //检测DHT11的发送bite开始信号是否开始
}
/*---------------------读一个字节函数-----------------------------------*/
uchar read_onebyte()
{ uchar i;
uchar flag;
uchar byte=0x00;
for(i=0;i8;i++)
{ while(DQ);
byte=byte=1;
while(!DQ); //检测数据信号,即高电平
delay2xus(17); //区分开1信号和0信号
if(DQ)
flag=1;
else
flag=0;
byte=byte|flag; //若DQ是高电平,就是1信号,是低电平就是0信号
}
return byte; //返回8位数据
}
/*-------------------------------读DHT11数据函数------------------------------*/
void Read()
{
uchar j,total;
//检测数据是否正确指示灯
for(j=0;j5;j++)
{ led=0;
DATA[j]=read_onebyte();} //按协议顺序,DATA[0]为湿整,DATA[1]为湿小,DATA[2]为温整,DATA[3]为温小
RH_H=DATA[0];
RH_L=DATA[1];
T_H=DATA[2];
T_L=DATA[3];
CHECK=DATA[4];
total=RH_H+RH_L+T_H+T_L;
if(CHECK==total ); //检测数据是否正确
else
led=1; //检测数据是否正确指数灯
}
/*------------------------------LCD写指令函数--------------------------------------------*/
void write_com(uchar com)
{
lcd_rs=0; //声明是指令
P1=com;
delay2ms(5);
lcd_en=1
文档评论(0)