dht11传感器可用来进行采集周围的温湿度数据,之前使用stm32 m0以及m3的板子都有对其进行驱动,使用esp8266 sdk开发也驱动过
现在使用的是esp32,对dht11进行数据采集
dht11有三个引脚,分别是GND,VCC,DATA
DATA接ESP32的IO4引脚
程序代码如下
#include <stdio.h>
#include "esp_system.h"
#include "esp_spi_flash.h"
#include "esp_wifi.h"
#include "esp_event_loop.h"
#include "esp_log.h"
#include "esp_err.h"
#include "nvs_flash.h"
#include "freertos/FreeRTOS.h"
#include "freertos/task.h"
#include "driver/ledc.h"
#include <stdio.h>
#include "driver/uart.h"
#include "driver/gpio.h"
#include "string.h"
#define DHT11_PIN 4//定义DHT11的引脚
#define uchar unsigned char
#define uint8 unsigned char
#define uint16 unsigned short
//温湿度定义
uchar ucharFLAG,uchartemp;
uchar Humi,Humi_small,Temp,Temp_small;
uchar ucharT_data_H,ucharT_data_L,ucharRH_data_H,ucharRH_data_L,ucharcheckdata;
uchar ucharT_data_H_temp,ucharT_data_L_temp,ucharRH_data_H_temp,ucharRH_data_L_temp,ucharcheckdata_temp;
uchar ucharcomdata;
static void InputInitial(void)//设置端口为输入
{
gpio_pad_select_gpio(DHT11_PIN);
gpio_set_direction(DHT11_PIN, GPIO_MODE_INPUT);
}
static void OutputHigh(void)//输出1
{
gpio_pad_select_gpio(DHT11_PIN);
gpio_set_direction(DHT11_PIN, GPIO_MODE_OUTPUT);
gpio_set_level(DHT11_PIN, 1);
}
static void OutputLow(void)//输出0
{
gpio_pad_select_gpio(DHT11_PIN);
gpio_set_direction(DHT11_PIN, GPIO_MODE_OUTPUT);
gpio_set_level(DHT11_PIN, 0);
}
static uint8 getData()//读取状态
{
return gpio_get_level(DHT11_PIN);
}
//读取一个字节数据
static void COM(void) // 温湿写入
{
uchar i;
for(i=0;i<8;i++)
{
ucharFLAG=2;
//等待IO口变低,变低后,通过延时去判断是0还是1
while((getData()==0)&&ucharFLAG++) ets_delay_us(10);
ets_delay_us(35);//延时35us
uchartemp=0;
//如果这个位是1,35us后,还是1,否则为0
if(getData()==1)
uchartemp=1;
ucharFLAG=2;
//等待IO口变高,变高后,表示可以读取下一位
while((getData()==1)&&ucharFLAG++)
ets_delay_us(10);
if(ucharFLAG==1)
break;
ucharcomdata<<=1;
ucharcomdata|=uchartemp;
}
}
void Delay_ms(uint16 ms)
{
int i=0;
for(i=0; i<ms; i++){
ets_delay_us(1000);
}
}
void DHT11(void) //温湿传感启动
{
OutputLow();
Delay_ms(19); //>18MS
OutputHigh();
InputInitial(); //输入
ets_delay_us(30);
if(!getData())//表示传感器拉低总线
{
ucharFLAG=2;
//等待总线被传感器拉高
while((!getData())&&ucharFLAG++)
ets_delay_us(10);
ucharFLAG=2;
//等待总线被传感器拉低
while((getData())&&ucharFLAG++)
ets_delay_us(10);
COM();//读取第1字节,
ucharRH_data_H_temp=ucharcomdata;
COM();//读取第2字节,
ucharRH_data_L_temp=ucharcomdata;
COM();//读取第3字节,
ucharT_data_H_temp=ucharcomdata;
COM();//读取第4字节,
ucharT_data_L_temp=ucharcomdata;
COM();//读取第5字节,
ucharcheckdata_temp=ucharcomdata;
OutputHigh();
//判断校验和是否一致
uchartemp=(ucharT_data_H_temp+ucharT_data_L_temp+ucharRH_data_H_temp+ucharRH_data_L_temp);
if(uchartemp==ucharcheckdata_temp)
{
//校验和一致,
ucharRH_data_H=ucharRH_data_H_temp;
ucharRH_data_L=ucharRH_data_L_temp;
ucharT_data_H=ucharT_data_H_temp;
ucharT_data_L=ucharT_data_L_temp;
ucharcheckdata=ucharcheckdata_temp;
//保存温度和湿度
Humi=ucharRH_data_H;
Humi_small=ucharRH_data_L;
Temp=ucharT_data_H;
Temp_small=ucharT_data_L;
}
else
{
Humi=100;
Temp=100;
}
}
else //没用成功读取,返回0
{
Humi=0,
Temp=0;
}
OutputHigh(); //输出
}
void app_main()
{
char dht11_buff[50]={0};
while(1)
{
DHT11(); //读取温湿度
printf("Temp=%d.%d℃--Humi=%d.%d%%RH \r\n", Temp,Temp_small,Humi,Humi_small);
vTaskDelay(300); //延时300毫秒
}
}