This repository contains public content related to the LVGL Editor.
LVGL's UI editor is a work-in-progress tool designed to help UI developers create embedded UIs faster and more maintainably. The key features of this tool are:
- Component-oriented: Various UI elements can be implemented as reusable components.
- XML-based: Components are described in an HTML-like syntax.
- Instant preview: Components can be previewed as you edit them.
- Figma support: LVGL's Figma plugin helps quickly extract styles from any Figma elements.
- Online preview: A CI action converts XML files into a website for easy preview.
- Custom widget creation: Unlike components, widgets have C logic. You can recompile the editor to include new widgets' code.
- C export: Both components and widgets can be exported to C, enabling seamless integration into your application, just like handwritten code.
- Runtime XML loading: Components can be loaded from XML at runtime without recompiling the firmware.
This tool is developer-centric, designed for those who bring designer-created UIs to life. It’s not a drag-and-drop tool for designers but assumes users are comfortable with writing and managing code. The editor complements your workflow, enabling seamless transitions between generated and handwritten code. Use it where it’s more efficient, and code directly when better suited.
We believe designers should work freely in tools like Figma, focusing on creativity without limitations. LVGL's editor helps developers structure and implement these designs in a maintainable, scalable way. Our goal is to bridge the gap, empowering both designers and developers to excel in their roles.
This video provides a step-by-step guide to all the support features
- Install Docker: Docker is required to compile your code and integrate it into the editor. Find the Docker installation guide here.
- Download and install the Editor. Find the installers here.
- Fork and clone this repository to experiment with its CI actions and online preview features. In the repository settings set the source of PagestoGitHub Action, and on theActionspage enable actions.
- Open the editor and load the example folder.
- Compile the project to generate the custom C code in the editor’s preview (use the button in the top-right corner).
- Edit components: Open button_default.xmland make edits. Save the file (Ctrl+S) to update the preview. Learn more about LVGL's XML language here.
- Edit a widget: Open slider_box.xml(a widget) and click "Compile Code." It will compile the C code alongside the widget's XML. Feel free to edit the C code and recompile it.
- Ckeck out Fonts and Images: Open globals.xmlto see how images and fonts are handled.
- Open the Figma project and duplicate it.
- Use the Figma to LVGL plugin: Open our plugin, modify the design, and update the XMLs with the new styles.
- Try the online preview: Commit and push your changes. Wait for the CI to run and check the online preview.
- Open an issue if you encounter problems or get stuck. 😊
This is an early preview of the UI editor, so only core functionalities are supported at this moment. The goal is to demonstrate the development direction and gather feedback for adjustments.
Note: This version is for preview purposes only and not suitable for production.
- Basic built-in widgets (lv_obj,lv_label,lv_slider,lv_button, etc.).
- Load XML components at runtime from files or data (part of LVGL as an open-source MIT-licensed feature).
- Style sheets and local styles supporting basic style properties.
- Nest components and widgets at any depth.
- Dynamically instantiate XML components in C.
- Register images and fonts accessible by name in XML (only files are supported; fonts/images are not exported as C).
- Use constants for widget and style properties.
- Define, pass, and use parameters for components.
Please refer to the examples to learn the XML syntax or read this page for more information.
We aim to release v0.2 in April 2025 and v0.3 in July 2025, which will include:
- XML auto-completion, syntax error highlighting, and common hotkeys (e.g., Ctrl+click to jump to declarations).
- Widget highlighting: Hovering over widgets in the preview will show their size, padding, margins, etc.
- Support for all style properties.
- Support for most LVGL widgets, including complex ones like tabview, chart, span, scale, table, and buttonmatrix.
- MicroPython support.
- Event and subject handling.
- Font manager for exporting fonts as C.
- Image manager for exporting images as C and supporting scaling/color format changes (all configurable via XML).
- Basic translation support.
- Memory monitoring and performance estimation tools.
- Commenting support in the online preview.
During development, everything will be free. After v1.0 (targeted for Q3 2025), we plan to introduce the following models (subject to change):
- No limitations on the number of components.
- No access to the Figma plugin or online preview.
- No support for custom widgets (i.e., recompiling the editor).
- No multi-language UI translation support.
- Some advanced features may be disabled.
Target Audience: Makers and small companies.
- Access to all editor features (e.g., multi-language support, custom widgets).
- Figma plugin and online preview support.
- Estimated cost: < $10k/year for a floating license.
- Free for open-source projects (requires regular updates to ensure the project remains open-source).
Target Audience: Teams with designers and developers requiring collaboration.
- Plugin support for deep customization (e.g., custom buttons, themes, XML processing, code export hooks).
- Integration with custom applications or CI workflows via CLI.
- Collaborative development, including feature development as a service.
- Custom pricing based on specific needs.
Target Audience: Large enterprise companies and vendors requiring custom tools and features.
Just like LVGL, we are developing this tool for you. We want to add the features you need, not just what we think is useful.
Please open an issue in this repository to share your feedback. Your input will help shape the development of LVGL's UI Editor!
Thank you! ❤️
