Skip to content

Latest commit

 

History

History
51 lines (32 loc) · 3.07 KB

README.md

File metadata and controls

51 lines (32 loc) · 3.07 KB

GitHub Release Espressif Release

Arduino Lint Version Consistency

ESP-UI

Overview

esp-ui is a UI runtime framework based on LVGL, designed to provide a consistent UI development experience for screens of various sizes and shapes. The framework integrates a range of standardized system UIs and application management mechanisms, allowing users to flexibly modify styles, add or remove application UIs, significantly improving the development efficiency of HMI products, and accelerating product development and time-to-market.

Key features include:

  • Developed in C++, it can be compiled for PC or ESP SoCs platforms and supports VSCode, ESP-IDF, and Arduino development environments.
  • Offers a rich set of standardized system UIs with support for dynamic UI style adjustments.
  • Implements an app-based application management approach, ensuring UI isolation and coexistence across multiple apps, enabling users to focus on UI implementation within their target app.
  • Application UIs are compatible with "Squareline exported code" development methods.

The system UI functionality demonstration is as follows:

phone_demo

System UI - Phone


The functional block diagram of esp-ui is as follows, mainly consisting of the following components:

block_diagram

  • System UI Core: Implements the unified core logic of all system UIs, including app management, stylesheet management, event management, etc.
  • System UI Widgets: Encapsulates common widgets for system UIs, including status bar, navigation bar, gesture, etc.
  • System UIs: Implements various types of system UIs based on "System UI Core" and "System UI Widgets".
  • Squareline: Contains multiple versions of ui_helpers files exported from "Squareline Studio" to avoid function name conflicts when used across multiple apps.
  • Fonts: Contains the default fonts used by the system UIs.

Usage

Please refer to the documentation - How to Use.

System UIs

Currently, esp-ui offers the following system UIs:

System UI Widgets

Please refer to the documentation - System UI Widgets.