STM32F411 标准库驱动DTH11温湿度传感器 PC13关闭入侵检测模式作普通IO使用

DTH11是一个使用单总线驱动的温湿度传感器,此demo用到的是PC13引脚连接到传感器的OUT引脚进行获取温湿度数据,由于PC13默认作为RTC的入侵检测功能引脚,在作为普通IO口使用时需要额外的配置才能正常使用。

还有一点需要注意的是,STM32F4的库函数中寄存器BSRRL、BSRRH用于控制IO的高低电平时,是反过来的,这一点导致了我在刚开始的时候一直无法正常获取数据,以为是延时不够精确的问题,这一点希望大家注意!!!

#define dht11_high    {dht11_GPIO_PORT->BSRRL=dht11_PIN;}
#define dht11_low     {dht11_GPIO_PORT->BSRRH=dht11_PIN;}
#include "dth11.h"
#include "delay.h"

//数据
unsigned int rec_data[4];
	

void DH11_GPIO_Init_IN()
{
	GPIO_InitTypeDef GPIO_InitStructure;
	RCC_AHB1PeriphClockCmd (dht11_GPIO_CLK, ENABLE);
	RCC_APB1PeriphClockCmd(RCC_APB1Periph_PWR, ENABLE);
	PWR_BackupAccessCmd( ENABLE );/* 允许修改RTC和后备寄存器*/
    RTC_TamperCmd(RTC_Tamper_1, DISABLE);
	// 配置 GPIO 引脚模式为输入
	GPIO_InitStructure.GPIO_Pin = dht11_PIN;
	GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN;
	GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_NOPULL;  
	GPIO_Init(dht11_GPIO_PORT, &GPIO_InitStructure);
	PWR_BackupAccessCmd(DISABLE);/* 禁止修改RTC和后备寄存器*/
}

void DH11_GPIO_Init_OUT() 
{
	GPIO_InitTypeDef GPIO_InitStructure;
	RCC_AHB1PeriphClockCmd (dht11_GPIO_CLK, ENABLE);
	RCC_APB1PeriphClockCmd(RCC_APB1Periph_PWR, ENABLE);
	PWR_BackupAccessCmd( ENABLE );/* 允许修改RTC和后备寄存器*/
    RTC_TamperCmd(RTC_Tamper_1, DISABLE);
	GPIO_InitStructure.GPIO_Pin = dht11_PIN;
	GPIO_InitStructure.GPIO_Speed = GPIO_Speed_2MHz;
	GPIO_InitStructure.GPIO_Mode = GPIO_Mode_OUT;
	GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;
	GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_NOPULL;  
	GPIO_Init(dht11_GPIO_PORT, &GPIO_InitStructure);
	PWR_BackupAccessCmd(DISABLE);/* 禁止修改RTC和后备寄存器*/
}

//主机发送开始信号
void DHT11_Start(void)
{
	DH11_GPIO_Init_OUT(); //输出模式
	
	dht11_high; //先拉高
	delay_us(30);
	
	dht11_low; //拉低电平至少18us
	delay_ms(20);
	
	dht11_high; //拉高电平20~40us
	delay_us(30);
	
	DH11_GPIO_Init_IN(); //输入模式
}


//获取一个字节
char DHT11_Rec_Byte(void)
{
	unsigned char i = 0;
	unsigned char data;
	
	for(i=0;i<8;i++) //1个数据就是1个字节byte,1个字节byte有8位bit
	{
		while( Read_Data == 0); //从1bit开始,低电平变高电平,等待低电平结束
		delay_us(30); //延迟30us是为了区别数据0和数据1,0只有26~28us
		
		data <<= 1; //左移
		
		if( Read_Data == 1 ) //如果过了30us还是高电平的话就是数据1
		{
			data |= 1; //数据+1
		}
		
		while( Read_Data == 1 ); //高电平变低电平,等待高电平结束
	}
	
	return data;
}

//获取数据

void DHT11_REC_Data(void)
{
	unsigned int R_H,R_L,T_H,T_L;
	unsigned char RH,RL,TH,TL,CHECK;
	char buf[20];
	
	DHT11_Start(); //主机发送信号
	dht11_high; //拉高电平
	
	if( Read_Data == 0 ) //判断DHT11是否响应
	{
		while( Read_Data == 0); //低电平变高电平,等待低电平结束
		while( Read_Data == 1); //高电平变低电平,等待高电平结束
		
		R_H = DHT11_Rec_Byte();
		R_L = DHT11_Rec_Byte();
		T_H = DHT11_Rec_Byte();
		T_L = DHT11_Rec_Byte();
		CHECK = DHT11_Rec_Byte(); //接收5个数据
		
		dht11_low; //当最后一bit数据传送完毕后,DHT11拉低总线 50us
		delay_us(55); //这里延时55us
		dht11_high; //随后总线由上拉电阻拉高进入空闲状态。
		
		if(R_H + R_L + T_H + T_L == CHECK) //和检验位对比,判断校验接收到的数据是否正确
		{
			RH = R_H;
			RL = R_L;
			TH = T_H;
			TL = T_L;
		}
	}
	rec_data[0] = RH;
	rec_data[1] = RL;
	rec_data[2] = TH;
	rec_data[3] = TL;
	
	sprintf(buf, "Temp = %d", rec_data[2]);
	//sprintf(buf, "Temp = %d",0);
	Gui_DrawFont_GBK16(20,30,BLUE,GRAY0, buf);
	memset(buf, 0, sizeof(buf));
	sprintf(buf, "Humi = %d", rec_data[0]);
	Gui_DrawFont_GBK16(20,80,BLUE,GRAY0, buf);
	memset(buf, 0, sizeof(buf));
}

#ifndef _DTH11_H_
#define _DTH11_H_

#include "main.h"

#define dht11_PIN                       GPIO_Pin_13         
#define dht11_GPIO_PORT                 GPIOC                     
#define dht11_GPIO_CLK                  RCC_AHB1Periph_GPIOC

#define dht11_high    {dht11_GPIO_PORT->BSRRL=dht11_PIN;}
#define dht11_low     {dht11_GPIO_PORT->BSRRH=dht11_PIN;}
#define Read_Data  	  GPIO_ReadInputDataBit(dht11_GPIO_PORT, dht11_PIN)

void DHT11_GPIO_Init_OUT(void);
void DHT11_GPIO_Init_IN(void);
void DHT11_Start(void);
unsigned char DHT11_REC_Byte(void);
void DHT11_REC_Data(void);




#endif

delay.c

#include "delay.h" 

static u8  fac_us=0;//us延时倍乘数
static u16 fac_ms=0;//ms延时倍乘数
//初始化延迟函数
//SYSTICK的时钟固定为HCLK时钟的1/8
//SYSCLK:系统时钟
void delay_init(u8 SYSCLK)
{
	SysTick->CTRL&=0xfffffffb;//bit2清空,选择外部时钟  HCLK/8
	fac_us=SYSCLK/8;		    
	fac_ms=(u16)fac_us*1000;
}								    
//延时nms
//注意nms的范围
//SysTick->LOAD为24位寄存器,所以,最大延时为:
//nms<=0xffffff*8*1000/SYSCLK
//SYSCLK单位为Hz,nms单位为ms
//对72M条件下,nms<=1864 
void delay_ms(u16 nms)
{	 		  	  
	u32 temp;		   
	SysTick->LOAD=(u32)nms*fac_ms;//时间加载(SysTick->LOAD为24bit)
	SysTick->VAL =0x00;           //清空计数器
	SysTick->CTRL=0x01 ;          //开始倒数  
	do
	{
		temp=SysTick->CTRL;
	}
	while(temp&0x01&&!(temp&(1<<16)));//等待时间到达   
	SysTick->CTRL=0x00;       //关闭计数器
	SysTick->VAL =0X00;       //清空计数器	  	    
}   
//延时nus
//nus为要延时的us数.		    								   
void delay_us(u32 nus)
{		
	u32 temp;	    	 
	SysTick->LOAD=nus*fac_us; //时间加载	  		 
	SysTick->VAL=0x00;        //清空计数器
	SysTick->CTRL=0x01 ;      //开始倒数 	 
	do
	{
		temp=SysTick->CTRL;
	}
	while(temp&0x01&&!(temp&(1<<16)));//等待时间到达   
	SysTick->CTRL=0x00;       //关闭计数器
	SysTick->VAL =0X00;       //清空计数器	 
}
#ifndef __DELAY_H
#define __DELAY_H 		

#include "main.h"

void delay_init(u8 SYSCLK);
void delay_ms(u16 nms);
void delay_us(u32 nus);

#endif

  • 5
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: DHT11湿度传感器是一种数字化的湿度传感器,可与STM32单片机相连并进行数据的采集和处理。以下是关于DHT11湿度传感器STM32程序下载的说明。 1. 首先,需要准备一台已安装STM32开发环境的计算机。这个开发环境可以是Keil、IAR等常用的嵌入式开发工具。 2. 接下来,需要根据具体的硬件连接情况,将DHT11传感器与STM32单片机相连。一般来说,DHT11传感器的供电线连接到STM32的供电引脚上,数据线连接到STM32的某个IO口,接地线连接到STM32的接地引脚上。 3. 然后,打开STM32开发环境,创建一个新的工程用于DHT11湿度传感器程序的开发。选择适合自己的芯片型号,配置相应的系统时钟等参数。 4. 根据DHT11的通信协议,编写相应的程序代码。代码中需要使用STM32IO口来读取传感器的数据,将数据转换为度和湿度值,并进行相应的处理。 5. 在代码编写完成后,进行编译和链接,并生成可执行文件。将可执行文件下载到STM32单片机上,可以通过JTAG/SWD等调试工具来完成下载。 6. 最后,将STM32与已下载的程序电路连接好,给STM32供电,开始进行测试。通过使用串口调试助手或者LCD屏幕来显示度和湿度数据,以验证程序的正确性。 以上是关于DHT11湿度传感器STM32程序下载的一般步骤。需要提醒的是,在具体的开发过程中,还需要根据实际情况进行程序的调试和优化,以保证传感器和STM32的正常工。 ### 回答2: DHT11湿度传感器是一种常用的数字湿度传感器,可以与STM32微控制器一起使用。要下载DHT11湿度传感器STM32程序,需要进行以下几个步骤: 1. 配置STM32的开发环境:首先要确保已经安装了适当的开发环境,例如Keil或者STM32CubeIDE等。 2. 编写程序代码:为了读取DHT11传感器的数据,需要编写相应的程序代码。可以使用C语言或者汇编语言来编写。在代码中,需要包含DHT11的驱动库或者编写自己的库函数来与传感器进行通信。 3. 配置STM32的引脚:在STM32上,需要选择合适的引脚连接DHT11传感器。可以参考DHT11的数据手册或者资料表来确定引脚的配置。 4. 下载程序到STM32:在完成程序代码编写和引脚配置后,可以通过调试器将程序下载到STM32微控制器上。根据开发环境的不同,下载的具体步骤会有所不同。 5. 测试程序:下载完成后,可以将STM32与DHT11传感器连接,并通过串口或者其他方式将读取到的湿度数据传输到电脑或其他设备上,进行测试。在测试过程中,需要确保程序能够正确地读取并解析DHT11传感器的数据,并将其显示出来。 总结起来,下载DHT11湿度传感器STM32程序,需要配置开发环境、编写程序代码、配置引脚、下载程序到STM32,并进行测试。以上这些步骤的具体实现方式,可以根据具体的开发环境和需求进行调整。 ### 回答3: DHT11湿度传感器是一种常用的数字式湿度传感器STM32微控制器的用户,我们可以通过编写程序来获取DHT11传感器的度和湿度数据。 首先,我们需要连接DHT11传感器到STM32微控制器。DHT11传感器有三个引脚:VCC(正电源)、DATA(数据信号)和GND(地)。我们需要将VCC引脚连接到STM32的3.3V电源,将DATA引脚连接到一个GPIO引脚(例如PA0),将GND引脚连接到GND。 其次,我们需要编写STM32的程序来读取DHT11传感器的数据。具体的程序可以通过使用STM32的GPIO库来配置和读取GPIO引脚的状态。我们需要将DATA引脚设置为输出模式,并给它一个高电平(1ms),然后将DATA引脚设置为输入模式,等待DHT11传感器的响应。一旦DHT11传感器给出响应,我们可以开始读取它发送的数据。DHT11发送的数据位共有40位,我们需要通过计时来确定每位数据的1或0的时间长度。 最后,我们可以将获取的数据进行处理,将度和湿度的数值提取出来,并进行进一步的处理或显示。我们可以使用串口或LCD等外设来进行数据的显示和记录。 总之,通过编写STM32的程序,我们可以实现DHT11湿度传感器的数据获取功能。这个程序可以根据具体的需求进行进一步的扩展和优化,以满足不同的应用场景。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值