slint/demos/printerdemo/zephyr
Simon Hausmann a98d4709be Move printer demo and energy-monitor into new top-level demos/ folder
These are showing off use-cases for Slint, but they're not examples showing individual Slint features.

Also removed the old printerdemo while at it.
2024-10-25 12:09:32 +02:00
..
boards Move printer demo and energy-monitor into new top-level demos/ folder 2024-10-25 12:09:32 +02:00
src Move printer demo and energy-monitor into new top-level demos/ folder 2024-10-25 12:09:32 +02:00
.gitignore Move printer demo and energy-monitor into new top-level demos/ folder 2024-10-25 12:09:32 +02:00
CMakeLists.txt Move printer demo and energy-monitor into new top-level demos/ folder 2024-10-25 12:09:32 +02:00
prj.conf Move printer demo and energy-monitor into new top-level demos/ folder 2024-10-25 12:09:32 +02:00
README.md Move printer demo and energy-monitor into new top-level demos/ folder 2024-10-25 12:09:32 +02:00
VERSION Move printer demo and energy-monitor into new top-level demos/ folder 2024-10-25 12:09:32 +02:00
west.yaml Move printer demo and energy-monitor into new top-level demos/ folder 2024-10-25 12:09:32 +02:00

Printer Demo with Zephyr

Known Issues

  1. Unlike the Espressif integration, we don't provide the platform integration as part of the Slint C++ API. In part, this is due to the way Zephyr OS handles device hardware. Zephyr uses the Device Tree to describe the hardware to the device driver model. In order to register an input event call back we need a pointer to a device obtained from a device tree node, and we also need to know how the driver behaves in order to write our callback function. The existing implementation is generic enough to cover the simulator and display shield drivers. A more general solution could be investigated in the future;
  2. Double buffering is not supported as neither the simulator or the hardware used for testing reported it as supported;

Prerequisites

Before you can run this example, make sure you have done the following:

  1. Install Rust, with the nightly channel enabled:

    # Install via rustup
    # See https://www.rust-lang.org/tools/install
    
    # Enable the nightly channel
    rustup toolchain install nightly
    rustup default nightly
    
  2. Install the Zephyr dependencies;

  3. Install West into a virtual environment:

    # If Slint source is already checked out:
    python3 -m venv ../.venv
    source ../.venv/bin/activate
    
    # If you do not have Slint source yet:
    mkdir slint-zephyr
    python3 -m venv slint-zephyr/.venv
    source slint-zephyr/.venv/bin/activate
    
    # Install west
    pip install west
    
  4. Get the Zephyr source code:

    # If Slint source is already checked out (this adds the Zephyr source next to the Slint source):
    cd ..
    west init -l --mf demos/printerdemo/zephyr/west.yaml ./slint
    
    # If you do not have Slint source yet (this checks out Slint and Zephyr source into slint-zephyr):
    west init -m https://github.com/slint-ui/slint --mr zephyr --mf demos/printerdemo/zephyr/west.yaml slint-zephyr
    cd slint-zephyr
    
    # Checkout the repositories:
    west update
    
  5. Export a Zephyr CMake package. This allows CMake to automatically load boilerplate code required for building Zephyr applications.

    west zephyr-export
    
  6. Zephyrs scripts/requirements.txt file declares additional Python dependencies. Install them with pip.

    pip install -r ~/zephyrproject/zephyr/scripts/requirements.txt
    
  7. Install the Zephyr SDK using version v0.16.8.

Build and Run the Example in the Simulator

Once you have the prerequisites, navigate to this directory and execute the following comands:

# Build
west build -b native_sim/native/64 -p always slint/demos/printerdemo/zephyr

# Run
./build/zephyr/zephyr.exe

The -p always option of the build command forces a pristine build. The Zephyr documentation recommends this for new users.

Build and Run the Example on a Device

This sample has been tested on the NXP MIMXRT1170-EVKB with a RK055HDMIPI4MA0 MIPI display. The board/debug probe may require configuring as described here.

# Build
west build -b mimxrt1170_evk@B/mimxrt1176/cm7 -p always slint/demos/printerdemo/zephyr -- -DSHIELD=rk055hdmipi4ma0 -DCMAKE_BUILD_TYPE=Release

# Flash
west flash