DHT11温湿度传感器与单片机之间的通信文档格式.docx

上传人:b****5 文档编号:19357111 上传时间:2023-01-05 格式:DOCX 页数:10 大小:251.95KB
下载 相关 举报
DHT11温湿度传感器与单片机之间的通信文档格式.docx_第1页
第1页 / 共10页
DHT11温湿度传感器与单片机之间的通信文档格式.docx_第2页
第2页 / 共10页
DHT11温湿度传感器与单片机之间的通信文档格式.docx_第3页
第3页 / 共10页
DHT11温湿度传感器与单片机之间的通信文档格式.docx_第4页
第4页 / 共10页
DHT11温湿度传感器与单片机之间的通信文档格式.docx_第5页
第5页 / 共10页
点击查看更多>>
下载资源
资源描述

DHT11温湿度传感器与单片机之间的通信文档格式.docx

《DHT11温湿度传感器与单片机之间的通信文档格式.docx》由会员分享,可在线阅读,更多相关《DHT11温湿度传感器与单片机之间的通信文档格式.docx(10页珍藏版)》请在冰豆网上搜索。

DHT11温湿度传感器与单片机之间的通信文档格式.docx

1。

通讯过程如图1所示

图1

总线空闲状态为高电平,主机把总线拉低等待DHT11响应,主机把总线拉低必须大于18毫秒,保证DHT11能检测到起始信号.DHT11接收到主机的开始信号后,等待主机开始信号结束,然后发送80us低电平响应信号.主机发送开始信号结束后,延时等待20-40us后,读取DHT11的响应信号,主机发送开始信号后,可以切换到输入模式,或者输出高电平均可,总线由上拉电阻拉高.

图2

总线为低电平,说明DHT11发送响应信号,DHT11发送响应信号后,再把总线拉高80us,准备发送数据,每一bit数据都以50us低电平时隙开始,高电平的长短定了数据位是0还是1。

格式见下面图示。

如果读取响应信号为高电平,则DHT11没有响应,请检查线路是否连接正常.当最后一bit数据传送完毕后,DHT11拉低总线50us,随后总线由上拉电阻拉高进入空闲状态。

数字0信号表示方法如图4所示

图4

数字1信号表示方法。

如图5所示

图5

二实现电路(简易视图)

三编程思路

根据传感器的通信协议,首先由单片机通过I/O口主动产生要求的激发信号,然后将数据线的控制权交给传感器,接着单片机通过while语句不间断的检查I/O口的高低电平,从而达到对时序的正确把握,解析出准确的传输数据.

四程序代码

#include<

stc12c5a。

h〉

#defineucharunsignedchar

#defineuintunsignedint

sbitdat=P1^0;

sbitRS=P2^5;

//led

sbitRW=P2^6;

sbitE=P2^7;

//led使能端

voiddelay(intx)

inty,z;

for(y=0;

y〈x;

y++)

for(z=0;

z〈30;

z++);

voidledxieshuju(ucharshuju)//液晶屏写指令函数

RS=1;

RW=0;

P0=shuju;

delay

(1);

E=1;

delay

(1);

E=0;

//delay(5);

voidledxiezhiling(ucharzhiling)//led写指令函数

RS=0;

RW=0;

P0=zhiling;

E=1;

//delay(5);

}

voidledchushihua()//led初始化函数

{

E=0;

ledxiezhiling(0x38);

ledxiezhiling(0x0c);

ledxiezhiling(0x06);

ledxiezhiling(0x01);

}

voidkaishi()

dat=0;

delay(30);

dat=1;

voidxiangying()

{

while(dat==1);

while(dat==0);

 

ucharjieshou()

{

intk=128;

uchara=0;

intn=0;

inti,m;

while(dat==1);

for(i=7;

i〉=0;

i--)

n=0;

m=0;

while(dat==0);

while(dat==1)

n++;

if(n〉24&

&

m==0)

a=a+k;

m=1;

if(m==1)

break;

k=k/2;

returna;

voidxianshi(ucharx,intk)

inti,j,n;

i=x/100;

j=x/10%10;

n=x%10;

//ledxiezhiling(0x80+3*k);

//ledxieshuju(0x30+i);

ledxiezhiling(0x80+3*k+1);

ledxieshuju(0x30+j);

ledxiezhiling(0x80+3*k+2);

ledxieshuju(0x30+n);

voidxianshi2(ucharx,intk)

i=x/100;

n=x%10;

ledxiezhiling(0xc0+3*k);

ledxieshuju(0x30+i);

ledxiezhiling(0xc0+3*k+1);

ledxieshuju(0x30+j);

ledxiezhiling(0xc0+3*k+2);

ledxieshuju(0x30+n);

voidmain()

{

inti;

uchara[5];

ucharx;

ledchushihua();

delay(10000);

delay(10000);

while

(1)

a[0]=0;

a[1]=0;

a[2]=0;

a[3]=0;

a[4]=0;

kaishi();

xiangying();

a[0]=jieshou();

a[1]=jieshou();

a[2]=jieshou();

a[3]=jieshou();

a[4]=jieshou();

x=a[0]+a[1]+a[2]+a[3];

for(i=0;

i〈5;

i++)

xianshi(a[i],i);

xianshi2(x,0);

五实践效果图

六反思与总结

虽然对时序的编程在之前已做过不少,但是在这次实践中发现了不少新问题。

在编程思路正确的情况,我们还是花了2天的时间才把这个程序搞定.期间出过的错误有,在循环中忘了将变量归零的,也有将数据帧的高低位反过来接的。

同时在调试阶段中,没有透过现象看本质,盲目的修改,浪费了大量时间。

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 工程科技 > 兵器核科学

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1