DHT11温湿度传感器与单片机之间的通信文档格式.docx
《DHT11温湿度传感器与单片机之间的通信文档格式.docx》由会员分享,可在线阅读,更多相关《DHT11温湿度传感器与单片机之间的通信文档格式.docx(10页珍藏版)》请在冰豆网上搜索。
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天的时间才把这个程序搞定.期间出过的错误有,在循环中忘了将变量归零的,也有将数据帧的高低位反过来接的。
同时在调试阶段中,没有透过现象看本质,盲目的修改,浪费了大量时间。