基于ESP32S3的智能终端项目--3.quareLine Studio 绘制 LVGL 界面

在嵌入式 GUI 开发中,手动编写每个控件的位置和样式非常耗时。SquareLine Studio 是一个强大的拖拽式 LVGL 界面设计工具,可以让我们像画图一样设计界面,并自动生成 C 代码。本文将带你快速上手:从安装、设计到移植到 ESP32-S3 的 PlatformIO 工程。

1. 安装 SquareLine Studio

  • 下载 SquareLine Studio V1.5.0 安装包(官网或网盘)。

  • 双击安装,一路 Next 即可。

2. 创建新工程

打开软件,点击 File -> New,选择 Arduino with TFT_eSPI(版本选 v1.1.1)。右侧面板设置:

  • Project Name :自定义,如 ESP32_S3_Terminal

  • Resolution320x240(与你的屏幕匹配)

  • Rotation0 degree

  • Color Depth16 bit

  • LVGL Version8.3.6(与项目中 LVGL 版本一致)

    其他默认,点击 Create。

3. 设计界面(简要)

  • 左侧控件库拖拽按钮、标签、面板等到画布上。

  • 右侧属性面板调整大小、对齐、样式。

  • 可添加多个屏幕(Screen),并通过"Initial actions"设置启动屏幕。

4. 导入图标和字体(可选)

  • iconfont 下载 PNG 图标或 TTF 字体文件。

  • 点击右下角 ADD FILE INTO ASSETS,导入资源,之后可在界面中使用。

5. 导出 UI 代码

设计完成后,点击菜单 File -> Export -> Create Template Project,选择一个文件夹保存。导出的工程中包含 libraries/ui 文件夹,这就是我们需要的 UI 源代码。

6. 移植到 PlatformIO 工程

  • 打开你的 ESP32-S3 PlatformIO 项目(比如 esp32-lvgl-terminal)。

  • 将导出的 ui 文件夹整个复制到项目的 src 目录下(最终路径:src/ui/)。

  • src/main.cpp 中包含 UI 头文件:

    cs 复制代码
    cpp
    
    #include "ui/ui.h"
  • setup() 函数中,完成 LVGL、显示器和触摸初始化 之后 ,调用 ui_init()

    cs 复制代码
    cpp
    
    void setup() {
        Serial.begin(115200);
        lv_init();
        tft.begin();
        touch.begin(); // 如果有触摸
        ui_init();     // 加载 SquareLine 设计的界面
        // 其他初始化(如任务创建)
    }

7. 编译与烧录

  • 点击 PlatformIO 底部工具栏的 ✓ 编译,→ 上传。

  • 如果一切顺利,屏幕将显示你在 SquareLine Studio 中设计的界面。

注意事项

  • 确保 SquareLine 导出的 LVGL 版本(8.3.6)与项目中 lv_conf.h 配置的版本一致。

  • 如果屏幕方向不对,可在 lv_conf.h 或 TFT_eSPI 的 User_Setup.h 中调整旋转。

  • 控件的事件回调(如按钮点击)需要在生成的 UI 文件中手动添加(后续可再写一篇事件处理教程)。

相关推荐
xuhaoyu_cpp_java1 天前
项目学习(三)分页查询
java·经验分享·笔记·学习
Cloud_Shy6181 天前
解读《Effective Python 3rd Edition》:从练气到老魔(第五章 Item 33 - 35)
开发语言·人工智能·笔记·python·学习方法
做cv的小昊1 天前
计算机图形学:【Games101】学习笔记08——光线追踪(辐射度量学、渲染方程与全局光照、蒙特卡洛积分与路径追踪)
图像处理·笔记·学习·计算机视觉·游戏引擎·图形渲染·概率论
星恒随风1 天前
C++ 类和对象入门(五):初始化列表、explicit 和 static 成员详解
开发语言·c++·笔记·学习·状态模式
伊布拉西莫1 天前
【流畅的Python】第20章:并发执行器 — 学习笔记
笔记·python·学习
AOwhisky1 天前
学习自测与解析:MySQL第五、六、七期核心知识点详解
运维·数据库·笔记·学习·mysql·云计算
niuniuyi~1 天前
QT学习笔记
笔记·qt·学习
咸甜适中1 天前
rust语言学习笔记Trait(十六)Error(错误)
笔记·学习·rust
xuhaoyu_cpp_java1 天前
项目学习(三)代码生成器
java·经验分享·笔记·学习
my_daling1 天前
松下伺服驱动器参数保存流程(已在松下A5上验证)
笔记