Compare commits
2 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
6516b3ee30
|
|||
|
32d0e96958
|
@@ -97,7 +97,24 @@ impl WindowContext<'_>{
|
|||||||
}
|
}
|
||||||
self.window.set_cursor_visible(true);
|
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)=>{
|
(keycode,state)=>{
|
||||||
|
if self.simulation_paused{
|
||||||
|
return;
|
||||||
|
}
|
||||||
let s=state.is_pressed();
|
let s=state.is_pressed();
|
||||||
|
|
||||||
// internal variants for this scope
|
// internal variants for this scope
|
||||||
@@ -139,16 +156,6 @@ impl WindowContext<'_>{
|
|||||||
if let Some(session_instruction)=match keycode{
|
if let Some(session_instruction)=match keycode{
|
||||||
winit::keyboard::Key::Named(winit::keyboard::NamedKey::Space)=>input_ctrl!(SetJump,s),
|
winit::keyboard::Key::Named(winit::keyboard::NamedKey::Space)=>input_ctrl!(SetJump,s),
|
||||||
// TODO: bind system so playback pausing can use spacebar
|
// 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::ArrowUp)=>session_playback!(IncreaseTimescale,s),
|
||||||
winit::keyboard::Key::Named(winit::keyboard::NamedKey::ArrowDown)=>session_playback!(DecreaseTimescale,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),
|
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){
|
fn device_event(&mut self,time:SessionTime,event:winit::event::DeviceEvent){
|
||||||
match event{
|
match event{
|
||||||
winit::event::DeviceEvent::MouseMotion{
|
winit::event::DeviceEvent::MouseMotion{
|
||||||
delta,
|
delta:(delta_x,delta_y),
|
||||||
}=>{
|
}=>{
|
||||||
if self.manual_mouse_lock{
|
if self.manual_mouse_lock{
|
||||||
match self.window.set_cursor_position(self.get_middle_of_screen()){
|
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),
|
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{
|
self.physics_thread.send(TimedInstruction{
|
||||||
time,
|
time,
|
||||||
instruction:PhysicsWorkerInstruction::SessionInput(SessionInputInstruction::Mouse(self.mouse_pos.as_ivec2())),
|
instruction:PhysicsWorkerInstruction::SessionInput(SessionInputInstruction::Mouse(self.mouse_pos.as_ivec2())),
|
||||||
|
|||||||
Reference in New Issue
Block a user