353浏览
查看: 353|回复: 10

[项目] 【花雕学编程】Arduino动手做(238)---ESP32 CYD屏显示温度

[复制链接]
【花雕学编程】Arduino动手做(238)---ESP32 CYD屏显示温度图2

ESP32-CYD(2432S028)液晶2.8寸屏开发板使用ESP32-WROOM-32模块作为主控,主控是一款双核MCU,集成了Wi-Fi和蓝牙功能,主频可达240MHz,具有520KB的SRAM、448KB的ROM,闪存容量为4MB+4MB,显示分辨率为240x320,采用电阻式触控式屏幕。该模块包括LCD显示器、背光控制电路、触控式屏幕控制电路、扬声器驱动电路、光敏电路和RGB LED控制电路。支持TF卡界面、序列界面、温湿度感测器界面(DHT11界面)和保留的IO口界面,该模块支持在Arduino IDE、ESP IDE、MicroPython和Mixly中进行开发。

【花雕学编程】Arduino动手做(238)---ESP32 CYD屏显示温度图1

驴友花雕  中级技神
 楼主|

发表于 2024-11-14 11:56:56

【花雕学编程】Arduino动手做(238)---ESP32 CYD屏显示温度

安装TFT_eSPI、XPT2046_Touchscreen、BasicLinearAlgebra和LVGL库
网址:
TFT_eSPI库的网址:https://github.com/Bodmer/TFT_eSPI
XPT2046_Touchscreen库的网址: https://github.com/PaulStoffregen/XPT2046_Touchscreen
BasicLinearAlgebra库:https://github.com/tomstewart89/BasicLinearAlgebra

要正确使用 TFT_eSPI 库,需要根据不同开发板与TFT屏幕正确配置User_Setup.h和lv_conf.h文件。

LVGL中文开发手册:https://lvgl.100ask.net/master/

【花雕学编程】Arduino动手做(238)---ESP32 CYD屏显示温度图1

回复

使用道具 举报

驴友花雕  中级技神
 楼主|

发表于 2024-11-14 12:03:15

【花雕学编程】Arduino动手做(238)---ESP32 CYD屏显示温度

【花雕学编程】Arduino动手做(238)---ESP32 CYD屏显示温度图2

【花雕学编程】Arduino动手做(238)---ESP32 CYD屏显示温度图1
回复

使用道具 举报

驴友花雕  中级技神
 楼主|

发表于 2024-11-14 12:04:28

【花雕学编程】Arduino动手做(238)---ESP32 CYD屏显示温度

DS18B20 是一种非常受欢迎的数字温度传感器,常用于各种温度监测应用。它具有以下特点:

1、高精度:DS18B20 的温度测量精度为 ±0.5°C,可以提供高达 0.0625°C 的分辨率。

2、数字输出:它通过一条数据线与微控制器进行通信,使用单线制(1-Wire)协议,简化了电路设计。

3、低功耗:该传感器在测量过程中的功耗非常低,适合用于电池供电的设备。

4、广泛的温度范围:DS18B20 可以测量从 -55°C 到 +125°C 的温度范围。

5、高可靠性:由于其数字化设计,DS18B20 具有较高的稳定性和可靠性。

这种传感器非常适合用于环境监测、食品冷藏设备、温度控制系统等领域。


【花雕学编程】Arduino动手做(238)---ESP32 CYD屏显示温度图1

回复

使用道具 举报

驴友花雕  中级技神
 楼主|

发表于 2024-11-14 12:07:17

【花雕学编程】Arduino动手做(238)---ESP32 CYD屏显示温度

【花雕学编程】Arduino动手做(238)---ESP32 CYD屏显示温度图2

【花雕学编程】Arduino动手做(238)---ESP32 CYD屏显示温度图1
回复

使用道具 举报

驴友花雕  中级技神
 楼主|

发表于 2024-11-14 12:08:46

【花雕学编程】Arduino动手做(238)---ESP32 CYD屏显示温度

在 ESP32 Cheap Yellow Display 上,有一个扩展的 IO 插槽,可让您连接外部外围设备。我们将传感器连接到 CN1 连接器,并使用 GPIO 27。

【花雕学编程】Arduino动手做(238)---ESP32 CYD屏显示温度图1

回复

使用道具 举报

驴友花雕  中级技神
 楼主|

发表于 2024-11-14 13:25:47

【花雕学编程】Arduino动手做(238)---ESP32 CYD屏显示温度

  【Arduino】168种传感器模块系列实验(资料代码+仿真编程+图形编程)
  实验二百三十八:ESP32开发板WiFi蓝牙2.8寸240*320智能液晶显示屏带触摸屏TFT模块
  项目实验之二十二:带 LVGL 的 ESP32 CYD:使用 DS18B20 传感器显示温度(曲面仪表)

实验开源代码

  1. /*
  2.   【Arduino】168种传感器模块系列实验(资料代码+仿真编程+图形编程)
  3.   实验二百三十八:ESP32开发板WiFi蓝牙2.8寸240*320智能液晶显示屏带触摸屏TFT模块
  4.   项目实验之二十二:带 LVGL 的 ESP32 CYD:使用 DS18B20 传感器显示温度(曲面仪表)
  5. */
  6. // 包含LVGL库
  7. #include <lvgl.h>
  8. // 安装“TFT_eSPI”库来与TFT显示屏接口 - https://github.com/Bodmer/TFT_eSPI - 重要:网上的User_Setup.h可能无法与Random Nerd Tutorials的示例配合使用
  9. #include <TFT_eSPI.h>
  10. // 安装OneWire和DallasTemperature库
  11. #include <OneWire.h>
  12. #include <DallasTemperature.h>
  13. // DS18B20传感器连接到的GPIO
  14. const int oneWireBus = 27;
  15. // 设置一个OneWire实例与任何OneWire设备通信
  16. OneWire oneWire(oneWireBus);
  17. // 将OneWire引用传递给Dallas Temperature传感器
  18. DallasTemperature sensors(&oneWire);
  19. // 设置变量为0表示华氏温度
  20. #define TEMP_CELSIUS 1
  21. #if TEMP_CELSIUS
  22. #define TEMP_ARC_MIN -20
  23. #define TEMP_ARC_MAX 40
  24. #else
  25. #define TEMP_ARC_MIN -4
  26. #define TEMP_ARC_MAX 104
  27. #endif
  28. #define SCREEN_WIDTH 240
  29. #define SCREEN_HEIGHT 320
  30. #define DRAW_BUF_SIZE (SCREEN_WIDTH * SCREEN_HEIGHT / 10 * (LV_COLOR_DEPTH / 8))
  31. uint32_t draw_buf[DRAW_BUF_SIZE / 4];
  32. // 如果启用日志,它将通知用户库中发生了什么
  33. void log_print(lv_log_level_t level, const char* buf) {
  34.   LV_UNUSED(level);
  35.   Serial.println(buf);
  36.   Serial.flush();
  37. }
  38. lv_obj_t* arc;
  39. // 在弧形图和文本标签中设置温度值
  40. static void set_temp(void* text_label_temp_value, int32_t v) {
  41.   sensors.requestTemperatures();
  42. // 获取最新的温度读数(摄氏度或华氏度)
  43. #if TEMP_CELSIUS
  44.   float ds18b20_temp = sensors.getTempCByIndex(0);
  45.   if (ds18b20_temp <= 10.0) {
  46.     lv_obj_set_style_text_color((lv_obj_t*)text_label_temp_value, lv_palette_main(LV_PALETTE_BLUE), 0);
  47.   } else if (ds18b20_temp > 10.0 && ds18b20_temp <= 29.0) {
  48.     lv_obj_set_style_text_color((lv_obj_t*)text_label_temp_value, lv_palette_main(LV_PALETTE_GREEN), 0);
  49.   } else {
  50.     lv_obj_set_style_text_color((lv_obj_t*)text_label_temp_value, lv_palette_main(LV_PALETTE_RED), 0);
  51.   }
  52.   const char degree_symbol[] = "\u00B0C";
  53. #else
  54.   float ds18b20_temp = sensors.getTempFByIndex(0);
  55.   if (ds18b20_temp <= 50.0) {
  56.     lv_obj_set_style_text_color((lv_obj_t*)text_label_temp_value, lv_palette_main(LV_PALETTE_BLUE), 0);
  57.   } else if (ds18b20_temp > 50.0 && ds18b20_temp <= 84.2) {
  58.     lv_obj_set_style_text_color((lv_obj_t*)text_label_temp_value, lv_palette_main(LV_PALETTE_GREEN), 0);
  59.   } else {
  60.     lv_obj_set_style_text_color((lv_obj_t*)text_label_temp_value, lv_palette_main(LV_PALETTE_RED), 0);
  61.   }
  62.   const char degree_symbol[] = "\u00B0F";
  63. #endif
  64.   lv_arc_set_value(arc, map(int(ds18b20_temp), TEMP_ARC_MIN, TEMP_ARC_MAX, 0, 100));
  65.   String ds18b20_temp_text = String(ds18b20_temp) + degree_symbol;
  66.   lv_label_set_text((lv_obj_t*)text_label_temp_value, ds18b20_temp_text.c_str());
  67.   Serial.print("Temperature: ");
  68.   Serial.println(ds18b20_temp_text);
  69. }
  70. void lv_create_main_gui(void) {
  71.   // 创建一个弧形图
  72.   arc = lv_arc_create(lv_screen_active());
  73.   lv_obj_set_size(arc, 210, 210);
  74.   lv_arc_set_rotation(arc, 135);
  75.   lv_arc_set_bg_angles(arc, 0, 270);
  76.   lv_obj_set_style_arc_color(arc, lv_color_hex(0x666666), LV_PART_INDICATOR);
  77.   lv_obj_set_style_bg_color(arc, lv_color_hex(0x333333), LV_PART_KNOB);
  78.   lv_obj_align(arc, LV_ALIGN_CENTER, 0, 10);
  79.   // 创建一个字体大小为32的文本标签来显示最新的温度读数
  80.   lv_obj_t* text_label_temp_value = lv_label_create(lv_screen_active());
  81.   lv_label_set_text(text_label_temp_value, "--.--");
  82.   lv_obj_align(text_label_temp_value, LV_ALIGN_CENTER, 0, 10);
  83.   static lv_style_t style_temp;
  84.   lv_style_init(&style_temp);
  85.   lv_style_set_text_font(&style_temp, &lv_font_montserrat_32);
  86.   lv_obj_add_style(text_label_temp_value, &style_temp, 0);
  87.   // 创建一个动画,每10秒更新一次最新的温度值
  88.   lv_anim_t a_temp;
  89.   lv_anim_init(&a_temp);
  90.   lv_anim_set_exec_cb(&a_temp, set_temp);
  91.   lv_anim_set_duration(&a_temp, 1000000);
  92.   lv_anim_set_playback_duration(&a_temp, 1000000);
  93.   lv_anim_set_var(&a_temp, text_label_temp_value);
  94.   lv_anim_set_values(&a_temp, 0, 100);
  95.   lv_anim_set_repeat_count(&a_temp, LV_ANIM_REPEAT_INFINITE);
  96.   lv_anim_start(&a_temp);
  97. }
  98. void setup() {
  99.   String LVGL_Arduino = String("LVGL Library Version: ") + lv_version_major() + "." + lv_version_minor() + "." + lv_version_patch();
  100.   Serial.begin(115200);
  101.   Serial.println(LVGL_Arduino);
  102.   // 启动DS18B20传感器
  103.   sensors.begin();
  104.   // 启动LVGL
  105.   lv_init();
  106.   // 注册打印函数用于调试
  107.   lv_log_register_print_cb(log_print);
  108.   // 创建显示对象
  109.   lv_display_t* disp;
  110.   // 使用TFT_eSPI库初始化TFT显示屏
  111.   disp = lv_tft_espi_create(SCREEN_WIDTH, SCREEN_HEIGHT, draw_buf, sizeof(draw_buf));
  112.   lv_display_set_rotation(disp, LV_DISPLAY_ROTATION_270);
  113.   // 绘制GUI
  114.   lv_create_main_gui();
  115. }
  116. void loop() {
  117.   lv_task_handler();  // 让GUI完成它的工作
  118.   lv_tick_inc(5);     // 告诉LVGL已经过去了多长时间
  119.   delay(5);           // 让这段时间过去吧
  120. }
复制代码


回复

使用道具 举报

驴友花雕  中级技神
 楼主|

发表于 2024-11-14 13:32:06

【花雕学编程】Arduino动手做(238)---ESP32 CYD屏显示温度

此代码通过ESP32控制一个DS18B20温度传感器和一个TFT显示屏,并且使用LVGL库在显示屏上显示温度信息。

代码说明:

  1. #include <lvgl.h>
复制代码

这是LVGL(Light and Versatile Graphics Library)的头文件,它用来创建图形用户界面(GUI)。


  1. #include <TFT_eSPI.h>
复制代码

此头文件是TFT_eSPI库,用来与TFT显示屏接口。


  1. #include <OneWire.h>
  2. #include <DallasTemperature.h>
复制代码

这两个头文件分别是OneWire和DallasTemperature库,用来与DS18B20温度传感器通信。


  1. const int oneWireBus = 27;
  2. OneWire oneWire(oneWireBus);
  3. DallasTemperature sensors(&oneWire);
复制代码

定义了DS18B20传感器的数据引脚为27,并初始化OneWire实例和DallasTemperature实例。


  1. #define TEMP_CELSIUS 1   
  2. #if TEMP_CELSIUS
  3.   #define TEMP_ARC_MIN -20
  4.   #define TEMP_ARC_MAX 40
  5. #else
  6.   #define TEMP_ARC_MIN -4
  7.   #define TEMP_ARC_MAX 104
  8. #endif
复制代码

定义了温度单位为摄氏度或华氏度,根据选择不同的温度范围。


  1. #define SCREEN_WIDTH 240
  2. #define SCREEN_HEIGHT 320
  3. #define DRAW_BUF_SIZE (SCREEN_WIDTH * SCREEN_HEIGHT / 10 * (LV_COLOR_DEPTH / 8))
  4. uint32_t draw_buf[DRAW_BUF_SIZE / 4];
复制代码

定义了屏幕宽度和高度,并根据屏幕大小定义绘图缓冲区。


  1. void log_print(lv_log_level_t level, const char * buf) {
  2.   LV_UNUSED(level);
  3.   Serial.println(buf);
  4.   Serial.flush();
  5. }
复制代码

这是LVGL库的日志打印函数,用于在串口监视器中输出调试信息。


  1. lv_obj_t * arc;
复制代码

定义了一个LVGL对象arc,用于绘制圆弧。


  1. static void set_temp(void * text_label_temp_value, int32_t v) {
  2.   sensors.requestTemperatures();
  3.   #if TEMP_CELSIUS
  4.     float ds18b20_temp = sensors.getTempCByIndex(0);
  5.     if(ds18b20_temp <= 10.0) {
  6.       lv_obj_set_style_text_color((lv_obj_t*) text_label_temp_value, lv_palette_main(LV_PALETTE_BLUE), 0);
  7.     }
  8.     else if (ds18b20_temp > 10.0 && ds18b20_temp <= 29.0) {
  9.       lv_obj_set_style_text_color((lv_obj_t*) text_label_temp_value, lv_palette_main(LV_PALETTE_GREEN), 0);
  10.     }
  11.     else {
  12.       lv_obj_set_style_text_color((lv_obj_t*) text_label_temp_value, lv_palette_main(LV_PALETTE_RED), 0);
  13.     }
  14.     const char degree_symbol[] = "\u00B0C";
  15.   #else
  16.     float ds18b20_temp = sensors.getTempFByIndex(0);
  17.     if(ds18b20_temp <= 50.0) {
  18.       lv_obj_set_style_text_color((lv_obj_t*) text_label_temp_value, lv_palette_main(LV_PALETTE_BLUE), 0);
  19.     }
  20.     else if (ds18b20_temp > 50.0 && ds18b20_temp <= 84.2) {
  21.       lv_obj_set_style_text_color((lv_obj_t*) text_label_temp_value, lv_palette_main(LV_PALETTE_GREEN), 0);
  22.     }
  23.     else {
  24.       lv_obj_set_style_text_color((lv_obj_t*) text_label_temp_value, lv_palette_main(LV_PALETTE_RED), 0);
  25.     }
  26.     const char degree_symbol[] = "\u00B0F";
  27.   #endif
  28.   lv_arc_set_value(arc, map(int(ds18b20_temp), TEMP_ARC_MIN, TEMP_ARC_MAX, 0, 100));
  29.   String ds18b20_temp_text = String(ds18b20_temp) + degree_symbol;
  30.   lv_label_set_text((lv_obj_t*) text_label_temp_value, ds18b20_temp_text.c_str());
  31.   Serial.print("Temperature: ");
  32.   Serial.println(ds18b20_temp_text);
  33. }
复制代码


该函数从DS18B20传感器读取温度数据,并根据温度值设置颜色和文本。在指定的LVGL对象上显示温度信息。

回复

使用道具 举报

驴友花雕  中级技神
 楼主|

发表于 2024-11-14 13:33:45

【花雕学编程】Arduino动手做(238)---ESP32 CYD屏显示温度

  1. void lv_create_main_gui(void) {
  2.   arc = lv_arc_create(lv_screen_active());
  3.   lv_obj_set_size(arc, 210, 210);
  4.   lv_arc_set_rotation(arc, 135);
  5.   lv_arc_set_bg_angles(arc, 0, 270);
  6.   lv_obj_set_style_arc_color(arc, lv_color_hex(0x666666), LV_PART_INDICATOR);
  7.   lv_obj_set_style_bg_color(arc, lv_color_hex(0x333333), LV_PART_KNOB);
  8.   lv_obj_align(arc, LV_ALIGN_CENTER, 0, 10);
  9.   lv_obj_t * text_label_temp_value = lv_label_create(lv_screen_active());
  10.   lv_label_set_text(text_label_temp_value, "--.--");
  11.   lv_obj_align(text_label_temp_value, LV_ALIGN_CENTER, 0, 10);
  12.   static lv_style_t style_temp;
  13.   lv_style_init(&style_temp);
  14.   lv_style_set_text_font(&style_temp, &lv_font_montserrat_32);
  15.   lv_obj_add_style(text_label_temp_value, &style_temp, 0);
  16.   lv_anim_t a_temp;
  17.   lv_anim_init(&a_temp);
  18.   lv_anim_set_exec_cb(&a_temp, set_temp);
  19.   lv_anim_set_duration(&a_temp, 1000000);
  20.   lv_anim_set_playback_duration(&a_temp, 1000000);
  21.   lv_anim_set_var(&a_temp, text_label_temp_value);
  22.   lv_anim_set_values(&a_temp, 0, 100);
  23.   lv_anim_set_repeat_count(&a_temp, LV_ANIM_REPEAT_INFINITE);
  24.   lv_anim_start(&a_temp);
  25. }
复制代码

该函数创建主界面,包括温度显示的圆弧和文本标签,并设置动画定时更新温度数据。


  1. void setup() {
  2.   String LVGL_Arduino = String("LVGL Library Version: ") + lv_version_major() + "." + lv_version_minor() + "." + lv_version_patch();
  3.   Serial.begin(115200);
  4.   Serial.println(LVGL_Arduino);
  5.   sensors.begin();
  6.   lv_init();
  7.   lv_log_register_print_cb(log_print);
  8.   lv_display_t * disp;
  9.   disp = lv_tft_espi_create(SCREEN_WIDTH, SCREEN_HEIGHT, draw_buf, sizeof(draw_buf));
  10.   lv_display_set_rotation(disp, LV_DISPLAY_ROTATION_270);
  11.   
  12.   lv_create_main_gui();
  13. }
复制代码

该函数初始化串口、DS18B20传感器、LVGL库和TFT显示屏,并调用函数创建主界面。


  1. void loop() {
  2.   lv_task_handler();
  3.   lv_tick_inc(5);
  4.   delay(5);
  5. }
复制代码

在主循环中,持续更新LVGL的任务处理和时间,以确保图形用户界面正常运行。

回复

使用道具 举报

驴友花雕  中级技神
 楼主|

发表于 2024-11-14 13:36:58

【花雕学编程】Arduino动手做(238)---ESP32 CYD屏显示温度

实验场景图

【花雕学编程】Arduino动手做(238)---ESP32 CYD屏显示温度图1
回复

使用道具 举报

驴友花雕  中级技神
 楼主|

发表于 2024-11-14 13:38:41

【花雕学编程】Arduino动手做(238)---ESP32 CYD屏显示温度

【花雕学编程】Arduino动手做(238)---ESP32 CYD屏显示温度图1

【花雕学编程】Arduino动手做(238)---ESP32 CYD屏显示温度图2
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

为本项目制作心愿单
购买心愿单
心愿单 编辑
[[wsData.name]]

硬件清单

  • [[d.name]]
btnicon
我也要做!
点击进入购买页面
上海智位机器人股份有限公司 沪ICP备09038501号-4 备案 沪公网安备31011502402448

© 2013-2025 Comsenz Inc. Powered by Discuz! X3.4 Licensed

mail