基于51单片机sht11温湿度传感器检测程序_第1页
基于51单片机sht11温湿度传感器检测程序_第2页
基于51单片机sht11温湿度传感器检测程序_第3页
基于51单片机sht11温湿度传感器检测程序_第4页
基于51单片机sht11温湿度传感器检测程序_第5页
已阅读5页,还剩8页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、-. z基于51单片机SHT11温湿度传感器检测程序(含电路图) 下面是原理图:下面是SHT11与MCU连接的典型电路:下面是源代码:#include #include /* 宏定义*/#define uint unsigned int#define uchar unsigned char#define noACK 0#define ACK 1#define STATUS_REG_W 0*06#define STATUS_REG_R 0*07#define MEASURE_TEMP 0*03#define MEASURE_HUMI 0*05#define RESET 0*1eenumTEMP,

2、HUMI;typedefunion/定义共用同类型 unsignedinti; floatf; value;/*位定义*/sbit lcdrs=P20;sbit lcdrw=P21;sbit lcden=P22;sbit SCK = P10;sbit DATA = P11;/* 变量定义*/uchar table2=SHT11 温湿度检测;uchar table3=温度为: ;uchar table4=湿度为:;uchar table5=.;uchar wendu6;uchar shidu6;/* 1ms延时函数*/voiddelay(intz) int*,y; for(*=z;*0;*-)

3、for(y=125;y0;y-);/* 50us延时函数*/voiddelay_50us(uint t) uint j; for(;t0;t-) for(j=19;j0;j-);/* 50ms延时函数*/voiddelay_50ms(uint t) uint j; for(;t0;t-) for(j=6245;j0;j-);/* 12864液晶写指令*/voidwrite_12864(uchar ) lcdrs=0; delay_50us(1); P0=; lcden=1; delay_50us(10); lcden=0; delay_50us(2);/* 12864液晶写数据*/ voidw

4、rite_dat(uchar dat) lcdrs=1; lcdrw=0; delay_50us(1); P0=dat; lcden=1; delay_50us(10); lcden=0; delay_50us(2); /* 12864液晶初始化*/voidinit12864lcd(void) delay_50ms(2); write_12864(0*30); delay_50us(4); write_12864(0*30); delay_50us(4); write_12864(0*0f); delay_50us(4); write_12864(0*01); delay_50us(240);

5、 write_12864(0*06); delay_50us(10); write_12864(0*0c); delay_50us(10); /* 12864液晶显示函数*/ voiddisplay1(void) uchar i; write_12864(0*80); for(i=0;i18;i+) write_dat(table2i); delay_50us(1); /* 12864液晶显示函数*/ voiddisplay2(void) uchar i; write_12864(0*90); for(i=0;i18;i+) write_dat(table3i); delay_50us(1);

6、 /* 12864液晶显示函数*/ voiddisplay3(void) uchar i; write_12864(0*88); for(i=0;i8;i+) write_dat(table4i); delay_50us(1); /* 12864液晶显示函数*/ voiddisplaywendu(void) uchar i; write_12864(0*94); for(i=0;i3;i+) write_dat(wendui); delay_50us(1); for(i=0;i1;i+) write_dat(table5i); delay_50us(1); for(i=4;i5;i+) wri

7、te_dat(wendui); delay_50us(1); /* 12864液晶显示函数*/voiddisplayshidu(void) uchar i; write_12864(0*8C); for(i=0;i3;i+) write_dat(shidui); delay_50us(1); for(i=0;i1;i+) write_dat(table5i); delay_50us(1); for(i=4;i0;i=1)/高位为1,循环右移 if(i&value) DATA=1;/和要发送的数相与,结果为发送的位 elseDATA=0; SCK=1; _nop_();_nop_();_nop_

8、();/延时3us SCK=0; DATA=1;/释放数据线 SCK=1; error=DATA;/检查应答信号,确认通讯正常 _nop_();_nop_();_nop_(); SCK=0; DATA=1; returnerror;/error=1 通讯错误/* SHT11读字节程序*/chars_read_byte(unsignedcharack) unsignedchari,val=0; DATA=1;/释放数据线 for(i=0*80;i0;i=1)/高位为1,循环右移 SCK=1; if(DATA) val=(val|i);/读一位数据线的值 SCK=0; DATA=!ack;/如果是

9、校验,读取完后完毕通讯 ; SCK=1; _nop_();_nop_();_nop_();/延时3us SCK=0; _nop_();_nop_();_nop_(); DATA=1;/释放数据线 returnval;/* SHT11启动传输*/voids_transstart(void) DATA=1; SCK=0;/准备 _nop_(); SCK=1; _nop_(); DATA=0; _nop_(); SCK=0; _nop_();_nop_();_nop_(); SCK=1; _nop_(); DATA=1; _nop_(); SCK=0;/* SHT11连接复位*/voids_conn

10、ectionreset(void) unsignedchari; DATA=1; SCK=0;/准备 for(i=0;i9;i+)/DATA保持高,SCK时钟触发9次,发送启动传输,通迅即复位 SCK=1; SCK=0; s_transstart();/启动传输/* SHT11温湿度检测*/chars_measure(unsignedchar*p_value, unsignedchar*p_checksum, unsignedcharmode) unsigned error=0; unsignedinti; s_transstart();/启动传输 switch(mode)/选择发送命令 ca

11、seTEMP : error+=s_write_byte(MEASURE_TEMP);break;/测量温度 caseHUMI : error+=s_write_byte(MEASURE_HUMI);break;/测量湿度 default:break; for(i=0;i100)rh_true=100;/湿度最大修正 if(rh_true0.1)rh_true=0.1;/湿度最小修正 *p_temperature=t_C;/返回温度结果 *p_humidity=rh_true;/返回湿度结果/*主函数*/voidmain(void) unsignedinttemp,humi; value hu

12、mi_val,temp_val;/定义两个共同体,一个用于湿度,一个用于温度 unsignedcharerror;/用于检验是否出现错误 unsignedcharchecksum;/CRC init12864lcd(); display1(); display2(); display3(); s_connectionreset();/启动连接复位 while(1) error=0;/初始化error=0,即没有错误 error+=s_measure(unsignedchar*)&temp_val.i,&checksum,TEMP);/温度测量 error+=s_measure(unsigned

13、char*)&humi_val.i,&checksum,HUMI);/湿度测量 if(error!=0) s_connectionreset();/如果发生错误,系统复位 else humi_val.f=(float)humi_val.i;/转换为浮点数 temp_val.f=(float)temp_val.i;/转换为浮点数 calc_sth10(&humi_val.f,&temp_val.f);/修正相对湿度及温度 temp=temp_val.f*10; humi=humi_val.f*10; wendu0=temp/1000+0;/温度百位 wendu1=temp%1000/100+0;/温度十位wendu2=temp%100/10+0;/温度个位 wendu3=0*2E;/小数点 wendu4=temp%10+0;/温度小数点后第一位 displaywendu(); sh

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论