From f3e5d6ebeeb685bf350f07ba626188fb097cb980 Mon Sep 17 00:00:00 2001 From: Gabor Kiss-Vamosi Date: Thu, 9 Oct 2025 09:28:15 +0200 Subject: [PATCH] docs(editor): improve installation and figma docs (#8998) Co-authored-by: cubic-dev-ai[bot] <191113872+cubic-dev-ai[bot]@users.noreply.github.com> Co-authored-by: Victor Wheeler --- .../src/_static/images/figma_to_lvgl_menu.png | Bin 0 -> 31825 bytes .../_static/images/figma_to_lvgl_plugin.png | Bin 0 -> 32090 bytes docs/src/details/xml/editor/install.rst | 68 +++++++--- .../src/details/xml/editor/user_interface.rst | 12 +- docs/src/details/xml/tools/figma.rst | 118 ++++++++++++++---- 5 files changed, 153 insertions(+), 45 deletions(-) create mode 100644 docs/src/_static/images/figma_to_lvgl_menu.png create mode 100644 docs/src/_static/images/figma_to_lvgl_plugin.png diff --git a/docs/src/_static/images/figma_to_lvgl_menu.png b/docs/src/_static/images/figma_to_lvgl_menu.png new file mode 100644 index 0000000000000000000000000000000000000000..625b3d20f36c7cc31bd465073ed5961ca9122c9f GIT binary patch literal 31825 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ⅅ8XeoaD6 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 Y!>OK{z`r$rofCXPQC%VH?B##{4}G3M>i_@% literal 0 HcmV?d00001 diff --git a/docs/src/details/xml/editor/install.rst b/docs/src/details/xml/editor/install.rst index e16fa9b9eb..1a892fbb3a 100644 --- a/docs/src/details/xml/editor/install.rst +++ b/docs/src/details/xml/editor/install.rst @@ -5,28 +5,57 @@ Installation ============ -Here are the guides to download and install |lvglpro| Editor appropriate for your platform: +Here are the guides to download and install |lvglpro| Editor appropriate for your +platform: Windows ******* -Navigate to https://pro.lvgl.io/#download and press the [Download] button and save the -resulting image to your workstation. Then execute the downloaded installer to install -|lvglpro|. +Install WSL +----------- +Before using the Editor ``WSL`` (Windows Subsystem for Linux) needs to be installed. + +Open a Terminal and type ``wsl.exe --list --verbose`` to see if it's already installed. + +If it's not, just type ``wsl --install`` and hit Enter. + +Install the Editor +------------------ + +Navigate to https://pro.lvgl.io/#download and press the [Download] button and save +the resulting image to your workstation. Then execute the downloaded installer to +install |lvglpro| Editor. Linux ***** -Installing |lvglpro| Editor on Linux is as simple as downloading the AppImage, making it -executable (``chmod +x LVGL_Pro_Editor.AppImage``), and running it. +Install Podman +-------------- + +The Editor is capable of recompiling the preview to use and run your C code as well. +We handle the compilation in a container using `Podman `__ +(similar to Docker). + +The simple way of installing Podman is via Terminal: + +- **Debian, Ubuntu, Linux Mint**: ``sudo apt-get install podman`` +- **Fedora**: ``sudo dnf -y install podman`` +- **Arch, Manjaro Linux**: ``sudo pacman -S podman`` + +For other distos check out https://podman.io/docs/installation#installing-on-linux + +Install the Editor +------------------ + +Installing |lvglpro| Editor on Linux is as simple as downloading the AppImage, making +it executable (``chmod +x LVGL_Pro_Editor.AppImage``), and running it. Troubleshooting --------------- -:Problem: Some users have experienced trouble launching Editor on some Linux - distributions. If you double click the ``.AppImage`` file and nothing - happens, try running it from the terminal. If you see this error: +:Problem: If you double click the ``.AppImage`` file and nothing happens, try + running it from the terminal. If you see this error: .. code-block:: bash @@ -34,16 +63,27 @@ Troubleshooting Using GTK 2/3 and GTK 4 in the same process is not supported Trace/breakpoint trap (core dumped) -:Solution: Specify the gtk version of the application with ``--gtk-version=3``. +:Solution: Specify the GTK version for the application with ``--gtk-version=3``. .. code-block:: bash ./path/to/editor.AppImage --gtk-version=3 - - MacOS ***** -Just download either the ARM for Apple Silicon (AMD) version) and drag the application -to your Applications folder in Finder. \ No newline at end of file +Install Podman +-------------- + +The Editor is capable of recompiling the preview to use and run your C code as well. +We handle the compilation in a container using `Podman `__ +(similar to Docker). The simplest way to install Podman is via ``brew`` using +``brew install podman``. + +For more information visit https://podman.io/docs/installation#macos + +Install the Editor +------------------ + +Just download either the ARM (for Apple Silicon) or AMD version and drag the +application to your Applications folder in Finder. diff --git a/docs/src/details/xml/editor/user_interface.rst b/docs/src/details/xml/editor/user_interface.rst index 6bb1722481..c5cdeaa303 100644 --- a/docs/src/details/xml/editor/user_interface.rst +++ b/docs/src/details/xml/editor/user_interface.rst @@ -29,21 +29,15 @@ won’t need to do anything manually, it stays up-to-date in the background. Login ***** -.. TODO - -hints: -- enter your email address -- you will receive an email with an OTP (On Time Password) -- it will create a user for you -- no password is needed +1. enter your email address +2. you will receive an email with an OTP (One-Time Password) +3. it will create a user for you (no password is needed) Licence Selection ***************** -.. TODO - After logging in you need select a licence for the list. diff --git a/docs/src/details/xml/tools/figma.rst b/docs/src/details/xml/tools/figma.rst index 62023f00b6..ca1d3b906a 100644 --- a/docs/src/details/xml/tools/figma.rst +++ b/docs/src/details/xml/tools/figma.rst @@ -1,3 +1,4 @@ +.. include:: ../editor/substitutions.txt .. _editor_figma: ================= @@ -7,15 +8,89 @@ Figma integration Overview ******** -When Figma is used to create a UI design, parts of it can be directly imported (or -updated). +|lvglpro|\ 's `Figma `__ plugin displays the style properties of selected UI elements in +Figma. +These properties can be easily copy-pasted as style attributes in the Editor, +enabling pixel-perfect design implementation. -Usage -***** +The plugin also shows the "Figma node ID" of the selected element, which allows +style synchronization. This means that, with a single click in the Editor or with +a CLI command, style properties from Figma can be downloaded and updated in the +XML files. -To enable sync-ing with a Figma project, add a ``project_local.xml`` file if it isn't -already there and add this to its content: +Since this is not a magical auto-importer, the developer retains full control +over how files, styles, components, etc., are organized. At the same time, the +designer is free to work in Figma without constraints. The developer should +take responsibility for restructuring the design with a developer mindset to +ensure a maintainable, clean, and optimal structure. + +The Figma to LVGL Plugin +************************ + +The Figma to LVGL Plugin is available publicly in Figma's plugin store and can +be added to both public and private projects, even without a Figma subscription. + +To install the Figma to LVGL Plugin, go to the Figma menu -> Plugins -> Manage +plugins and find it in the list. + +.. figure:: /_static/images/figma_to_lvgl_menu.png + :align: center + :alt: Figma to LVGL Installation + :scale: 75 + + Click "Manage Plugins ..." to find and install Figma to LVGL + +If you used it earlier, it will appear among the "Recents". + +Once it's installed, a small window will appear showing the style properties of +the selected element. + +.. figure:: /_static/images/figma_to_lvgl_plugin.png + :align: center + :alt: Figma to LVGL listing style properties of the selected UI element + :scale: 75 + + Figma to LVGL listing style properties of the selected UI element + +Usage in the Editor +******************* + +The style properties listed by the plugin can be copy-pasted into any XML style +section. +For example: + +.. code-block:: xml + + + +