Move more event handling to the render context

This commit is contained in:
Jarrod Doyle 2023-10-20 11:37:24 +01:00
parent 9a4bd5d1a0
commit 2a6bee18a6
Signed by: Jayrude
GPG Key ID: 38B57B16E7C0ADF7
2 changed files with 67 additions and 51 deletions

View File

@ -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;
}
}
_ => {}
});
}
});
}
}

View File

@ -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,