# lv_micropython **Repository Path**: yc_911/lv_micropython ## Basic Information - **Project Name**: lv_micropython - **Description**: Micropython bindings to LittlevGL for Embedded devices, Unix and JavaScript - **Primary Language**: C - **License**: MIT - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 0 - **Created**: 2019-08-21 - **Last Updated**: 2020-12-20 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README # Micropython + lvgl **For information abound Micropython lvgl bindings please refrer to [lv_bindings/README.md](https://github.com/littlevgl/lv_bindings/blob/master/README.md)** See also [Micropython + LittlevGL](https://blog.littlevgl.com/2019-02-20/micropython-bindings) blog post. ## Build Instructions 1. `sudo apt-get install build-essential libreadline-dev libffi-dev git pkg-config libsdl2-2.0-0 libsdl2-dev python` 2. `git clone --recurse-submodules https://github.com/littlevgl/lv_micropython.git` 3. `cd lv_micropython` 4. `make -C ports/unix/` 5. `./ports/unix/micropython` ### For ESP32 port Please set `ESPIDF` parameter for the esp-idf install dir. It needs to match Micropython expected esp-idf, otherwise a warning will be displayed (and build will probably fail) For more details refer to [Setting up the toolchain and ESP-IDF](https://github.com/littlevgl/lv_micropython/blob/master/ports/esp32/README.md#setting-up-the-toolchain-and-esp-idf) When using IL9341 driver, the width height and color need to be set to match ILI9341. This can be done from the command line. Here is the command to build ESP32 + LittlevGL which is compatible with ILI9341 driver: `make -C ports/esp32/ ESPIDF=~/esp/projects/lv_mpy_deps/esp-idf -j4 LV_CFLAGS="-DLV_HOR_RES=240 -DLV_VER_RES=320 -DLV_COLOR_DEPTH=16" deploy` This make command will create ESP32 port of Micropython, and will try to deploy it through USB-UART bridge. `LV_CFLAGS` are used to override width height and color, for ILI9341 compatibility. ### For JavaScript port You need Emscripten installed and working. There are lots of guides about that on the web, but here's the [official one](https://emscripten.org/docs/getting_started/index.html). Once you have Emscripten working, you also need to install the `clang` package: 1. `cd ` 2. `./emsdk install clang-e-64bit # for example: clang-e1.30.0-64bit` 3. `./emsdk activate clang-e-64bit` Now you can build the JavaScript port. 1. `cd ` 2. `. ./emsdk_env.sh` 3. `git checkout lvgl_javascript` 4. `git submodule update --init --recursive` (*can be very important!*) 5. `cd ports/javascript` 6. `make` 7. Run an HTTP server that serves files from the current directory. 8. Browse to `/lvgl_editor.html` on the HTTP Server. ## Super Simple Example First, LittlevGL needs to be imported and initialized ```python import lvgl as lv lv.init() ``` Then display driver and input driver needs to be registered. Refer to [Porting the library](https://docs.littlevgl.com/#Porting) for more information. Here is an example of registering SDL drivers on Micropython unix port: ```python import SDL SDL.init() # Register SDL display driver. disp_drv = lv.disp_drv_t() lv.disp_drv_init(disp_drv) disp_drv.disp_flush = SDL.monitor_flush disp_drv.disp_fill = SDL.monitor_fill disp_drv.disp_map = SDL.monitor_map lv.disp_drv_register(disp_drv) # Regsiter SDL mouse driver indev_drv = lv.indev_drv_t() lv.indev_drv_init(indev_drv) indev_drv.type = lv.INDEV_TYPE.POINTER; indev_drv.read = SDL.mouse_read; lv.indev_drv_register(indev_drv); ``` Here is an alternative example, for registering ILI9341 drivers on Micropython ESP32 port: ```python # Import ESP32 driver (advnaces tick count and schedules tasks) import lvesp32 # Import ILI9341, initialize it and register it to LittlevGL import ILI9341 as ili d = ili.display(miso=5, mosi=18, clk=19, cs=13, dc=12, rst=4, backlight=2) d.init() disp_drv = lv.disp_drv_t() lv.disp_drv_init(disp_drv) disp_drv.disp_flush = d.flush disp_drv.disp_fill = d.fill lv.disp_drv_register(disp_drv) ``` Now you can create the GUI itself ```python # Create a screen with a button and a label scr = lv.obj() btn = lv.btn(scr) btn.align(lv.scr_act(), lv.ALIGN.CENTER, 0, 0) label = lv.label(btn) label.set_text("Button") # Load the screen lv.scr_load(scr) ``` ## More information More info about LittlevGL: - Website https://littlevgl.com - GitHub: https://github.com/littlevgl/lvgl More info about lvgl Micropython bindings: - https://github.com/littlevgl/lv_bindings/blob/master/README.md Discussions about the Microptyhon binding: https://github.com/littlevgl/lvgl/issues/557 More info about the unix port: https://github.com/micropython/micropython/wiki/Getting-Started#debian-ubuntu-mint-and-variants