oop
This commit is contained in:
@@ -7,3 +7,7 @@ impl Event for Submit {}
|
||||
#[derive(Eq, PartialEq, Hash, Clone)]
|
||||
pub struct Edited;
|
||||
impl Event for Edited {}
|
||||
|
||||
#[derive(Eq, PartialEq, Hash, Clone)]
|
||||
pub struct Draw;
|
||||
impl Event for Draw {}
|
||||
|
||||
@@ -101,9 +101,21 @@ pub struct DefaultRsc<State: 'static> {
|
||||
pub events: EventManager<Self>,
|
||||
pub tasks: Tasks<Self>,
|
||||
pub state: WidgetState,
|
||||
pub widget_events: Vec<WidgetEvent>,
|
||||
_state: PhantomData<State>,
|
||||
}
|
||||
|
||||
pub struct WidgetEvent {
|
||||
id: WidgetId,
|
||||
ty: WidgetEventType,
|
||||
}
|
||||
|
||||
pub enum WidgetEventType {
|
||||
Draw,
|
||||
Undraw,
|
||||
Remove,
|
||||
}
|
||||
|
||||
impl<State> DefaultRsc<State> {
|
||||
fn init(window: Arc<Window>) -> (Self, TaskMsgReceiver<Self>) {
|
||||
let (tasks, recv) = Tasks::init(window);
|
||||
@@ -112,6 +124,7 @@ impl<State> DefaultRsc<State> {
|
||||
ui: Default::default(),
|
||||
events: Default::default(),
|
||||
tasks,
|
||||
widget_events: Default::default(),
|
||||
state: Default::default(),
|
||||
_state: Default::default(),
|
||||
},
|
||||
@@ -135,15 +148,27 @@ impl<State> UiRsc for DefaultRsc<State> {
|
||||
|
||||
fn on_draw(&mut self, active: &ActiveData) {
|
||||
self.events.draw(active);
|
||||
self.widget_events.push(WidgetEvent {
|
||||
id: active.id,
|
||||
ty: WidgetEventType::Draw,
|
||||
});
|
||||
}
|
||||
|
||||
fn on_undraw(&mut self, active: &ActiveData) {
|
||||
self.events.undraw(active);
|
||||
self.widget_events.push(WidgetEvent {
|
||||
id: active.id,
|
||||
ty: WidgetEventType::Undraw,
|
||||
});
|
||||
}
|
||||
|
||||
fn on_remove(&mut self, id: WidgetId) {
|
||||
self.events.remove(id);
|
||||
self.state.remove(id);
|
||||
self.widget_events.push(WidgetEvent {
|
||||
id,
|
||||
ty: WidgetEventType::Remove,
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
@@ -297,6 +322,18 @@ impl<State: DefaultAppState> AppState for DefaultApp<State> {
|
||||
_ => (),
|
||||
}
|
||||
state.window_event(event, rsc, render);
|
||||
|
||||
let mut events = std::mem::take(&mut rsc.widget_events);
|
||||
for event in events.drain(..) {
|
||||
match event.ty {
|
||||
WidgetEventType::Draw => {
|
||||
rsc.run_event::<Draw>(event.id, (), state);
|
||||
}
|
||||
_ => (),
|
||||
}
|
||||
}
|
||||
rsc.widget_events = events;
|
||||
|
||||
let ui_state = self.state.default_state_mut();
|
||||
if render.needs_redraw(&ui_state.root, rsc.widgets()) {
|
||||
ui_state.renderer.window().request_redraw();
|
||||
|
||||
Reference in New Issue
Block a user