97 lines
3.8 KiB
Rust
97 lines
3.8 KiB
Rust
//! [![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=
|
|
//!
|
|
//! <br>
|
|
//!
|
|
//! [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;
|
|
|
|
#[macro_use]
|
|
extern crate lazy_static;
|
|
|
|
#[macro_use]
|
|
mod lv_core;
|
|
|
|
#[cfg(feature = "lvgl_alloc")]
|
|
extern crate alloc;
|
|
|
|
// We can ONLY use `alloc::boxed::Box` if `lvgl_alloc` is enabled.
|
|
// That is because we use `Box` to send memory references to LVGL. Since the global allocator, when
|
|
// `lvgl_alloc` feature is enabled, is the LVGL memory manager then everything is in LVGL
|
|
// managed memory anyways. In that case we can use the Rust's provided Box definition.
|
|
//
|
|
#[cfg(feature = "lvgl_alloc")]
|
|
use ::alloc::boxed::Box;
|
|
|
|
#[cfg(feature = "lvgl_alloc")]
|
|
mod allocator;
|
|
|
|
#[cfg(not(feature = "lvgl_alloc"))]
|
|
pub(crate) mod mem;
|
|
|
|
// When LVGL allocator is not used on the Rust code, we need a way to add objects to the LVGL
|
|
// managed memory. We implement a very simple `Box` that has the minimal features to copy memory
|
|
// safely to the LVGL managed memory.
|
|
//
|
|
#[cfg(not(feature = "lvgl_alloc"))]
|
|
use crate::mem::Box;
|
|
|
|
pub mod display;
|
|
mod functions;
|
|
mod support;
|
|
mod ui;
|
|
pub mod widgets;
|
|
use core::sync::atomic::{AtomicBool, Ordering};
|
|
pub use functions::*;
|
|
pub use lv_core::*;
|
|
use parking_lot::Mutex;
|
|
pub use support::*;
|
|
pub use ui::*;
|
|
|
|
lazy_static! {
|
|
static ref MUTEX: Mutex<AtomicBool> = Mutex::new(AtomicBool::new(false));
|
|
}
|
|
|
|
pub fn init() {
|
|
let initialized = MUTEX.lock();
|
|
if initialized
|
|
.compare_exchange(false, true, Ordering::Relaxed, Ordering::Relaxed)
|
|
.is_ok()
|
|
{
|
|
unsafe {
|
|
lvgl_sys::lv_init();
|
|
}
|
|
}
|
|
}
|
|
|
|
#[cfg(test)]
|
|
pub(crate) mod tests {
|
|
use super::*;
|
|
use crate::display::Display;
|
|
use embedded_graphics::mock_display::MockDisplay;
|
|
use embedded_graphics::pixelcolor::Rgb565;
|
|
|
|
pub(crate) fn initialize_test() {
|
|
init();
|
|
|
|
static RUN_ONCE: Mutex<Option<u8>> = parking_lot::const_mutex(None);
|
|
let mut run_once = RUN_ONCE.lock();
|
|
|
|
if run_once.is_none() {
|
|
let embedded_graphics_display: MockDisplay<Rgb565> = Default::default();
|
|
let _ = Display::register(embedded_graphics_display).unwrap();
|
|
*run_once = Some(1);
|
|
}
|
|
}
|
|
}
|