DHT11驱动(STM32)

一、前期准备
单片机:STM32F103ZET6
开发环境:MDK5.14
库函数:标准库V3.5
DHT11模块:淘宝有售
在这里插入图片描述

二、实验效果
在这里插入图片描述
在这里插入图片描述

三、驱动原理
看数据手册。需要完整工程或者有问题的请加QQ:1002521871,验证:呵呵。

四、驱动代码
dht11.h

#ifndef __DHT11_H__
#define	__DHT11_H__
#include "stm32f10x.h"
#include "gpio.h"
#include "delay.h"

#define 	DHT_Direction_I  	{GPIOA->CRL &= 0XFFFFFFF0; GPIOA->CRL |= 8;}
#define 	DHT_Direction_O 	{GPIOA->CRL &= 0XFFFFFFF0; GPIOA->CRL |= 3;}
/*	IO Definitions	*/
#define		O_DHT_DAT		PAout(0)
#define		I_DHT_DAT		PAin(0)
#define		DHT_DAT_Pin		GPIO_Pin_0
#define    	DHTPORT         GPIOA
#define     DHTCLKLINE      RCC_APB2Periph_GPIOA

extern void DHT11Configuration(void);
extern uint8_t DHT11_IsOnline(void);
extern uint8_t DHT11_Read_Data(uint8_t *temp,uint8_t *humi);
#endif

ds1302.c

#include "dht11.h"
      
//复位DHT11
void DHT11_Reset(void)	   
{                 
	DHT_Direction_O; 	
    O_DHT_DAT = 0; 	
    DelayMs(20);    	
    O_DHT_DAT = 1; 	
	DelayUs(30);     
}

//等待DHT11的回应
//返回1:未检测到DHT11的存在
//返回0:存在
uint8_t DHT11_IsOnline(void) 	   
{   
	uint8_t retry = 0;
	DHT_Direction_I;
	
    while (I_DHT_DAT && retry < 100)//DHT11会拉低40~80us
	{
		retry ++;
		DelayUs(1);
	}
	
	if(retry >= 100)
	{
		return 1;
	}
	else
	{
		retry = 0;
	}
	
    while (!I_DHT_DAT && retry < 100)//DHT11拉低后会再次拉高40~80us
	{
		retry ++;
		DelayUs(1);
	}
	
	if(retry >= 100)
	{
		return 1;
	}	    
	return 0;
}

uint8_t DHT11_ReadBit(void) 			 
{
 	uint8_t retry = 0;
	while(I_DHT_DAT && retry < 100)
	{
		retry ++;
		DelayUs(1);
	}
	retry = 0;
	while(!I_DHT_DAT && retry < 100)
	{
		retry ++;
		DelayUs(1);
	}
	
	DelayUs(40);//等待40us
	
	if(I_DHT_DAT)
	{
		return 1;
	}
	else 
	{
		return 0;	
	}		
}


uint8_t DHT11_ReadByte(void)    
{        
    uint8_t i,dat;
    dat = 0;
	for (i = 0; i < 8; i ++) 
	{
   		dat <<= 1; 
	    dat |= DHT11_ReadBit();
    }						    
    return dat;
}

//从DHT11读取一次数据
//temp:温度值(范围:0~50°)
//humi:湿度值(范围:20%~90%)
//返回值:0,正常;1,读取失败
uint8_t DHT11_Read_Data(uint8_t *temp,uint8_t *humi)    
{        
 	uint8_t buf[5];
	uint8_t i;
	
	DHT11_Reset();
	
	if(DHT11_IsOnline() == 0)
	{
		for(i = 0; i < 5; i ++)//读取40位数据
		{
			buf[i] = DHT11_ReadByte();
		}
		if((buf[0] + buf[1] + buf[2] + buf[3]) == buf[4])
		{
			*humi = buf[0];
			*temp = buf[2];
		}
	}
	else 
	{
		return 1;
	}
	
	return 0;	    
}
 
void DHT11Configuration(void)
{	 
 	GPIO_InitTypeDef  MyGPIO;
 	
 	RCC_APB2PeriphClockCmd(DHTCLKLINE, ENABLE);	 
	
 	MyGPIO.GPIO_Pin 	= DHT_DAT_Pin;				 
 	MyGPIO.GPIO_Mode 	= GPIO_Mode_Out_PP; 		 
 	MyGPIO.GPIO_Speed 	= GPIO_Speed_50MHz;
 	GPIO_Init(DHTPORT, &MyGPIO);				 
	O_DHT_DAT = 1;		
			    
	DHT11_Reset();  //复位DHT11
} 

由于作者能力有限,有不妥之处欢迎指正,邮箱alex_hua@foxmail.com

  • 6
    点赞
  • 64
    收藏
    觉得还不错? 一键收藏
  • 10
    评论
驱动DHT11传感器,首先需要连接DHT11传感器到STM32的GPIO引脚上。然后,需要编写STM32代码来读取DHT11传感器的数据。 以下是一个简单的代码示例,可以读取DHT11传感器的数据: ```c #include "stm32f10x.h" #define DHT11_DATA_PIN GPIO_Pin_0 #define DHT11_DATA_PORT GPIOA void delay_us(uint32_t us) { // 延时函数,us为微秒数 uint32_t i; for (i = 0; i < us * 8; i++); } void DHT11_start() { // 发送起始信号 GPIO_InitTypeDef GPIO_InitStructure; GPIO_InitStructure.GPIO_Pin = DHT11_DATA_PIN; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP; GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; GPIO_Init(DHT11_DATA_PORT, &GPIO_InitStructure); GPIO_ResetBits(DHT11_DATA_PORT, DHT11_DATA_PIN); delay_us(18000); GPIO_SetBits(DHT11_DATA_PORT, DHT11_DATA_PIN); delay_us(20); GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING; GPIO_Init(DHT11_DATA_PORT, &GPIO_InitStructure); } uint8_t DHT11_read_bit() { // 读取一个位的数据 while(GPIO_ReadInputDataBit(DHT11_DATA_PORT, DHT11_DATA_PIN) == RESET); delay_us(40); if(GPIO_ReadInputDataBit(DHT11_DATA_PORT, DHT11_DATA_PIN) == SET) { while(GPIO_ReadInputDataBit(DHT11_DATA_PORT, DHT11_DATA_PIN) == SET); return 1; } else { return 0; } } uint8_t DHT11_read_byte() { // 读取一个字节的数据 uint8_t i, byte = 0; for (i = 0; i < 8; i++) { byte <<= 1; byte |= DHT11_read_bit(); } return byte; } uint8_t DHT11_read(uint8_t *humidity, uint8_t *temperature) { // 读取湿度数据 uint8_t data[5]; uint8_t i; DHT11_start(); if(GPIO_ReadInputDataBit(DHT11_DATA_PORT, DHT11_DATA_PIN) == RESET) { while(GPIO_ReadInputDataBit(DHT11_DATA_PORT, DHT11_DATA_PIN) == RESET); while(GPIO_ReadInputDataBit(DHT11_DATA_PORT, DHT11_DATA_PIN) == SET); for (i = 0; i < 5; i++) { data[i] = DHT11_read_byte(); } if(data[0] + data[1] + data[2] + data[3] == data[4]) { *humidity = data[0]; *temperature = data[2]; return 1; } else { return 0; } } else { return 0; } } int main(void) { uint8_t humidity, temperature; RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE); while(1) { if(DHT11_read(&humidity, &temperature)) { // 读取成功 } else { // 读取失败 } } } ``` 在这个代码示例中,首先定义了DHT11传感器的引脚和端口。然后,定义了一些辅助函数,如延时函数、发送起始信号和读取一个位数据等。最后,在主函数中循环读取DHT11传感器的湿度数据。 需要注意的是,DHT11传感器的数据读取需要严格按照一定的时间序列进行,否则可能会出现读取错误。因此,在编写代码时需要仔细调试和测试。
评论 10
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值