2022-03-08 11:52:01 +00:00
[![SWUbanner ](https://raw.githubusercontent.com/vshymanskyy/StandWithUkraine/main/banner2-direct.svg )](https://github.com/vshymanskyy/StandWithUkraine/blob/main/docs/README.md)
2022-03-08 11:49:26 +00:00
2021-05-25 23:03:07 +00:00
< h1 align = "center" > LVGL - Open-source Embedded GUI Library in Rust< / h1 >
2020-04-12 07:58:01 +00:00
2021-05-25 23:03:07 +00:00
![Original LVGL demo image ](lv_demo.png )
2020-04-12 07:58:01 +00:00
< p align = "center" >
2021-05-25 23:03:07 +00:00
LVGL provides everything you need to create a Graphical User Interface (GUI) on embedded systems with easy-to-use graphical elements, beautiful visual effects and low memory footprint.
2020-04-12 08:03:02 +00:00
< / p >
< p align = "center" >
2021-05-25 23:03:07 +00:00
LVGL is compatible with < samp > #![no_std]< / samp > environments by default.
2020-04-12 07:58:01 +00:00
< / p >
< h4 align = "center" >
2021-05-25 23:03:07 +00:00
< a href = "https://github.com/rafaelcaricio/lvgl-rs-wasm" > Rust to WASM demo< / a > ·
< a href = "https://lvgl.io/" > Official LVGL Website < / a > ·
2020-04-12 10:32:18 +00:00
< a href = "https://github.com/littlevgl/lvgl" > C library repository< / a > ·
2021-05-25 23:03:07 +00:00
< a href = "https://lvgl.io/demos" > Official live demos< / a >
2020-04-12 07:58:01 +00:00
< / h4 >
---
2020-04-12 10:34:03 +00:00
![Rust bindings usage demo code. ](demo.png )
2020-04-12 18:37:26 +00:00
2021-03-06 19:25:09 +00:00
## System Build Dependencies
In order to build the `lvgl` project you will need the following system dependencies to be installed:
```
$ sudo apt install build-essential llvm clang
```
2021-03-06 20:09:06 +00:00
If you want to build the examples, then you will need to install SDL2 as well.
```
$ sudo apt install libsdl2-dev
```
2020-04-12 18:37:26 +00:00
## Usage
Edit your `Cargo.toml` file dependencies with:
```
$ cargo add lvgl
```
The build requires the environment variable bellow to be set:
2021-05-25 23:03:07 +00:00
- `DEP_LV_CONFIG_PATH` : Path to the directory containing the `lv_conf.h` header file used for configuration of LVGL library.
2020-04-12 18:37:26 +00:00
We recommend the `lv_conf.h` file to be in your project's root directory. If so, the command to build your project would be:
```shell script
$ DEP_LV_CONFIG_PATH=`pwd` cargo build
```
2020-05-30 18:24:35 +00:00
### Building for embedded environments
We make use of `bindgen` for generating the bindings to LittlevGL at build time. There is a problem in cargo when building
for `no_std` , so we need to use a workaround to build "lvgl-rs". The mainstrem issue in cargo is being tracked at
[rust-lang/cargo#7915 ](https://github.com/rust-lang/cargo/issues/7915 ).
```shell
$ DEP_LV_CONFIG_PATH=`pwd` cargo build -Zfeatures=build_dep
```
2021-05-25 23:03:07 +00:00
### LVGL Global Allocator
A [global allocator ](https://doc.rust-lang.org/std/alloc/trait.GlobalAlloc.html ) for Rust leveraging the
[LVGL memory allocator ](https://github.com/lvgl/lvgl/blob/master/src/misc/lv_mem.h ) is provided, but not enabled
by default. Can be enabled by the feature `lvgl_alloc` . This will make all dynamic memory to be allocated by LVGL
internal memory manager.
2020-05-30 18:24:35 +00:00
2020-05-15 10:54:31 +00:00
## Running the demo
2021-05-25 23:03:07 +00:00
**Hint for macOS users**: Before you run the demos you need to make sure you have [libsdl ](https://www.libsdl.org )
installed on your machine. To install it, use HomeBrew:
2020-11-17 15:17:42 +00:00
```shell
$ brew install sdl2
```
2020-05-31 07:12:37 +00:00
[This project contains examples that can run in a desktop simulator. ](./examples )
2020-05-31 16:53:09 +00:00
First, make sure to pull `lvgl-rs` submodules:
2020-05-31 16:51:12 +00:00
```shell
$ git submodule init
$ git submodule update
```
Then run the `demo` example:
2020-05-31 07:12:37 +00:00
```shell
2022-01-08 19:54:31 +00:00
$ DEP_LV_CONFIG_PATH=`pwd`/examples/include cargo run --example demo --features="alloc"
2020-05-31 07:12:37 +00:00
```
2020-06-02 07:39:02 +00:00
## Feature Support
The bindings are still in development. There are many features of LVGL that needs to be exposed by `lvgl-rs` . In
this section you can check what is implemented at the moment.
### Features
List of LVGL features that impacts the library usage in general.
- [x] Displays: We use [`embedded_graphics` ](https://docs.rs/embedded-graphics/0.6.2/embedded_graphics/ ) library to
draw to the display. You can use `lvgl-rs` with any of the
[`embedded_graphics` supported displays ](https://docs.rs/embedded-graphics/0.6.2/embedded_graphics/#supported-displays ).
- [x] Events: You can listen and trigger events in widget objects.
2020-06-12 16:54:28 +00:00
- [x] Styles: You can set styles in any exposed object. We are still missing the possibility of defining global base styles.
2020-06-02 07:39:02 +00:00
- [ ] Input Devices
- [ ] Fonts
- [ ] Images
- [ ] File system
- [ ] Animations
- [ ] Tasks
### Widgets
Widgets currently implemented might have some missing features. If the widget you want to use is not exposed or
is missing a feature you want to make use, please send a Pull Request or open an issue.