GUI 优化解决方案
ESP LVGL Adapter
ESP LVGL Adapter 是专为 ESP32 全系列芯片设计的高性能 LVGL 适配层,针对屏幕撕裂与帧率进行了深度优化,并无缝集成了图片解码、FreeType 字体渲染和 Dummy Draw 等高级特性,为开发者提供真正的开箱即用体验。
组件链接:https://components.espressif.com/components/espressif/esp_lvgl_adapter
相关示例:
https://github.com/espressif/esp-iot-solution/tree/master/examples/display/gui/lvgl_common_demo
https://github.com/espressif/esp-iot-solution/tree/master/examples/display/gui/lvgl_dummy_draw
https://github.com/espressif/esp-iot-solution/tree/master/examples/display/gui/lvgl_decode_image
https://github.com/espressif/esp-iot-solution/tree/master/examples/display/gui/lvgl_freetype_font
https://github.com/espressif/esp-iot-solution/tree/master/examples/display/gui/lvgl_multi_screen
https://github.com/espressif/esp-iot-solution/tree/master/examples/display/gui/lvgl_mono_demo
ESP LVGL EAF Player
esp_lv_eaf_player 是一款专为 LVGL v8/v9 设计的轻量级高效 EAF 动画播放器。它可以将压缩动画序列无缝集成到 LVGL 项目中。EAF 格式支持多种压缩方法,包括 RLE、Huffman 编码和 JPEG 压缩,在保持高质量动画的同时最大限度地减少内存占用。
特性:
支持多种压缩方式:RLE、Huffman、JPEG
针对嵌入式优化:内存占用小,解码效率高
LVGL 集成:与 LVGL 控件系统无缝集成
动画控制:播放、暂停、重启和循环控制
适用场景:
使用 LVGL v8/v9 需要播放高质量动画的用户
需要在资源受限平台上实现高效动画播放
EAF 文件转换:可使用在线转换工具将 GIF 或其他动画格式转换为 EAF 格式:https://esp32-gif.espressif.com/
组件链接:https://components.espressif.com/components/espressif/esp_lv_eaf_player
相关示例:
Thorvg 组件
支持 Lottie 动画和 TVG 矢量图形解析渲染刷图,noglic 版本支持
组件链接:https://components.espressif.com/components/espressif/thorvg
相关示例:
tinyGL 3D 图形库
tinyGL 是一个轻量级的 3D 图形库,支持 OpenGL ES 1.1 的子集,适用于 ESP32-P4 平台。
适用场景:
需要实现 3D 图形渲染。
SDL3 开发库
SDL 是一个跨平台的开发库,旨在通过 OpenGL/Direct3D/Metal/Vulkan 提供对音频、键盘、鼠标、摇杆和图形硬件的低级访问。它被视频播放软件、模拟器以及包括 Valve 获奖游戏在内的许多流行游戏和 Humble Bundle 游戏使用。
适用场景:
有模拟器开发、游戏移植和跨平台应用开发需求的用户。
组件链接:https://components.espressif.com/components/georgik/sdl/versions/3.1.2~9
esp_lv_lottie_player
esp_lv_lottie_player 是一款专为 LVGL v8/v9 设计的轻量级高效 Lottie 动画播放器。它可以将基于矢量的动画无缝集成到 LVGL 项目中。通过利用 ThorVG 作为渲染引擎,该模块确保了现代嵌入式 GUI 应用程序的高性能和灵活性。
适用场景:
使用 LVGL v8/v9 需要播放 Lottie 动画的用户
组件链接:https://components.espressif.com/components/espressif/esp_lv_lottie_player
相关示例:
esp_emote_gfx
esp_emote_gfx 是一款面向资源受限平台的轻量级动画渲染库,支持将 GIF 转换为自定义 EAF 动画格式进行播放,具备解码快、内存占用小、显示灵活的优势,适用于 HMI 场景中的高效动态图形播放需求。
特性:
支持文字滚动效果
支持同时播放多个动图,帧率独立控制
适应多尺寸屏幕
适用场景:
各类屏幕上的引导动效、开机动画、表情和文字渲染等
资源受限平台(ESP32-C2/C3 等)上的动态 UI 组件展示
组件链接:https://components.espressif.com/components/espressif2022/esp_emote_gfx/
esp_emote_expression
esp_emote_expression 是基于 esp_emote_gfx 构建的表情与界面描述系统,提供完整的资源解析、加载与生命周期管理能力,并支持第三方自定义控件扩展。可作为 AI 交互设备的基础 UI 框架使用。
系统覆盖 AI 对话常见的 UI 场景,包括:
表情与动画显示
文本渲染(系统提示、用户消息等)
状态图标(说话中、聆听中等)
二维码展示
弹窗与提示组件
适用场景:
AI 交互设备的基础 UI 框架
需要完整 UI 资源管理和控件扩展的嵌入式设备
已适配的仓库:
rainmaker agent:https://github.com/espressif/esp-agents-firmware
快速开始:
gfx-gen-tool:https://gfx-gen-tool.pages.dev/
本地预置资源:https://components.espressif.com/components/espressif2022/esp_emote_assets
组件链接:https://components.espressif.com/components/espressif2022/esp_emote_expression