编写使用51单片机+DHT11+LED1602进行湿度监测的代码

时间: 2024-01-13 20:03:28 浏览: 32
以下是使用51单片机、DHT11和LED1602进行湿度监测的代码: ``` #include <reg51.h> // 引入51单片机头文件 #define DHT11_PIN P1_0 // 定义DHT11数据引脚 #define LCD_RS P2_0 // 定义LCD_RS引脚 #define LCD_RW P2_1 // 定义LCD_RW引脚 #define LCD_EN P2_2 // 定义LCD_EN引脚 #define LCD_DATA P0 // 定义LCD数据引脚 sbit LED = P1_1; // 定义LED引脚 unsigned char humi_data = 0; // 定义湿度数据 unsigned char temp_data = 0; // 定义温度数据 unsigned char check_sum = 0; // 定义校验和 void delay_us(unsigned int i) // 延时函数 { while (i--); } void LCD_Write_Cmd(unsigned char cmd) // 写入LCD指令 { LCD_RS = 0; LCD_RW = 0; LCD_DATA = cmd; LCD_EN = 1; delay_us(5); LCD_EN = 0; } void LCD_Write_Data(unsigned char dat) // 写入LCD数据 { LCD_RS = 1; LCD_RW = 0; LCD_DATA = dat; LCD_EN = 1; delay_us(5); LCD_EN = 0; } void LCD_Init() // 初始化LCD { LCD_Write_Cmd(0x38); // 8位数据接口,2行显示,5x7点阵字符 LCD_Write_Cmd(0x0c); // 显示开,光标关闭 LCD_Write_Cmd(0x06); // 光标右移,字符不移动 LCD_Write_Cmd(0x01); // 清屏 } void LCD_Show_Str(unsigned char x, unsigned char y, unsigned char *str) // 在LCD上显示字符串 { unsigned char addr; if (y == 0) addr = 0x80 + x; else addr = 0xc0 + x; LCD_Write_Cmd(addr); while (*str != '\0') { LCD_Write_Data(*str++); } } void Start_DHT11() // 启动DHT11 { DHT11_PIN = 0; delay_us(20); DHT11_PIN = 1; delay_us(30); } void Check_Response() // 检查DHT11响应信号 { while (!DHT11_PIN); while (DHT11_PIN); } unsigned char Read_Data() // 读取DHT11数据 { unsigned char i, j, dat = 0; for (j = 0; j < 8; j++) { while (!DHT11_PIN); delay_us(30); if (DHT11_PIN == 0) { dat &= ~(1 << (7 - j)); } else { dat |= (1 << (7 - j)); while (DHT11_PIN); } } return dat; } void Read_DHT11() // 读取DHT11湿度和温度数据 { Start_DHT11(); Check_Response(); humi_data = Read_Data(); humi_data = Read_Data(); temp_data = Read_Data(); temp_data = Read_Data(); check_sum = Read_Data(); } void main() { unsigned char str[16]; LCD_Init(); // 初始化LCD while (1) { Read_DHT11(); // 读取DHT11数据 if (check_sum == humi_data + temp_data) // 判断校验和是否正确 { LED = 0; // 设置LED灯亮 sprintf(str, "Humi: %d%%", humi_data); // 将湿度数据转化为字符串 LCD_Show_Str(0, 0, str); // 在LCD上显示湿度数据 sprintf(str, "Temp: %dC", temp_data); // 将温度数据转化为字符串 LCD_Show_Str(0, 1, str); // 在LCD上显示温度数据 } else { LED = 1; // 设置LED灯灭 LCD_Show_Str(0, 0, "DHT11 Error!"); // 在LCD上显示错误信息 LCD_Show_Str(0, 1, "Please try again!"); } delay_us(500000); // 延时500ms } } ``` 注意事项: 1. 以上代码假设LCD1602的数据线接口为P0,如果接口不同需要修改代码中的LCD_DATA宏定义。 2. 在读取DHT11数据时,需要先发送启动信号,然后等待DHT11响应信号,在此之后才能开始读取数据。 3. 在读取DHT11湿度和温度数据时,需要读取两次,分别为整数和小数部分。 4. 在读取DHT11数据时,需要校验和才能保证数据的正确性。

相关推荐

最新推荐

recommend-type

C51_温湿度传感器DHT11驱动_LCD1602显示程序_硬件通过_含电路图和实际测试效果图

C51_温湿度传感器DHT11驱动_LCD1602显示程序_硬件通过_含电路图和实际测试效果图
recommend-type

51单片机与DHT11实现温湿度采集

51单片机与DHT11实现温湿度采集,用12864液晶显示,c语言编程!
recommend-type

DHT11温湿度传感器应用及感受

朋友送的DHT11传感器,用于湿度和温度测量,网上找了资料看,相对的控制较为简单,花了点时间把程序写了出来,用1602做显示,单总线控制的器件,基本上没什么指令,只有一个启动信号,然后是连续读出40bit的数据,...
recommend-type

基于51单片机的智能家居环境监测系统论文.doc

本论文是基于51单片机技术的智能家居环境监测系统参考论文,包含DHT11温湿度采集,MQ-2烟雾浓度采集,LCD1602实时显示,蜂鸣器和LED组成的声光报警等部分电路的参考与选定
recommend-type

Python源码-数学美之樱花.py

Python源码-数学美之樱花
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

用matlab绘制高斯色噪声情况下的频率估计CRLB,其中w(n)是零均值高斯色噪声,w(n)=0.8*w(n-1)+e(n),e(n)服从零均值方差为se的高斯分布

以下是用matlab绘制高斯色噪声情况下频率估计CRLB的代码: ```matlab % 参数设置 N = 100; % 信号长度 se = 0.5; % 噪声方差 w = zeros(N,1); % 高斯色噪声 w(1) = randn(1)*sqrt(se); for n = 2:N w(n) = 0.8*w(n-1) + randn(1)*sqrt(se); end % 计算频率估计CRLB fs = 1; % 采样频率 df = 0.01; % 频率分辨率 f = 0:df:fs/2; % 频率范围 M = length(f); CRLB = zeros(M,1); for
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。