ESP32 + DHT11/DHT22 温湿度传感器接入 ThingsCloud

您所在的位置:网站首页 物联网温湿度传感器实验 ESP32 + DHT11/DHT22 温湿度传感器接入 ThingsCloud

ESP32 + DHT11/DHT22 温湿度传感器接入 ThingsCloud

2024-07-14 01:25| 来源: 网络整理| 查看: 265

ESP32 + DHT11/DHT22 温湿度传感器接入 ThingsCloud

ESP32 是乐鑫公司推出的 WiFi 芯片,它不仅支持 WiFi 和 BLE,还可以作为可编程的 MCU,通过 Espressif IDF、Arduino 等框架编写固件,用于非常广泛的物联网场景。

这个教程我们分享如何在 Arduino IDE 中使用 ThingsCloud ESP SDK,为 ESP32 开发固件程序,将 DHT11/DHT22 温湿度传感器的数据上报到 ThingsCloud 物联网平台,并利用 ThingsCloud 强大的零代码应用开发工具,为用户生成 App。

该示例不仅支持 ESP32 芯片,同样支持:ESP8266、ESP32-S2、ESP32-S3、ESP32-C3。

温馨提示

在学习本教程之前,您需要具备一些基础知识,包括:

如何在 Arduino IDE 中开发和上传 ESP32 固件。Arduino 框架下的单片机编程基础。C 语言基础

这些内容不在本教程的范围内,请您自行学习,相关的学习资源很多。

硬件部分准备关于 DHT 系列传感器

DHT11 和 DHT22 传感器用于测量温度和相对湿度,这些传感器包含一个芯片,用于模数转换,输出温度和湿度的数字信号。

DHT11 和 DHT22 非常相似,但规格不同,如下:

DHT11DHT22温度范围0 至 50 ºC +/-2ºC-40 至 80 ºC +/-0.5ºC湿度范围20 至 90%+/-5%0 至 100%+/-2%分辨率湿度:1% 温度:1ºC湿度:0.1% 温度:0.1ºC工作电压3 – 5.5 V DC3 – 6 V DC电流供应0.5 – 2.5 mA1 – 1.5 mA采样周期1 秒2 秒

DHT22 传感器具有更好的分辨率和更宽的温度和湿度测量范围,价格稍高一些。

尽管它们存在差异,但它们的接线方式和工作方式相似,我们可以使用相同的代码来读取温度和湿度,只需要在代码中选择正确的传感器类型。

连线示意图

DHT 传感器有4个引脚,如果使用带有板子的 DHT 传感器,实际上只引出了3个必要的引脚,并且内部对数据引脚接了上拉电阻。

DHT 传感器和 ESP32 开发板的接线方式,如下图:

示例中我们将 DHT 传感器的数据引脚接到了 ESP32 的 GPIO4 上,您也可以使用其它可用的 GPIO 引脚,并在代码中修改引脚编号。

在 Arduino 中安装依赖库安装 ThingsCloud ESP SDK

详细安装方法,请浏览 在 Arduino IDE 中安装 ThingsCloud ESP SDK

安装 DHT 依赖库

本示例中我们需要用到 DHT 第三方库,使用同样的方法安装 DHT_sensor_library,如下图:

安装时通常会提示安装另一个依赖库 Adafruit_Unified_Sensor,是否提示取决于您使用的 Arduino 版本,如果没有提示,您需要手动安装。

使用示例代码

请确保已更新 SDK 到最新版本,在 Arduino 示例代码中,找到 10.IoT_Tutorials > dht_sensor 示例代码。

以下为完整代码:

#include #include #include "DHT.h" //====================================================== // 设置 ssid / password,连接到你的 WiFi AP const char *ssid = ""; const char *password = ""; // 在 ThingsCloud 控制台的设备详情页中,复制以下设备连接信息 // https://console.thingscloud.xyz #define THINGSCLOUD_MQTT_HOST "" #define THINGSCLOUD_DEVICE_ACCESS_TOKEN "" #define THINGSCLOUD_PROJECT_KEY "" //====================================================== ThingsCloudMQTT client( THINGSCLOUD_MQTT_HOST, THINGSCLOUD_DEVICE_ACCESS_TOKEN, THINGSCLOUD_PROJECT_KEY); // 上报数据的间隔时间计时器 unsigned long timer1 = millis(); // 设置定时上报数据的时间间隔,单位是 ms。免费版项目请务必大于30秒,否则设备可能会被限连。 const int report_interval = 1000 * 60 * 5; // 设置DHT11的数据引脚 #define DHTPIN 4 // 设置使用的DHT类型,这里我们使用了DHT11 #define DHTTYPE DHT11 // DHT 11 //#define DHTTYPE DHT22 // DHT 22 (AM2302), AM2321 //#define DHTTYPE DHT21 // DHT 21 (AM2301) DHT dht(DHTPIN, DHTTYPE); void setup() { Serial.begin(115200); // 允许 SDK 的日志输出 client.enableDebuggingMessages(); // 连接 WiFi AP client.setWifiCredentials(ssid, password); dht.begin(); } // 读取并发布传感器数据到 ThingsCloud void pubSensors() { float h = dht.readHumidity(); float t = dht.readTemperature(); // 检查是否读取到传感器数据 if (isnan(h) || isnan(t)) { Serial.println(F("Failed to read from DHT sensor!")); return; } // 串口打印数据日志 Serial.print(F("Humidity: ")); Serial.print(h); Serial.print(F("% Temperature: ")); Serial.print(t); Serial.println(); // 生成属性 JSON DynamicJsonDocument obj(512); obj["temperature"] = t; obj["humidity"] = h; char attributes[512]; serializeJson(obj, attributes); // 调用属性上报方法 client.reportAttributes(attributes); } // 必须实现这个回调函数,当 MQTT 连接成功后执行该函数。 void onMQTTConnect() { // 延迟 5 秒上报首次传感器数据 client.executeDelayed(1000 * 5, []() { pubSensors(); }); } void loop() { client.loop(); // 按间隔时间上报传感器数据 if (millis() - timer1 > report_interval) { timer1 = millis(); pubSensors(); } } 设置代码中的参数

示例代码中,只需要补全以下两处参数。

WiFi 连接参数

这个教程中我们使用的是指定 WiFi 连接参数的方式,需要修改以下部分:

// 设置 ssid / password,连接到你的 WiFi AP const char *ssid = ""; const char *password = "";

请修改为您自己的 WiFi 连接参数,修改后大致是这样的:

// 设置 ssid / password,连接到你的 WiFi AP const char *ssid = "my-wifi-ap"; const char *password = "thingscloud.xyz"; ThingsCloud 设备 MQTT 地址和连接证书

接下来填写您在 ThingsCloud 的设备 MQTT 地址和连接证书,如下:

// 在 ThingsCloud 控制台的设备详情页中,复制以下设备连接信息 // https://console.thingscloud.xyz #define THINGSCLOUD_MQTT_HOST "" #define THINGSCLOUD_DEVICE_ACCESS_TOKEN "" #define THINGSCLOUD_PROJECT_KEY ""

如何获得这些参数呢?首先在 ThingsCloud 创建设备,如下图:

在设备创建页面,给设备起个名字,其它的选项可以暂不填写。如下图:

设备创建后,进入设备的 连接 页面,在这里可以复制以下参数,如下图:

将参数补全到代码中,例如:

// 在 ThingsCloud 控制台的设备详情页中,复制以下设备连接信息 // https://console.thingscloud.xyz #define THINGSCLOUD_MQTT_HOST "********.iot-api.com" #define THINGSCLOUD_DEVICE_ACCESS_TOKEN "bzqsg6b7l2******" #define THINGSCLOUD_PROJECT_KEY "VV9Z******"

特别注意

不要直接使用以上的参数示例,请登录 ThingsCloud 创建自己的设备,获取 MQTT 地址和设备证书。

编译代码并上传固件到 ESP32

接下来编译和上传固件到 ESP32 开发板。

查看上报数据Arduino 串口日志

固件上传成功后,ESP32 打印日志到串口,可以看到 WiFi 连接成功,ThingsCloud 连接成功后,开始定时上报传感器数据。

ThingsCloud 控制台

在 ThingsCloud 控制台的设备概要页面,可以实时看到上报的数据,如下图:

设计App设备面板

到此为止,ESP32 已经成功接入 ThingsCloud,我们可以在控制台浏览数据。如果您的设备是卖给用户,那就需要给用户提供相应的管理软件,并且为用户分配相应的设备。ThingsCloud 提供了用户应用,帮助您生成用户 App。

我们需要完成以下几步简单的操作。

创建设备类型

前边创建设备的时候,我们并没有使用设备类型,是的,设备类型不是必须的。但是当我们需要深入发挥 ThingsCloud 的更多功能,就必须创建设备类型,它为设备定义了各种功能。

创建设备类型非常简单,这里我们可以直接用标准类型,如下图:

选择温室度传感器,这个标准类型中已经存在定义好的属性。

完善设备类型的信息,如下图:

设备类型创建成功后,记得将设备关联到该设备类型,如下图:

这样一来,设备类型下的所有设备,都继承了设备类型的功能设置。

查看属性定义

进入设备类型的功能定义,可以看到这里已经有自动生成的温度和湿度属性。如果要开发更多功能,您可以继续添加其它属性。

回到设备页面,可以看到属性显示的名称替换成了功能定义中的属性名称。

编辑App界面

我们再回到设备类型中,进入 应用配置 > 编辑设备面板,如下图:

打开 App 设备面板编辑器,在左侧的数值显示组件中,选择一个环形组件,添加到界面中。如下图:

接下来,在右侧的设置中,添加温度和湿度属性,如下图:

为了方便预览实际效果,选择预览设备,如下图:

不喜欢这个组件?换一个试试,并设置个性化样式。

提示

ThingsCloud 将不断增加更多的组件和样式风格,并支持包括分页和背景样式等高级功能。

ThingsX App 已支持设备面板分页组件open in new windowThingsX App 已支持设备面板个性化背景open in new window创建用户并关联设备

接下来,为设备关联现有用户,也可以创建新用户。

创建新用户,如下图:

然后添加关联用户,选择刚添加的新用户。

如下图,设备已经关联了一个用户。

创建用户应用

还剩最后一步,那就是创建一个用户应用,所有的用户都可以登录这个应用来管理自己关联的设备。

这里我们选择 ThingsX ,这是用户应用通用版 App。

给应用起个名字,如下图:

进入创建的应用,可以看到平台为我们生成了多个平台的应用,不论使用哪个,界面都是完全一致的。

在 App 中浏览设备数据

这里我们以微信小程序为例,点击上边的微信小程序,会自动生成小程序码,用微信扫一扫,进入登录页,如下图:

使用创建用户时设置的登录名和密码,登录成功,进入设备列表页,如下图:

进入设备,看到的便是我们刚才编辑的设备面板界面,您可以重新编辑这个界面,界面更新后,只需要重新进入设备页,便会自动同步新的面板界面。

提示

了解用户应用的详细介绍,以及 ThingsX 公版及 OEM App,请浏览 用户应用。

更多应用

设备接入 ThingsCloud 后,以上只介绍了如何创建关联用户,以及快速生成用户 App。还有更多的功能值得您探索,例如:

创建可视化看板,点此了解详情创建可视化大屏,点此了解详情创建项目管理后台,点此了解详情使用告警通知,点此了解详情

更多场景和功能介绍,请浏览官方资源:

博客open in new window文档open in new window教程


【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3