//! [![github]](https://github.com/rafaelcaricio/lvgl-rs) [![crates-io]](https://crates.io/crates/lvgl) [![docs-rs]](crate) //! //! [github]: https://img.shields.io/badge/github-8da0cb?style=for-the-badge&labelColor=555555&logo=github //! [crates-io]: https://img.shields.io/badge/crates.io-fc8d62?style=for-the-badge&labelColor=555555&logo=rust //! [docs-rs]: https://img.shields.io/badge/docs.rs-66c2a5?style=for-the-badge&labelColor=555555&logoColor=white&logo= //! //!
//! //! [LVGL][1] bindings for Rust. A powerful and easy-to-use embedded GUI with many widgets, advanced visual effects, and //! low memory footprint. This crate is compatible with `#![no_std]` environments by default. //! //! [1]: https://docs.lvgl.io/v7/en/html/get-started/quick-overview.html //! #![cfg_attr(not(test), no_std)] #[macro_use] extern crate bitflags; #[cfg(feature = "lvgl_alloc")] extern crate alloc; mod support; mod ui; #[macro_use] mod lv_core; pub mod widgets; #[cfg(feature = "lvgl_alloc")] mod allocator; #[cfg(feature = "lvgl_alloc")] use ::alloc::boxed::Box; #[cfg(not(feature = "lvgl_alloc"))] pub(crate) mod mem; #[cfg(not(feature = "lvgl_alloc"))] use crate::mem::Box; pub use lv_core::*; pub use support::*; pub use ui::*; // Initialize LVGL only once. lazy_static::lazy_static! { static ref LVGL_INITIALIZED: bool = { unsafe { lvgl_sys::lv_init(); } true }; }