dht11的c语言程序.docxVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
dht11的c语言程序

#includereg51.h #define uint unsigned int #define uchar unsigned char sbit TRH = P1^0;//温湿度传感器DHT11数据接入uchar str[]={0,0,0,0,0,0,0,0};uint TH,TL,RH,RL,CK; uint THc,TLc,RHc,RLc,CKc; uint xh,sum; // void delay(uchar s) //延时10us// {// uchar v;// for(;s0;s--)// for(v=25;v0;v--);// } void delay(uchar b) //误差 0us{ unsigned char a; for(;b0;b--) for(a=2;a0;a--);}//void delay1( )// 延时20ms//{ //uchar x,y,z;//for(x=15;x0;x--)//for(y=4;y0;y--)//for(z=248;z0;z--);//}void delay1(uchar c) //误差 0us{ unsigned char a,b; for(;c0;c--) for(b=142;b0;b--) for(a=2;a0;a--);}void delay2()//数码管显示用的延时{ uchar l,j,k;for(l=2;l0;l--)for(j=4;j0;j--)for(k=100;k0;k--);} void start() { TRH=1; delay(2); TRH=0; //主机拉低18ms delay1(20); TRH=1; //DATA总线由上拉电阻拉高主机延时20 delay(3); }uchar receive() { uchar i,temp; xh=0; while(TRH); for(i=0;i8;i++) { while(!TRH); delay(3); if(TRH) { temp=1;while(TRH);} else temp=0; xh=1; xh|=temp; } return (xh);} void display(){uchar a[]={0xC0,0xF9,0xA4,0xB0,0x99,0x92,0x82,0xF8,0x80,0x90};uchar m,n,s,i; m= str[3];//数码管显示部分 n= str[4]; s= str[5]; while(1) { for(i=0;i10;i++){ if(m==i) m=a[i]; } P0=m; P2=0x10; delay2(); for(i=0;i10;i++){ if(n==i) n=a[i]; } P0=n-0X80; P2=0x20; delay2(); for(i=0;i10;i++){ if(s==i) s=a[i]; } P0=s; P2=0x40;delay2(); P0=0X9C; P2=0x80; delay2();} } void main() { while(1) { start(); TRH=1; // 读取数据并写入指令 if(!TRH) { while(!TRH); //判断DHT11发出 80us 的低电平响应信号是否结束while(TRH);delay(8); RHc = receive(); //数据接收状态 RLc = receive(); THc = receive(); TLc = receive(); CKc = receive();} TRH=1; sum=(RHc+RLc+THc+TLc);//数据校验 if(sum==CKc) { RH = RHc; RL = RLc; TH= THc; TL = TLc; CK = CKc; str[0] =RH/10; //湿度整数部分 str[1] =RH%10; str[2] = RL/10 ; str[3] = TH/10; //温度整数部分 str[4] = TH%10; str[5] = TL/10; } display(); } }

文档评论(0)

xcs88858 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

版权声明书
用户编号:8130065136000003

1亿VIP精品文档

相关文档