基于STM32F103C8T6温湿度传感器DHT11
时间: 2023-10-31 19:06:54 浏览: 184
好的,你需要使用STM32F103C8T6微控制器和DHT11传感器来获取温度和湿度数据。以下是一些基本步骤:
1. 连接DHT11传感器:将DHT11传感器的VCC引脚连接到STM32F103C8T6的5V引脚,将DHT11传感器的GND引脚连接到STM32F103C8T6的GND引脚,将DHT11传感器的DATA引脚连接到STM32F103C8T6的GPIO引脚。
2. 配置GPIO引脚:使用STM32CubeMX或手动编写代码配置GPIO引脚,使其与DHT11传感器的DATA引脚连接。将引脚配置为输入模式,并启用上拉电阻。
3. 读取传感器数据:使用STM32F103C8T6的GPIO库读取DHT11传感器的数据,以获取温度和湿度数据。你需要编写代码解析DHT11传感器返回的数据,以获取实际的温度和湿度值。
4. 显示数据:将温度和湿度数据显示在LCD屏幕上或通过串口输出。
需要注意的是,DHT11传感器的数据输出是一种单线传输协议,你需要编写代码来解析这种协议。同时,DHT11传感器的响应时间比较慢,需要一定的等待时间来获取数据。
相关问题
stm32f103c8t6温湿度计dht11
以下是基于STM32F103C8T6实现DHT11温湿度采集的步骤和代码:
1. 确定引脚连接:将DHT11的VCC引脚连接到STM32的5V电源引脚,将DHT11的GND引脚连接到STM32的GND引脚,将DHT11的DATA引脚连接到STM32的GPIO引脚。
2. 配置GPIO引脚:将DATA引脚连接到STM32的GPIO引脚后,需要在代码中配置该引脚为输入模式。
```c
GPIO_InitTypeDef GPIO_InitStruct;
GPIO_InitStruct.Pin = GPIO_PIN_0;
GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
GPIO_InitStruct.Pull = GPIO_PULLUP;
HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
```
3. 发送起始信号:DHT11在开始采集数据前需要接收到主机发送的起始信号,起始信号为低电平持续18ms以上,然后主机发送一个高电平持续20-40us的信号。
```c
HAL_GPIO_WritePin(GPIOA, GPIO_PIN_0, GPIO_PIN_RESET);
HAL_Delay(20);
HAL_GPIO_WritePin(GPIOA, GPIO_PIN_0, GPIO_PIN_SET);
```
4. 接收数据:DHT11在接收到主机发送的起始信号后,会开始发送40位数据,其中前16位为湿度值,后16位为温度值,最后8位为校验和。每一位数据的发送都是通过50us的低电平和高电平来表示的,低电平持续26-28us表示0,低电平持续70us表示1。
```c
uint8_t data[5];
for (int i = 0; i < 5; i++) {
uint8_t byte = 0;
for (int j = 0; j < 8; j++) {
while (!HAL_GPIO_ReadPin(GPIOA, GPIO_PIN_0)); // 等待低电平结束
HAL_Delay(30); // 判断高电平持续时间,长则为1,短则为0
if (HAL_GPIO_ReadPin(GPIOA, GPIO_PIN_0)) {
byte |= (1 << (7 - j));
}
while (HAL_GPIO_ReadPin(GPIOA, GPIO_PIN_0)); // 等待高电平结束
}
data[i] = byte;
}
```
5. 校验数据:DHT11发送完40位数据后,会发送一个校验和,校验和为前面40位数据的和,如果校验和与实际计算的和不相等,则数据传输错误。
```c
if (data[4] != (data[0] + data[1] + data[2] + data[3])) {
// 数据传输错误
}
```
完整的代码如下:
```c
#include "main.h"
#include "dht11.h"
void DHT11_ReadData(DHT11_Data_TypeDef *DHT11_Data) {
GPIO_InitTypeDef GPIO_InitStruct;
GPIO_InitStruct.Pin = GPIO_PIN_0;
GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
GPIO_InitStruct.Pull = GPIO_PULLUP;
HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
HAL_GPIO_WritePin(GPIOA, GPIO_PIN_0, GPIO_PIN_RESET);
HAL_Delay(20);
HAL_GPIO_WritePin(GPIOA, GPIO_PIN_0, GPIO_PIN_SET);
GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP;
HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
uint8_t data[5];
for (int i = 0; i < 5; i++) {
uint8_t byte = 0;
for (int j = 0; j < 8; j++) {
while (!HAL_GPIO_ReadPin(GPIOA, GPIO_PIN_0)); // 等待低电平结束
HAL_Delay(30); // 判断高电平持续时间,长则为1,短则为0
if (HAL_GPIO_ReadPin(GPIOA, GPIO_PIN_0)) {
byte |= (1 << (7 - j));
}
while (HAL_GPIO_ReadPin(GPIOA, GPIO_PIN_0)); // 等待高电平结束
}
data[i] = byte;
}
if (data[4] != (data[0] + data[1] + data[2] + data[3])) {
// 数据传输错误
}
DHT11_Data->Humidity = data[0];
DHT11_Data->Temperature = data[2];
}
--相关问题--:
stm32f103c8t6温湿度dht11教程
好的,以下是stm32f103c8t6与DHT11温湿度传感器的连接及程序实现教程。
1.连接
将DHT11的VCC连接到stm32f103c8t6的5V电源,GND连接到GND,数据线连接到PA1。
2.程序实现
首先需要在stm32f103c8t6中配置GPIO的输入输出模式和中断模式。具体配置方法可以参考资料进行学习。
下面是使用STM32CubeMX生成的代码,实现DHT11的温湿度读取。
```c
/* Includes ------------------------------------------------------------------*/
#include "main.h"
#include "dht11.h"
/* Private variables ---------------------------------------------------------*/
TIM_HandleTypeDef htim2;
UART_HandleTypeDef huart1;
/* Private function prototypes -----------------------------------------------*/
void SystemClock_Config(void);
static void MX_GPIO_Init(void);
static void MX_USART1_UART_Init(void);
static void MX_TIM2_Init(void);
int main(void)
{
HAL_Init();
SystemClock_Config();
MX_GPIO_Init();
MX_USART1_UART_Init();
MX_TIM2_Init();
HAL_TIM_Base_Start_IT(&htim2);
while (1)
{
}
}
void HAL_TIM_PeriodElapsedCallback(TIM_HandleTypeDef *htim)
{
if (htim->Instance == TIM2)
{
DHT11_Start();
uint8_t check = DHT11_Check();
if (check == 1)
{
printf("Temperature = %d.%dC, Humidity = %d.%d%%\r\n", DHT11_Read_Temp() / 10, DHT11_Read_Temp() % 10, DHT11_Read_Humidity() / 10, DHT11_Read_Humidity() % 10);
}
else
{
printf("DHT11 check error!\r\n");
}
}
}
void SystemClock_Config(void)
{
RCC_OscInitTypeDef RCC_OscInitStruct = {0};
RCC_ClkInitTypeDef RCC_ClkInitStruct = {0};
/** Initializes the RCC Oscillators according to the specified parameters
* in the RCC_OscInitTypeDef structure.
*/
RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSI;
RCC_OscInitStruct.HSIState = RCC_HSI_ON;
RCC_OscInitStruct.HSICalibrationValue = RCC_HSICALIBRATION_DEFAULT;
RCC_OscInitStruct.PLL.PLLState = RCC_PLL_NONE;
if (HAL_RCC_OscConfig(&RCC_OscInitStruct) != HAL_OK)
{
Error_Handler();
}
/** Initializes the CPU, AHB and APB buses clocks
*/
RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK | RCC_CLOCKTYPE_SYSCLK
| RCC_CLOCKTYPE_PCLK1 | RCC_CLOCKTYPE_PCLK2;
RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_HSI;
RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1;
RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV1;
RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV1;
if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_0) != HAL_OK)
{
Error_Handler();
}
}
static void MX_TIM2_Init(void)
{
TIM_ClockConfigTypeDef sClockSourceConfig = {0};
TIM_MasterConfigTypeDef sMasterConfig = {0};
htim2.Instance = TIM2;
htim2.Init.Prescaler = 7199;
htim2.Init.CounterMode = TIM_COUNTERMODE_UP;
htim2.Init.Period = 2000;
htim2.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1;
if (HAL_TIM_Base_Init(&htim2) != HAL_OK)
{
Error_Handler();
}
sClockSourceConfig.ClockSource = TIM_CLOCKSOURCE_INTERNAL;
if (HAL_TIM_ConfigClockSource(&htim2, &sClockSourceConfig) != HAL_OK)
{
Error_Handler();
}
sMasterConfig.MasterOutputTrigger = TIM_TRGO_RESET;
sMasterConfig.MasterSlaveMode = TIM_MASTERSLAVEMODE_DISABLE;
if (HAL_TIMEx_MasterConfigSynchronization(&htim2, &sMasterConfig) != HAL_OK)
{
Error_Handler();
}
}
static void MX_USART1_UART_Init(void)
{
huart1.Instance = USART1;
huart1.Init.BaudRate = 115200;
huart1.Init.WordLength = UART_WORDLENGTH_8B;
huart1.Init.StopBits = UART_STOPBITS_1;
huart1.Init.Parity = UART_PARITY_NONE;
huart1.Init.Mode = UART_MODE_TX_RX;
huart1.Init.HwFlowCtl = UART_HWCONTROL_NONE;
huart1.Init.OverSampling = UART_OVERSAMPLING_16;
if (HAL_UART_Init(&huart1) != HAL_OK)
{
Error_Handler();
}
}
static void MX_GPIO_Init(void)
{
GPIO_InitTypeDef GPIO_InitStruct = {0};
/* GPIO Ports Clock Enable */
__HAL_RCC_GPIOC_CLK_ENABLE();
__HAL_RCC_GPIOA_CLK_ENABLE();
/*Configure GPIO pin Output Level */
HAL_GPIO_WritePin(GPIOA, GPIO_PIN_1, GPIO_PIN_RESET);
/*Configure GPIO pin : PA1 */
GPIO_InitStruct.Pin = GPIO_PIN_1;
GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP;
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
}
```
在main函数中,启动了TIM2定时器,并在定时器中断中读取DHT11传感器的温湿度值。DHT11_Start()函数用于启动传感器,并且等待40us,然后通过DHT11_Check()函数检测传感器的响应信号是否正确,如果正确则通过DHT11_Read_Temp()和DHT11_Read_Humidity()函数读取温湿度值。
最后,通过串口打印函数printf()将温湿度值输出。
这就是stm32f103c8t6与DHT11温湿度传感器的连接及程序实现教程。
阅读全文