From 2a6bee18a6227dd511ffd6399ffef39425305414 Mon Sep 17 00:00:00 2001 From: Jarrod Doyle Date: Fri, 20 Oct 2023 11:37:24 +0100 Subject: [PATCH] Move more event handling to the render context --- src/core/app.rs | 79 +++++++++++++++++++++------------------------- src/gfx/context.rs | 39 ++++++++++++++++++----- 2 files changed, 67 insertions(+), 51 deletions(-) diff --git a/src/core/app.rs b/src/core/app.rs index 5566c16..d5e1ca8 100644 --- a/src/core/app.rs +++ b/src/core/app.rs @@ -84,51 +84,44 @@ impl App { let mut cumulative_dt = 0.0; let mut frames_accumulated = 0.0; let mut last_render_time = Instant::now(); - self.event_loop - .run(move |event, _, control_flow| match event { - Event::WindowEvent { - ref event, - window_id, - } if window_id == self.render_ctx.window.id() - && !self.render_ctx.handle_window_event(event) => - { - match event { - WindowEvent::CloseRequested => *control_flow = ControlFlow::Exit, - _ => { - camera_controller.process_events(event); + self.event_loop.run(move |event, _, control_flow| { + if !self.render_ctx.handle_window_event(&event, control_flow) { + match event { + Event::WindowEvent { + ref event, + window_id, + } if window_id == self.render_ctx.window.id() => { + camera_controller.process_events(event); + } + Event::RedrawRequested(_) => { + let now = Instant::now(); + let dt = now - last_render_time; + last_render_time = now; + camera_controller.update(dt); + camera_controller.update_buffer(&self.render_ctx); + renderer.render(&self.render_ctx); + renderer.update(&dt, &self.render_ctx); + renderer.update_brickmap(&self.render_ctx, &mut world); + + // Simple framerate tracking + self.render_ctx.window.set_title(&format!( + "{}: {} fps", + self.title, + (1.0 / dt.as_secs_f32()).floor() + )); + cumulative_dt += dt.as_secs_f32(); + frames_accumulated += 1.0; + if cumulative_dt >= 1.0 { + let fps = frames_accumulated * 1.0 / cumulative_dt; + let frame_time = cumulative_dt * 1000.0 / frames_accumulated; + log::info!("FPS: {}, Frame Time: {}", fps.floor(), frame_time); + cumulative_dt = 0.0; + frames_accumulated = 0.0; } } + _ => {} } - Event::MainEventsCleared => { - self.render_ctx.window.request_redraw(); - } - Event::RedrawRequested(_) => { - let now = Instant::now(); - let dt = now - last_render_time; - last_render_time = now; - camera_controller.update(dt); - camera_controller.update_buffer(&self.render_ctx); - renderer.render(&self.render_ctx); - renderer.update(&dt, &self.render_ctx); - renderer.update_brickmap(&self.render_ctx, &mut world); - - // Simple framerate tracking - self.render_ctx.window.set_title(&format!( - "{}: {} fps", - self.title, - (1.0 / dt.as_secs_f32()).floor() - )); - cumulative_dt += dt.as_secs_f32(); - frames_accumulated += 1.0; - if cumulative_dt >= 1.0 { - let fps = frames_accumulated * 1.0 / cumulative_dt; - let frame_time = cumulative_dt * 1000.0 / frames_accumulated; - log::info!("FPS: {}, Frame Time: {}", fps.floor(), frame_time); - cumulative_dt = 0.0; - frames_accumulated = 0.0; - } - } - _ => {} - }); + } + }); } } diff --git a/src/gfx/context.rs b/src/gfx/context.rs index e1582ed..d6c9860 100644 --- a/src/gfx/context.rs +++ b/src/gfx/context.rs @@ -1,4 +1,9 @@ -use winit::{dpi::PhysicalSize, event::WindowEvent, window::Window}; +use winit::{ + dpi::PhysicalSize, + event::{Event, WindowEvent}, + event_loop::ControlFlow, + window::Window, +}; pub struct Context { pub window: Window, @@ -78,14 +83,32 @@ impl Context { } } - pub fn handle_window_event(&mut self, event: &WindowEvent) -> bool { + pub fn handle_window_event( + &mut self, + event: &Event<()>, + control_flow: &mut ControlFlow, + ) -> bool { match event { - WindowEvent::Resized(physical_size) => { - self.resize(*physical_size); - true - } - WindowEvent::ScaleFactorChanged { new_inner_size, .. } => { - self.resize(**new_inner_size); + Event::WindowEvent { + ref event, + window_id, + } if *window_id == self.window.id() => match event { + WindowEvent::CloseRequested => { + *control_flow = ControlFlow::Exit; + true + } + WindowEvent::Resized(physical_size) => { + self.resize(*physical_size); + true + } + WindowEvent::ScaleFactorChanged { new_inner_size, .. } => { + self.resize(**new_inner_size); + true + } + _ => false, + }, + Event::MainEventsCleared => { + self.window.request_redraw(); true } _ => false,