API re-design #9
1 changed files with 22 additions and 15 deletions
|
@ -1,6 +1,7 @@
|
||||||
use core::marker::PhantomData;
|
use core::marker::PhantomData;
|
||||||
use core::time::Duration;
|
use core::time::Duration;
|
||||||
use core::sync::atomic::{AtomicBool, Ordering};
|
use core::sync::atomic::{AtomicBool, Ordering};
|
||||||
|
use core::cell::{RefCell, RefMut};
|
||||||
|
|
||||||
// There can only be a single reference to LittlevGL library.
|
// There can only be a single reference to LittlevGL library.
|
||||||
static LVGL_IN_USE: AtomicBool = AtomicBool::new(false);
|
static LVGL_IN_USE: AtomicBool = AtomicBool::new(false);
|
||||||
|
@ -12,7 +13,8 @@ pub enum LvError {
|
||||||
|
|
||||||
pub struct UI {
|
pub struct UI {
|
||||||
// LittlevGL is not thread-safe by default.
|
// LittlevGL is not thread-safe by default.
|
||||||
_not_send: PhantomData<*const ()>
|
_not_send: PhantomData<*const ()>,
|
||||||
|
display: Option<DisplayDriver>,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl UI {
|
impl UI {
|
||||||
|
@ -21,15 +23,26 @@ impl UI {
|
||||||
// lvgl_sys::lv_init();
|
// lvgl_sys::lv_init();
|
||||||
Ok(Self {
|
Ok(Self {
|
||||||
_not_send: PhantomData,
|
_not_send: PhantomData,
|
||||||
|
display: None,
|
||||||
})
|
})
|
||||||
} else {
|
} else {
|
||||||
Err(LvError::AlreadyInUse)
|
Err(LvError::AlreadyInUse)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn disp_drv_register(&mut self, _display: &mut DisplayDriver) {
|
pub fn disp_drv_register(&mut self, display: DisplayDriver) {
|
||||||
// register it
|
// register it
|
||||||
// lvgl_sys::lv_disp_drv_register(&mut disp_drv);
|
// lvgl_sys::lv_disp_drv_register(&mut disp_drv);
|
||||||
|
self.display = Some(display);
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn scr_act(&self) -> Option<&Screen> {
|
||||||
|
match self.display.as_ref() {
|
||||||
|
Some(drv) => {
|
||||||
|
Some(drv.scr_act())
|
||||||
|
},
|
||||||
|
None => None
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn tick_inc(&mut self, _tick_period: Duration) {
|
pub fn tick_inc(&mut self, _tick_period: Duration) {
|
||||||
|
@ -56,8 +69,8 @@ impl DisplayDriver {
|
||||||
self.current_screen = screen;
|
self.current_screen = screen;
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn scr_act(&mut self) -> &mut Screen {
|
pub fn scr_act(&self) -> &Screen {
|
||||||
&mut self.current_screen
|
&self.current_screen
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -114,27 +127,22 @@ impl<'a, F> LvObject for Button<'a, F> where F: FnMut() {}
|
||||||
mod test {
|
mod test {
|
||||||
use crate::api::{UI, DisplayDriver, LvObject};
|
use crate::api::{UI, DisplayDriver, LvObject};
|
||||||
use core::time::Duration;
|
use core::time::Duration;
|
||||||
use core::cell::RefCell;
|
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn basic_usage() {
|
fn basic_usage() {
|
||||||
let mut ui = UI::init().unwrap();
|
let mut ui = UI::init().unwrap();
|
||||||
|
|
||||||
let refresh_lines = 10;
|
let refresh_lines = 10;
|
||||||
let mut display = DisplayDriver::new(refresh_lines);
|
let display = DisplayDriver::new(refresh_lines);
|
||||||
ui.disp_drv_register(&mut display);
|
ui.disp_drv_register(display);
|
||||||
let display = RefCell::new(display);
|
|
||||||
|
|
||||||
{
|
{
|
||||||
let mut d = display.borrow_mut();
|
let screen = ui.scr_act().unwrap();
|
||||||
let screen = d.scr_act();
|
|
||||||
|
|
||||||
let mut button = screen.btn_create();
|
let mut button = screen.btn_create();
|
||||||
|
|
||||||
button.on_event(|| {
|
button.on_event(|| {
|
||||||
// something
|
// something
|
||||||
let mut disp = display.borrow_mut();
|
let screen = ui.scr_act().unwrap();
|
||||||
let screen = disp.scr_act();
|
|
||||||
let mut label = screen.label_create();
|
let mut label = screen.label_create();
|
||||||
label.set_text("Clicked");
|
label.set_text("Clicked");
|
||||||
});
|
});
|
||||||
|
@ -144,8 +152,7 @@ mod test {
|
||||||
};
|
};
|
||||||
|
|
||||||
{
|
{
|
||||||
let mut d = display.borrow_mut();
|
let screen = ui.scr_act().unwrap();
|
||||||
let screen = d.scr_act();
|
|
||||||
let mut button2 = screen.btn_create();
|
let mut button2 = screen.btn_create();
|
||||||
button2.on_event(|| {
|
button2.on_event(|| {
|
||||||
// else
|
// else
|
||||||
|
|
Loading…
Reference in a new issue