【51单片机STC89C52】DHT11温湿度传感器的使用

目录

 一、DHT11概述

数据传送逻辑

数据格式

通讯过程时序图

 二、检测模块是否存在

  时序逻辑分析

 代码实现

三、读取温湿度数据

DHT11传输0的时序分析

DHT11传输1的时序分析

代码实现

 四、串口打印


 一、DHT11概述

数据传送逻辑

        模块一次完整的数据传输为40bit,高位在前

数据格式

        8bit湿度整数数据+8bit 湿度小数数据 +8bi 温度整数数据 +8bit 温度小数数据 +8bit 校验和

通讯过程时序图

 二、检测模块是否存在

        根据如下时序图,做通信初始化,并检测模块是否存在,功能是否正常

  时序逻辑分析

a : dht = 1

b :dht = 0

延时至少18ms

c: dht = 1

卡d点:while(dht)

卡e点:while(!dht)

卡f点:while(dht)

 代码实现

void DHT11_Start()
{
	dht = 1;
	dht = 0;
	//延时30ms
	Delay30ms();
	dht = 1;
    //卡d点:while(dht);卡e点:while(!dht);卡f点:while(dht)
	while(dht);
	while(!dht);
	while(dht);
}

三、读取温湿度数据

DHT11传输0的时序分析

DHT11传输1的时序分析

 代码实现

char datas[5];

void Read_Data_From_DHT()
{
	int i;//轮
	int j;//每一轮读多少次
	char tmp;
	char flag;
	
	DHT11_Start();
	for(i=0;i<5;i++){      
		for(j=0;j<8;j++){
			while(!dht);//等待卡g点
			Delay40us();//有效数据都是高电平,持续时间不一样,40us读,低电平0 高电平1
			if(dht == 1){
				flag = 1;
				while(dht);
			}else{
				flag = 0;
			} 
			tmp = tmp << 1;
			tmp |= flag;
		}
		datas[i] = tmp;
	}
}

 四、串口打印

#include "reg52.h"
#include "intrins.h"

sbit ledOne = P3^7;
sbit dht = P3^3;//模块的data插在p3.3

char datas[5];

sfr AUXR = 0x8E;

void UartInit(void)		//9600bps@11.0592MHz
{
	AUXR = 0x01;
	SCON = 0x40; //配置串口工作方式1,REN不使能接收
	TMOD &= 0xF0;
	TMOD |= 0x20;//定时器1工作方式位8位自动重装
	
	TH1 = 0xFD;
	TL1 = 0xFD;//9600波特率的初值
	TR1 = 1;//启动定时器
}
void sendByte(char data_msg)
{
	SBUF = data_msg;
	while(!TI);
	TI = 0;
}

void sendString(char* str)
{
	while( *str != '\0'){
		sendByte(*str);
		str++;
	}
}

void Delay30ms()		//@11.0592MHz
{
	unsigned char i, j;

	i = 54;
	j = 199;
	do
	{
		while (--j);
	} while (--i);
}

void Delay40us()		//@11.0592MHz
{
	unsigned char i;

	_nop_();
	i = 15;
	while (--i);
}

void Delay1000ms()		//@11.0592MHz
{
	unsigned char i, j, k;

	_nop_();
	i = 8;
	j = 1;
	k = 243;
	do
	{
		do
		{
			while (--k);
		} while (--j);
	} while (--i);
}

void DHT11_Start()
{
	dht = 1;
	dht = 0;
	//延时30ms
	Delay30ms();
	dht = 1;
	//卡d点:while(dht1);卡e点:while(!dht);卡f点:while(dht)
	while(dht);
	while(!dht);
	while(dht);
}

void Read_Data_From_DHT()
{
	int i;//轮
	int j;//每一轮读多少次
	char tmp;
	char flag;
	
	DHT11_Start();
	for(i= 0;i < 5;i++){
		for(j=0;j<8;j++){
			while(!dht);//等待卡g点
			Delay40us();//有效数据都是高电平,持续时间不一样,40us读,低电平0 高电平1
			if(dht == 1){
				flag = 1;
				while(dht);
			}else{
				flag = 0;
			} 
			tmp = tmp << 1;
			tmp |= flag;
		}
		datas[i] = tmp;
	}
}

void main()
{
	ledOne = 1;
	UartInit();
	Delay1000ms();
	Delay1000ms();
	while(1){
		Delay1000ms();
		Read_Data_From_DHT();	
		sendString("H:");             //湿度
		sendByte(datas[0]/10 + 0x30);
		sendByte(datas[0]%10 + 0x30);
		sendByte('.');
		sendByte(datas[1]/10 + 0x30);
		sendByte(datas[1]%10 + 0x30);	
		sendString("\r\n");	
		sendString("T:");             //温度
		sendByte(datas[2]/10 + 0x30);
		sendByte(datas[2]%10 + 0x30);	
		sendByte('.');
		sendByte(datas[3]/10 + 0x30);
		sendByte(datas[3]%10 + 0x30);			
		sendString("\r\n");	
        //湿度小数部分为0;温度小数部分只能显示十进制1位,需修改代码
	}
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值