Compare commits

...

2 Commits

Author SHA1 Message Date
6516b3ee30 cleaner 2025-12-22 14:09:36 -08:00
32d0e96958 stop sending instructions when paused 2025-12-22 14:06:59 -08:00

View File

@@ -97,7 +97,24 @@ impl WindowContext<'_>{
}
self.window.set_cursor_visible(true);
},
(winit::keyboard::Key::Named(winit::keyboard::NamedKey::Enter),winit::event::ElementState::Pressed)=>{
let paused=!self.simulation_paused;
self.simulation_paused=paused;
if paused{
self.free_mouse();
}else{
self.lock_mouse();
}
let instruction=PhysicsWorkerInstruction::SessionControl(SessionControlInstruction::SetPaused(paused));
self.physics_thread.send(TimedInstruction{
time,
instruction,
}).unwrap();
}
(keycode,state)=>{
if self.simulation_paused{
return;
}
let s=state.is_pressed();
// internal variants for this scope
@@ -139,16 +156,6 @@ impl WindowContext<'_>{
if let Some(session_instruction)=match keycode{
winit::keyboard::Key::Named(winit::keyboard::NamedKey::Space)=>input_ctrl!(SetJump,s),
// TODO: bind system so playback pausing can use spacebar
winit::keyboard::Key::Named(winit::keyboard::NamedKey::Enter)=>if s{
let paused=!self.simulation_paused;
self.simulation_paused=paused;
if paused{
self.free_mouse();
}else{
self.lock_mouse();
}
Some(SessionInstructionSubset::Control(SessionControlInstruction::SetPaused(paused)))
}else{None},
winit::keyboard::Key::Named(winit::keyboard::NamedKey::ArrowUp)=>session_playback!(IncreaseTimescale,s),
winit::keyboard::Key::Named(winit::keyboard::NamedKey::ArrowDown)=>session_playback!(DecreaseTimescale,s),
winit::keyboard::Key::Named(winit::keyboard::NamedKey::ArrowLeft)=>session_playback!(SkipBack,s),
@@ -207,7 +214,7 @@ impl WindowContext<'_>{
fn device_event(&mut self,time:SessionTime,event:winit::event::DeviceEvent){
match event{
winit::event::DeviceEvent::MouseMotion{
delta,
delta:(delta_x,delta_y),
}=>{
if self.manual_mouse_lock{
match self.window.set_cursor_position(self.get_middle_of_screen()){
@@ -215,7 +222,10 @@ impl WindowContext<'_>{
Err(e)=>println!("Could not set cursor position: {:?}",e),
}
}
self.mouse_pos+=glam::dvec2(delta.0,delta.1);
self.mouse_pos+=glam::dvec2(delta_x,delta_y);
if self.simulation_paused{
return;
}
self.physics_thread.send(TimedInstruction{
time,
instruction:PhysicsWorkerInstruction::SessionInput(SessionInputInstruction::Mouse(self.mouse_pos.as_ivec2())),