【瑞萨RA MCU创意氛围赛速通】瑞萨RA6M5单片机之DHT温湿度测试以及屏幕显示
功能说明:使用DHT11采集环境数据,并将数据通过SPI屏幕进行显示。
1.DHT11
1.1DHT11产品概述
DHT11数字温湿度传感器是一款含有已校准数字信号输出的温湿度复合传感器。它应用专用的数字模块采集技术和温湿度传感技术,确保产品具有极高的可靠性与卓越的长期稳定性。传感器包括一个电阻式感湿元件和一个NTC测温元件,并与一个高性能8位单片机相连接。因此该产品具有品质卓越、超快响应、抗干扰能力强、性价比极高等优点。每个DHT11传感器都在极为精确的湿度校验室中进行校准。校准系数以程序的形式储存在OTP内存中,传感器内部在检测信号的处理过程中要调用这些校准系数。单线制串行接口,使系统集成变得简易快捷。超小的体积、极低的功耗,信号传输距离可达20米以上,使其成为各类应用甚至最为苛刻的应用场合的最佳选则。产品为 4 针单排引脚封装。连接方便,特殊封装形式可根据用户需求而提供。
1.2接口说明
建议连接线长度短于20米时用5K上拉电阻,大于20米时根据实际情况使用合适的上拉电阻。
1.3电源引脚
DHT11的供电电压为 3-5.5V。传感器上电后,要等待 1s 以越过不稳定状态在此期间无需发送任何指令。电源引脚(VDD,GND)之间增加一个100nF 的电容,用以去耦滤波。
1.4串行接口 (单线双向)
DATA 用于微处理器与 DHT11之间的通讯和同步,采用单总线数据格式,一次通讯时间4ms左右,数据分小数部分和整数部分,具体格式在下面说明,当前小数部分用于以后扩展,现读出为零.操作流程如下:
一次完整的数据传输为40bit,高位先出。数据格式:8bit湿度整数数据+8bit湿度小数数据+8bi温度整数数据+8bit温度小数数据+8bit校验和数据传送正确时校验和数据等于“8bit湿度整数数据+8bit湿度小数数据+8bi温度整数数据+8bit温度小数数据”所得结果的末8位。用户MCU发送一次开始信号后,DHT11从低功耗模式转换到高速模式,等待主机开始信号结束后,DHT11发送响应信号,送出40bit的数据,并触发一次信号采集, 用户可选择读取部分数据.从模式下,DHT11接收到开始信号触发一次温湿度采集, 如果没有接收到主机发送开始信号,DHT11不会主动进行温湿采集.采集数据后转换到低速模式。通讯过程如图所示
1.5测量分辨率
测量分辨率分别为 8bit(温度)、8bit(湿度)。
1.6DHT11引脚说明
2.硬件接线
P0.10——DATA
Mode选择Output mode(Initial Low)
3.效果展示以及代码
主程序代码:
#include "hal_data.h"
/*
* 作者:PrairieOne
* csdn:PrairieOne
* 邮箱:prairieone1024@163.com
* 嵌入式技术交流群:826251093
*/
FSP_CPP_HEADER
void R_BSP_WarmStart(bsp_warm_start_event_t event);
FSP_CPP_FOOTER
/* 用户头文件包含 */
#include "led/bsp_led.h"
#include "led/ST7735.h"
#include "led/bsp_dht11.h"
//温湿度变量定义
uint8_t humdity_integer;//湿度整数
uint8_t humdity_decimal;//湿度小数
uint8_t temp_integer ;//温度整数
uint8_t temp_decimal ;//温度小数
uint8_t dht11_check ;//校验值
/*******************************************************************************************************************//**
* main() is generated by the RA Configuration editor and is used to generate threads if an RTOS is used. This function
* is called by main() when no RTOS is used.
**********************************************************************************************************************/
void hal_entry(void)
{
/* TODO: add your own code here */
LED_Init(); // LED 初始化
DHT11_Init();// DHT11 初始化
XTFT_Init_GPIO();//LCD引脚初始化
LCD_Init();//LCD——SPI初始化
ST7735_FillScreen(ST7735_BLACK);
R_BSP_PinWrite(BSP_IO_PORT_00_PIN_10, BSP_IO_LEVEL_HIGH); //DHT11端口配置
while(1)
{
DHT11_Read();
// ST7735_DrawString(0, 0, "CSDN", Font_7x10, ST7735_RED, ST7735_BLACK);
//ST7735_DrawString(0, 32, "CSDN", Font_16x26, ST7735_BLUE, ST7735_BLACK);
ST7735_DrawString(0, 0, "RA6M5", Font_11x18, ST7735_GREEN, ST7735_BLACK);
ST7735_DrawString(0, 16, "PrairieOne", Font_11x18, ST7735_GREEN, ST7735_BLACK);
ST7735_DrawString(0, 32, "-----------", Font_11x18, ST7735_RED, ST7735_BLACK);
ST7735_DrawString(0, 48, "Temp:", Font_11x18, ST7735_GREEN, ST7735_BLACK);
ST7735_DrawString(0, 64, "Humi:", Font_11x18, ST7735_GREEN, ST7735_BLACK);
LCD_ShowIntNum(55, 48, temp_integer, Font_11x18, ST7735_GREEN, ST7735_BLACK);
LCD_ShowIntNum(55, 64, humdity_integer, Font_11x18, ST7735_GREEN, ST7735_BLACK);
ST7735_DrawString(77, 48, "C", Font_11x18, ST7735_GREEN, ST7735_BLACK);
ST7735_DrawString(77, 64, "%", Font_11x18, ST7735_GREEN, ST7735_BLACK);
LED1_ON; // LED1亮
LED2_ON; // LED2亮
LED3_ON; // LED3亮
R_BSP_SoftwareDelay(1, BSP_DELAY_UNITS_SECONDS); //延时1秒
LED1_OFF; // LED1灭
LED2_OFF; // LED2灭
LED3_OFF; // LED3灭
R_BSP_SoftwareDelay(1, BSP_DELAY_UNITS_SECONDS); //延时1秒
}
#if BSP_TZ_SECURE_BUILD
/* Enter non-secure code */
R_BSP_NonSecureEnter();
#endif
}
/*******************************************************************************************************************//**
* This function is called at various points during the startup process. This implementation uses the event that is
* called right before main() to set up the pins.
*
* @param[in] event Where at in the start up process the code is currently at
**********************************************************************************************************************/
void R_BSP_WarmStart(bsp_warm_start_event_t event)
{
if (BSP_WARM_START_RESET == event)
{
#if BSP_FEATURE_FLASH_LP_VERSION != 0
/* Enable reading from data flash. */
R_FACI_LP->DFLCTL = 1U;
/* Would normally have to wait tDSTOP(6us) for data flash recovery. Placing the enable here, before clock and
* C runtime initialization, should negate the need for a delay since the initialization will typically take more than 6us. */
#endif
}
if (BSP_WARM_START_POST_C == event)
{
/* C runtime environment and system clocks are setup. */
/* Configure pins. */
R_IOPORT_Open (&g_ioport_ctrl, g_ioport.p_cfg);
}
}
#if BSP_TZ_SECURE_BUILD
BSP_CMSE_NONSECURE_ENTRY void template_nonsecure_callable ();
/* Trustzone Secure Projects require at least one nonsecure callable function in order to build (Remove this if it is not required to build). */
BSP_CMSE_NONSECURE_ENTRY void template_nonsecure_callable ()
{
}
#endif
bsp_dht11.c代码:
#include "bsp_dht11.h" // Device header
extern fsp_err_t err ;
uint8_t DHT11_Init(void)
{
/**********************DHT11初始化***************************************/
R_IOPORT_PinWrite(&g_ioport_ctrl, BSP_IO_PORT_00_PIN_10, BSP_IO_LEVEL_HIGH);
R_BSP_SoftwareDelay(1000U, BSP_DELAY_UNITS_MILLISECONDS);
return 0;
}
uint8_t DHT11_ReadByte(void)
{
bsp_io_level_t state;
uint8_t ans=0,ind;
for (ind=0;ind<8;ind++)
{
ans<<=1;
do
{
R_IOPORT_PinRead(&g_ioport_ctrl, BSP_IO_PORT_00_PIN_10, &state);
}while(state==BSP_IO_LEVEL_LOW);//直至识别低电平,开始接受数据
R_BSP_SoftwareDelay(30, BSP_DELAY_UNITS_MICROSECONDS); //延时54us
R_IOPORT_PinRead(&g_ioport_ctrl, BSP_IO_PORT_00_PIN_10, &state);
if (state==BSP_IO_LEVEL_HIGH)
ans |= 1;
do{
R_IOPORT_PinRead(&g_ioport_ctrl, BSP_IO_PORT_00_PIN_10, &state);
}while(state==BSP_IO_LEVEL_HIGH);
}
return ans;
}
extern uint8_t humdity_integer;//湿度整数
extern uint8_t humdity_decimal;//湿度小数
extern uint8_t temp_integer ;//温度整数
extern uint8_t temp_decimal ;//温度小数
extern uint8_t dht11_check ;//校验值
uint8_t DHT11_Read(void)
{
uint8_t dht11_check=0;
bsp_io_level_t state;
uint16_t delay_dht=0xffff;
//DHT启动时序DATA设为输出状态
R_IOPORT_PinCfg(&g_ioport_ctrl,BSP_IO_PORT_00_PIN_10,((uint32_t) IOPORT_CFG_PORT_DIRECTION_OUTPUT | (uint32_t) IOPORT_CFG_PORT_OUTPUT_HIGH));
//发送18ms低电平
R_IOPORT_PinWrite(&g_ioport_ctrl, BSP_IO_PORT_00_PIN_10, BSP_IO_LEVEL_LOW);
R_BSP_SoftwareDelay(18, BSP_DELAY_UNITS_MILLISECONDS); //延时20ms
//在输出20-40us高电平
R_IOPORT_PinWrite(&g_ioport_ctrl, BSP_IO_PORT_00_PIN_10, BSP_IO_LEVEL_HIGH);
// R_BSP_SoftwareDelay(30, BSP_DELAY_UNITS_MICROSECONDS); //延时30us
//DATA设为输入状态
R_IOPORT_PinCfg(&g_ioport_ctrl,BSP_IO_PORT_00_PIN_10,((uint32_t) IOPORT_CFG_PORT_DIRECTION_INPUT));
//等待DATA响应低电平,后变为高电平
do{
delay_dht--;
if (!delay_dht)
return 0;
R_IOPORT_PinRead(&g_ioport_ctrl, BSP_IO_PORT_00_PIN_10, &state);
}while(state==BSP_IO_LEVEL_HIGH);
do{
delay_dht--;
if (!delay_dht)
return 0;
R_IOPORT_PinRead(&g_ioport_ctrl, BSP_IO_PORT_00_PIN_10, &state);
}while(state==BSP_IO_LEVEL_LOW);
do{
delay_dht--;
if (!delay_dht)
return 0;
R_IOPORT_PinRead(&g_ioport_ctrl, BSP_IO_PORT_00_PIN_10, &state);
}while(state==BSP_IO_LEVEL_HIGH);
humdity_integer = DHT11_ReadByte();
humdity_decimal = DHT11_ReadByte();
temp_integer = DHT11_ReadByte();
temp_decimal = DHT11_ReadByte();
dht11_check = DHT11_ReadByte();
if (((humdity_integer+humdity_decimal+temp_integer+temp_decimal)&0xff)==dht11_check)
return 1;
else
return 0;
}
bsp_dht11.h代码:
#ifndef __BSP_DHT11_H
#define __BSP_DHT11_H
#include "hal_data.h"
uint8_t DHT11_Init(void);
uint8_t DHT11_ReadByte(void);
uint8_t DHT11_Read(void);
#endif /* DHT11_H_ */
遇事不决,可问春风!
DHT11代码参考链接为:记帖
如有冒犯,联系可删