Arduino ESP32/ESP8266 +ST7735 1.8“tft中秋小时钟

Arduino ESP32 +ST7735 1.8"tft中秋小时钟


  • 🌼原作者B站视频:

ESP32中秋小时钟,表盘自动切换,代码开源,原图可下载(案例应用)

  • 🎞tft ST7735 128160 1.8" 显示效果:(由于原作者提供的素材是128128的素材,在128*160屏幕上显示,所以下面有一部分是雪花)

在这里插入图片描述

📚原创作者的资源
链接: https://pan.baidu.com/s/1xO-eux35rcmTasQyp8qz2g?pwd=65mp 
提取码: 65mp

📑引脚定义

  • 🌿 ESP32,基于tft1.8" ST7735显示屏,TFT_eSPI库,User_Setup.h头文件相关参数调整:
// For ESP32 Dev board (only tested with GC9A01 display)
// The hardware SPI can be mapped to any pins#define TFT_MOSI 23 // In some display driver board, it might be written as "SDA" and so on.
#define TFT_SCLK 18
#define TFT_CS   5  // Chip select control pin
#define TFT_DC   19  // Data Command control pin
#define TFT_RST  21  // Reset pin (could connect to Arduino RESET pin)
#define TFT_BL   22  // LED back-light
//#define TOUCH_CS 21     // Chip select pin (T_CS) of touch screen//#define TFT_WR 22    // Write strobe for modified Raspberry Pi TFT only

在这里插入图片描述

  • 🌿ESP8266,基于tft1.8" ST7735显示屏,TFT_eSPI库,User_Setup.h头文件相关参数调整:
// For NodeMCU - use pin numbers in the form PIN_Dx where Dx is the NodeMCU pin designation
#define TFT_CS   PIN_D8  // Chip select control pin D8
#define TFT_DC   PIN_D3  // Data Command control pin
#define TFT_RST  PIN_D4  // Reset pin (could connect to NodeMCU RST, see next line)
//#define TFT_RST  -1    // Set TFT_RST to -1 if the display RESET is connected to NodeMCU RST or 3.3V//#define TFT_BL PIN_D1  // LED back-light (only for ST7789 with backlight control pin)
//#define TOUCH_CS PIN_D2     // Chip select pin (T_CS) of touch screen
SDA ---- D7
SCL ---- D5
CS  ---- D8
DC  ---- D3
BL ---- 3.3V

在这里插入图片描述

📓依赖库

  • 🔧依赖库:TFT_eSPI、NTPClient
    • 🌿TFT_eSPI // 在Arduino IDE中点击后面链接会,自动打开管理库页面: http://librarymanager/All#TFT_eSPI
      在这里插入图片描述
    • 🌿NTPClient // 在Arduino IDE中点击后面链接,会自动打开管理库页面: http://librarymanager/All#NTPClient
      在这里插入图片描述

📑Debug主程序

  • ⚡需要注意ESP32和ESP8266在处理时间数据上有个别参数存在差异。代码已适配好了,兼容ESP8266和ESP32,修复了所发现的原作者有bug的地方,并烧录了ESP32和esp8266实测验证过显示正常,没有问题。
/** - 依赖库:TFT_eSPI、NTPClient* - TFT_eSPI // 点击这里会自动打开管理库页面: http://librarymanager/All#TFT_eSPI* - NTPClient  // 点击这里会自动打开管理库页面: http://librarymanager/All#NTPClient* 安装号对应的库后,找到TFT_eSPI安装位置:C:\Users\Administrator\Documents\Arduino\libraries\TFT_eSPI* 修改"User_Setup.h"修改屏幕驱动型号,根据个人所使用的屏幕型号和规格设定。基于ST7735 1.8"tft driver参数//显示长宽设置:TFT_WIDTH:128; TFT_HEIGHT  160======= ESP32 =======#define TFT_MOSI 15 //D15 In some display driver board, it might be written as "SDA" and so on.#define TFT_SCLK 14 //D14#define TFT_CS   5  //D5 Chip select control pin#define TFT_DC   27  //D27 Data Command control pin#define TFT_RST  33  //D33 Reset pin (could connect to Arduino RESET pin)#define TFT_BL   22  //D22 LED back-light======= ESP8266 =======
GPIO14(D5) — CLK
GPIO12(D6) — MISO(RES)
GPIO13(D7) — MOSI(SDA)
GPIO0 (D3) ------ DC
GPIO 15(D8) — CS(SS)
BL ------ VCC*/#ifdef ESP32
#include <WiFi.h>
#else
#include <ESP8266WiFi.h>
//  #include <WiFiClient.h>//3.0.2新增
//  #include <ESP8266HTTPClient.h>
#endif
//#include <Ticker.h>
// 获取网络时间相关库
#include <NTPClient.h>
#include <WiFiUdp.h>
#include <SPI.h>
// TFT显示库
#include <TFT_eSPI.h>//显示长宽设置:TFT_HEIGHT:128; TFT_WIDTH  160// 导入图片
#include "clock1.h"
#include "moon1.h"
#include "moon2.h"
#include "moon3.h"
#include "moon4.h"
#include "moon5.h"
// 导入字库
#include "noto10.h"
#include "noto20.h"
#include "clock10.h"
#include "clock20.h"#define SERIAL_DEBUG    //是否开启串口调试信息输出
// 网络时间相关定义
const char *ssid = "MERCURY_D268G";           // WiFi账号
const char *password = "pba5ayzk";  // WiFi密码
WiFiUDP ntpUDP;
NTPClient timeClient(ntpUDP, "ntp.aliyun.com");  // NTP服务器地址// 实例化定时器对象
//Ticker time1;
//Ticker time2;
//Ticker time3;
//Ticker time4;void updateTime();
void clockStyle();
void moonStyle1();
void moonStyle2();
/*void Ticker_Task1() {// 切换到样式1clockStyle();}void Ticker_Task2() {// 切换到样式1moonStyle1();}void Ticker_Task3() {// 切换到样式2moonStyle2();}void Ticker_Task3() {//更新时间updateTime();}
*/
// TFT相关定义
TFT_eSPI tft = TFT_eSPI();
TFT_eSprite sprite = TFT_eSprite(&tft);  // 创建一个 TFT_eSprite 对象,tft 是你的 TFT 显示对象// 定义一个字符串数组,用于存储星期描述,将星期几换成中文
const char weekdays_en[][4] = { "Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat" };
const char weekdays_cn[][7] = {  "周日", "周一", "周二", "周三", "周四", "周五", "周六" };//定义时间用变量
int16_t currentYear = 0;
int16_t currentWeekDay = 0;
int16_t currentMonth = 0;
int16_t currentMonthDay = 0;
int16_t currentHour = 0;
int16_t currentMin = 0;
int16_t currentSec = 0;unsigned long lastTime = 0;
//设置每1秒获得一次
unsigned long timerDelay = 5000;void setup() {#ifdef SERIAL_DEBUGSerial.begin(115200);  // 初始化串口通信,波特率为115200#endif// ===网络时间初始化设定===// 连接WiFiWiFi.begin(ssid, password);while (WiFi.status() != WL_CONNECTED) {  // 等待WiFi连接成功delay(500);#ifdef SERIAL_DEBUGSerial.print(".");#endif}timeClient.begin();               // 初始化NTPClienttimeClient.setTimeOffset(28800);  // 时区设置,时间偏移为28800秒(8小时)// ===TFT初始化设定===tft.begin();                    // 初始化显示寄存器tft.setRotation(0);             // 设置显示屏旋转角度(0表示不旋转,根据需要调整)sprite.setColorDepth(16);       // 设置颜色深度(根据你的需求)sprite.setSwapBytes(true);      // 设置字节顺序,将RGB颜色顺序转换为BGR以正确显示颜色。sprite.createSprite(160, 128);  // 创建一个128x160像素的绘图窗口//  time1.attach(3, clockStyle); // 设置定时器,每隔 1 秒钟调用一次 Ticker_Task1 函数//  time2.attach(6, moonStyle1); // 设置定时器,每隔 1 秒钟调用一次 Ticker_Task2 函数//  time3.attach(9, moonStyle2); // 设置定时器,每隔 1 秒钟调用一次 Ticker_Task2 函数//  time4.attach(1, updateTime);
}void loop() {if ((millis() - lastTime) > timerDelay) {updateTime();if (currentSec % 3 == 0) {// 切换到样式1clockStyle();} else if (currentSec % 3 == 1) {// 切换到样式2moonStyle1();} else {// 切换到样式3moonStyle2();}lastTime = millis();}//  delay(1000);  // 延迟1秒,每秒更新一次}void updateTime() {timeClient.update();                                  // 更新时间信息unsigned long epochTime = timeClient.getEpochTime();  // 获取当前时间的时间戳#ifdef ESP32struct tm *ptm = gmtime((time_t *)&epochTime);  // 将时间戳转换为tm结构体#elsetime_t  ntpTime =(time_t)epochTime;struct tm *ptm = localtime(&ntpTime); // 将时间戳转换为tm结构体#endif// 将epochTime换算成年月日  currentYear = ptm->tm_year + 1900;              // 获取年份currentMonth = ptm->tm_mon + 1;                 // 获取月份currentMonthDay = ptm->tm_mday;                 // 获取月份中的日期#ifdef ESP32currentWeekDay = ptm->tm_wday;                  // 获取星期几if (currentWeekDay < 0) {currentWeekDay += 7;  // 将负数转换为正数}currentHour = ptm->tm_hour;  // 获取时currentMin = ptm->tm_min;    // 获取分currentSec = ptm->tm_sec;    // 获取秒#else  currentHour = timeClient.getHours();  // 获取时currentMin = timeClient.getMinutes();    // 获取分currentSec = timeClient.getSeconds();    // 获取秒currentWeekDay = timeClient.getDay();    // 获取星期几#endif#ifdef SERIAL_DEBUG// 打印时间Serial.println("Epoch Time: " + String(epochTime));  // 打印时间戳Serial.println(timeClient.getFormattedTime());       // 打印时间格式Serial.printf("NTP Time: %04d-%02d-%02d\n", currentYear, currentMonth, currentMonthDay);#endif}void clockStyle() {// tft显示时间sprite.fillScreen(TFT_BLACK);              // 清屏sprite.pushImage(0, 0, 128, 160, clock1);  // 显示底图sprite.setTextColor(TFT_PINK);  // 设置字体颜色为白色TFT_WHITE  粉色TFT_PINKsprite.setCursor(55, 35);                   // 设定打印位置sprite.loadFont(noto10);                    // 设定显示字体sprite.print(weekdays_cn[currentWeekDay]);  // 打印 星期几sprite.setCursor(52, 47);      // 设定打印位置currentMonthDay >9 ? sprite.print(String(currentMonth) + "/" + String(currentMonthDay)): sprite.print(String(currentMonth) + "/0" + String(currentMonthDay));  // 打印 月/日sprite.setCursor(43, 60);                                      // 设定打印位置sprite.loadFont(noto20);                                       // 设定显示字体currentMin >9?sprite.print(String(currentHour) + ":" + String(currentMin)):sprite.print(String(currentHour) + ":0" + String(currentMin));  // 打印 时:分sprite.setCursor(60, 80);          // 设定打印位置sprite.loadFont(noto10);           // 设定显示字体currentSec>9 ? sprite.print(String(currentSec)):sprite.print( "0" + String(currentSec));  // 打印 秒sprite.pushSprite(0, 0);  // 将 sprite 显示在指定的屏幕位置 (0, 0)
}
void moonStyle1() {// tft显示时间sprite.fillScreen(TFT_BLACK);             // 清屏sprite.pushImage(0, 0, 128, 160, moon1);  // 显示底图sprite.setTextColor(TFT_PINK);  // 设置字体颜色为白色 TFT_WHITEsprite.loadFont(clock10);                                            // 设定显示字体sprite.setCursor(95, 10);                                            // 设定打印位置currentMonthDay >9 ? sprite.print(String(currentMonth) + "/" + String(currentMonthDay)): sprite.print(String(currentMonth) + "/0" + String(currentMonthDay));  // 打印 月/日sprite.setCursor(95, 20);                   // 设定打印位置sprite.loadFont(clock10);                   // 设定显示字体sprite.print(weekdays_en[currentWeekDay]);  // 打印 星期几sprite.setTextColor(TFT_PURPLE);                                // 设置字体颜色为白色sprite.setCursor(35, 20);                                      // 设定打印位置sprite.loadFont(clock10);                                      // 设定显示字体currentMin >9?sprite.print(String(currentHour) + ":" + String(currentMin)):sprite.print(String(currentHour) + ":0" + String(currentMin));  // 打印 时:分sprite.setCursor(43, 30);          // 设定打印位置sprite.loadFont(clock10);          // 设定显示字体currentSec >9 ? sprite.print(String(currentSec)):sprite.print( "0" + String(currentSec));  // 打印 秒sprite.pushSprite(0, 0);  // 将 sprite 显示在指定的屏幕位置 (0, 0)
}void moonStyle2() {sprite.fillScreen(TFT_BLACK);             // 清屏TFT_BLACK  TFT_PURPLEsprite.pushImage(0, 0, 128, 160, moon3);  // 显示底图,尺寸:128*160sprite.setTextColor(TFT_SKYBLUE);  // 设置字体颜色为白色TFT_WHITE  TFT_SKYBLUEsprite.loadFont(clock10);                                            // 设定显示字体sprite.setCursor(50, 40);                                            // 设定打印位置currentMonthDay >9 ? sprite.print(String(currentMonth) + "/" + String(currentMonthDay)): sprite.print(String(currentMonth) + "/0" + String(currentMonthDay));  // 打印 月/日  sprite.setCursor(55, 50);                   // 设定打印位置sprite.loadFont(clock10);                   // 设定显示字体sprite.print(weekdays_en[currentWeekDay]);  // 打印 星期几#ifdef SERIAL_DEBUGSerial.println(currentWeekDay);#endifsprite.setTextColor(TFT_PINK);                                // 设置字体颜色为黑色TFT_BLACK TFT_PINK   TFT_GOLD TFT_SKYBLUEsprite.setCursor(35, 10);                                      // 设定打印位置sprite.loadFont(clock20);                                      // 设定显示字体currentMin >9?sprite.print(String(currentHour) + ":" + String(currentMin)): sprite.print(String(currentHour) + ":0" + String(currentMin));  // 打印 时:分sprite.setCursor(55, 30);          // 设定打印位置sprite.loadFont(clock10);          // 设定显示字体currentSec>9 ? sprite.print(String(currentSec)):sprite.print( "0" + String(currentSec));  // 打印 秒sprite.pushSprite(0, 0);  // 将 sprite 显示在指定的屏幕位置 (0, 0)
}
  • 📜ESP8266串口打印信息:
    在这里插入图片描述

📚Debug程序和图片资料(128*128)

  • 🔖代码已适配兼容ESP8266和ESP32。
链接:https://pan.baidu.com/s/1PThuvRrMK3rVpjiaqGapMA 
提取码:463q

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/145987.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

MD5 绕过第二式:数组绕过

文章目录 参考环境推荐阅读强类型比较运算符雾来哈希碰撞目标 王小云院士与白宫密码王小云院士两度破译白宫密码白宫密码亮剑十年磨一剑 雾散曲径通幽WarningPHP 中的数组与 md5()尝试绕过PHP8 下的致命错误 参考 项目描述搜索引擎Bing、GoogleAI 大模型文心一言、通义千问、讯…

JavaScript中如何确定this的值?如何指定this的值?

&#x1f380;JavaScript中的this 在绝大多数情况下&#xff0c;函数的调用方法决定了this的值&#xff08;运行时绑定&#xff09;。this不能在执行期间被赋值&#xff0c;并且在每次函数呗调用时this的值也可能会不同。 &#x1f37f;如何确定this的值&#xff1a; 在非严格…

【React】React组件生命周期以及触发顺序(部分与vue做比较)

最近在学习React&#xff0c;发现其中的生命周期跟Vue有一些共同点&#xff0c;但也有比较明显的区别&#xff0c;并且执行顺序也值得讨论一下&#xff0c;于是总结了一些资料在这里&#xff0c;作为学习记录。 v17.0.1后生命周期图片 初始化阶段 由ReactDOM.render()触发 —…

【Axure】元件库和母版、常见的原型规范、静态原型页面制作

添加现有元件库 点击元件库——载入 当然也可以创建元件库&#xff0c;自己画自己保存 建立京东秒杀母版 静态原型页面的制作 框架 选择以iphone8的界面大小为例&#xff0c;顶部状态栏高度为20 左侧类似于标尺&#xff0c;因为图标、文字离最左侧的间距是不一样的 信…

Nat. Commun. | 大规模高分辨单光子成像

本文由论文作者团队(课题组)投稿 单光子雪崩二极管(Single Photon Avalanche Diode,简称SPAD)阵列因其极佳的单光子灵敏度而受到广泛关注,已广泛应用于量子通信与计算、荧光寿命成像、时间飞行成像等各个领域。与同样具有较高灵敏度的EMCCD和sCMOS相比,SPAD阵列能够在极…

车载ADB环境搭建

ADB是什么 ADB&#xff0c;即 Android Debug Bridge 是一种允许模拟器或已连接的 Android 设备进行通信的命令行工具&#xff0c;它可为各种设备操作提供便利&#xff0c;如安装和调试应用&#xff0c;并提供对 Unix shell&#xff08;可用来在模拟器或连接的设备上运行各种命…

SimpleCG动画示例--汉诺塔动画演示

前言 SimpleCG的使用方法在前面已经介绍了许多&#xff0c;有兴趣的同学如果有去动手&#xff0c;制作一些简单动画应该没多大问题的。所以这次我们来演示一下简单动画。我们刚学习C语言的递归函数时&#xff0c;有一个经典例子相信很多同学都写过&#xff0c;那就是汉诺塔。那…

【C++】多线程的学习笔记——白话文版(bushi

目录 为什么要使用多线程 例子 代码 结果 首先要先学的库——thread库 thread的简介 thread的具体使用方法 基本变量的定义 注意&#xff08;小重点&#xff09; join函数的解读&#xff08;重点&#xff09; detach函数的解读 注意 关于vector和thread是联合使用 …

【DLoopDetector(C++)】DBow2词袋模型loop close学习

0.前言 最近读了两篇论文&#xff0c;论文作者开源了一种基于词袋模型DBoW2库的DLoopDetector算法&#xff0c;自己运行demo测试一下 对应论文介绍&#xff1a;Bags of Binary Words for Fast Place Recognition in Image Sequences 开源项目Github地址&#xff1a;https://gi…

P1541 [NOIP2010 提高组] 乌龟棋(4维背包问题)

[NOIP2010 提高组] 乌龟棋 题目背景 小明过生日的时候&#xff0c;爸爸送给他一副乌龟棋当作礼物。 题目描述 乌龟棋的棋盘是一行 N N N 个格子&#xff0c;每个格子上一个分数&#xff08;非负整数&#xff09;。棋盘第 1 1 1 格是唯一的起点&#xff0c;第 N N N 格是…

C++代码示例:排列数简单生成工具

文章目录 前言代码仓库内容代码&#xff08;有详细注释&#xff09;编译和运行命令结果总结参考资料作者的话 前言 C代码示例&#xff1a;排列数简单生成工具。 代码仓库 yezhening/Programming-examples: 编程实例 (github.com)Programming-examples: 编程实例 (gitee.com) …

GEO生信数据挖掘(四)数据清洗(离群值处理、低表达基因、归一化、log2处理)

检索到目标数据集后&#xff0c;开始数据挖掘&#xff0c;本文以阿尔兹海默症数据集GSE1297为例 目录 离群值处理 删除 低表达基因 函数归一化&#xff0c;矫正差异 数据标准化—log2处理 完整代码 上节围绕着探针ID和基因名称做了一些清洗工作&#xff0c;还做了重复值检查…

牛客网_HJ2_计算某字符出现次数

HJ2_计算某字符出现次数 原题思路代码运行截图收获 原题 HJ2_计算某字符出现次数 思路 把输入的字符串和字符都变成大写或小写&#xff0c;然后逐一计数 代码 #include <cctype> #include <iostream> #include <string> #include <algorithm> usi…

java多线程相关介绍

1. 线程的创建和启动 在 Java 中创建线程有两种方式。一种是继承 Thread 类并重写其中的 run() 方法&#xff0c;另一种是实现 Runnable 接口并重写其中的 run() 方法。创建完线程对象后&#xff0c;调用 start() 方法可以启动线程。 2. 线程的状态 Java 的线程在不同阶段会处于…

C++八股

1、简述一下C中的多态 在面向对象中&#xff0c;多态是指通过基类的指针或引用&#xff0c;在运行时动态调用实际绑定对象函数的行为&#xff0c;与之相对应的编译时绑定函数称为静态绑定。 静态多态 静态多态是编译器在编译期间完成的&#xff0c;编译器会根据实参类型来选择…

自动驾驶技术:现状与未来

自动驾驶技术&#xff1a;现状与未来 文章目录 引言自动驾驶技术的现状自动驾驶技术的挑战自动驾驶技术的未来结论结论 2023星火培训【专项营】Apollo开发者社区布道师倾力打造&#xff0c;包含PnC、新感知等的全新专项课程上线了。理论与实践相结合&#xff0c;全新的PnC培训不…

Vim学习笔记

博客主页&#xff1a;https://tomcat.blog.csdn.net 博主昵称&#xff1a;农民工老王 主要领域&#xff1a;Java、Linux、K8S 期待大家的关注&#x1f496;点赞&#x1f44d;收藏⭐留言&#x1f4ac; 目录 模式介绍指令概览启动退出移动光标插入删除复制替换撤销搜索信息设置外…

Redis缓存穿透、击穿和雪崩

面试高频 服务的高可用问题&#xff01; 在这里我们不会详细的区分析解决方案的底层&#xff01; Redis缓存概念 Redis缓存的使用&#xff0c;极大的提升了应用程序的性能和效率&#xff0c;特别是数据查询方面。但同时&#xff0c;它也带来了一些问题。其中&#xff0c;最要…

Linux shell编程学习笔记4:修改命令行提示符格式(内容和颜色)

一、命令行提示符格式内容因shell类型而异 Linux终端命令行提示符内容格式则因shell的类型而异&#xff0c;例如CoreLinux默认的shell是sh&#xff0c;其命令行提示符为黑底白字&#xff0c;内容为&#xff1a; tcbox:/$ 其中&#xff0c;tc为当前用户名&#xff0c;box为主机…

【JVM】并发可达性分析-三色标记算法

欢迎访问&#x1f44b;zjyun.cc 可达性分析 为了验证堆中的对象是否为可回收对象&#xff08;Garbage&#xff09;标记上的对象&#xff0c;即是存活的对象&#xff0c;不会被垃圾回收器回收&#xff0c;没有标记的对象会被垃圾回收器回收&#xff0c;在标记的过程中需要stop…