Compare commits

...
Sign in to create a new pull request.

1 commit

Author SHA1 Message Date
948a929040 Add event handling to systems 2025-09-10 15:54:23 +03:00
5 changed files with 30 additions and 23 deletions

View file

@ -8,6 +8,7 @@ pub trait EngineTrait {
fn new() -> Self; fn new() -> Self;
fn initialize(&mut self, platform_context: PlatformContext); fn initialize(&mut self, platform_context: PlatformContext);
fn update(&mut self, platform_context: PlatformContext); fn update(&mut self, platform_context: PlatformContext);
fn handle_event(&mut self, platform_context: PlatformContext);
fn current_scene_mut(&mut self) -> &mut Scene; fn current_scene_mut(&mut self) -> &mut Scene;
fn get_debug_ui_buffer(&self) -> Rc<RefCell<DebugUIBuffer>>; fn get_debug_ui_buffer(&self) -> Rc<RefCell<DebugUIBuffer>>;
fn reset_debug_ui_buffer(&mut self); fn reset_debug_ui_buffer(&mut self);

View file

@ -56,6 +56,18 @@ impl EngineTrait for Engine {
} }
} }
fn handle_event(&mut self, platform_context: PlatformContext) {
let mut ctx = SystemContext {
scene: self.scene_manager.current_mut(),
platform_context,
debug_ui_buffer: self.debug_ui_buffer.clone(),
};
for system in self.system_manager.systems.values_mut() {
system.handle_event(&mut ctx);
}
}
// pub fn build_system_context(&mut self) -> SystemContext { // pub fn build_system_context(&mut self) -> SystemContext {
// SystemContext { // SystemContext {
// scene: self.scene_manager.current_mut(), // scene: self.scene_manager.current_mut(),

View file

@ -18,6 +18,8 @@ pub trait System {
fn initialize(&mut self) {} fn initialize(&mut self) {}
/// Spawn the first entities of the world. /// Spawn the first entities of the world.
fn load_world(&mut self, _ctx: &mut SystemContext) {} fn load_world(&mut self, _ctx: &mut SystemContext) {}
/// Handle events sent from the platform.
fn handle_event(&mut self, _ctx: &mut SystemContext) {}
fn update(&mut self, _ctx: &mut SystemContext) {} fn update(&mut self, _ctx: &mut SystemContext) {}
} }

View file

@ -18,27 +18,18 @@ const MAIN_SCENE_ID: &str = "main_scene";
#[derive(Default)] #[derive(Default)]
struct UpdateAspectRatioSystem; struct UpdateAspectRatioSystem;
impl System for UpdateAspectRatioSystem { impl System for UpdateAspectRatioSystem {
fn initialize(&mut self) {} fn handle_event(&mut self, ctx: &mut SystemContext) {
if let Event::WindowEvent { event: WindowEvent::Resized(sz), .. } =
fn load_world(&mut self, _ctx: &mut SystemContext) {} &ctx.platform_context.current_event
{
fn update(&mut self, ctx: &mut SystemContext) { let _ = ctx
// FIXME: Need an event handler rework for systems. .scene
match &ctx.platform_context.current_event { .world
Event::WindowEvent { event, .. } => match event { .query_mut::<&mut Camera>()
WindowEvent::Resized(sz) => { .into_iter()
let _ = ctx .map(|(_, cam)| {
.scene cam.aspect = sz.width as f32 / sz.height as f32;
.world });
.query_mut::<&mut Camera>()
.into_iter()
.map(|(_, cam)| {
cam.aspect = sz.width as f32 / sz.height as f32;
});
}
_ => {}
},
_ => {}
} }
} }
} }

View file

@ -66,6 +66,9 @@ impl<E: EngineTrait> Platform<E> for GliumPlatform<E> {
.systems .systems
.values_mut() .values_mut()
.for_each(|system| system.handle_event(&mut self.window, event.clone())); .for_each(|system| system.handle_event(&mut self.window, event.clone()));
let mut ctx2 = ctx.clone();
ctx2.current_event = event.clone();
self.engine.handle_event(ctx2.clone());
match event { match event {
Event::WindowEvent { event, .. } => match event { Event::WindowEvent { event, .. } => match event {
@ -94,8 +97,6 @@ impl<E: EngineTrait> Platform<E> for GliumPlatform<E> {
_ => {}, _ => {},
}, },
Event::AboutToWait => { Event::AboutToWait => {
let mut ctx2 = ctx.clone();
ctx2.current_event = event.clone();
self.engine.update(ctx2); self.engine.update(ctx2);
self.rendering_system_manager self.rendering_system_manager
.systems .systems