mirror of
https://github.com/italicsjenga/winit-sonoma-fix.git
synced 2025-01-11 05:21:31 +11:00
f9758528f6
Inner panics could make it hard to trouble shoot the issues and for some users it's not desirable. The inner panics were left only when they are used to `assert!` during development. This reverts commit 9f91bc413fe20618bd7090829832bb074aab15c3 which reverted the original patch which was merged without a proper review. Fixes: #500.
52 lines
1.6 KiB
Rust
52 lines
1.6 KiB
Rust
use simple_logger::SimpleLogger;
|
|
use winit::{
|
|
event::{Event, WindowEvent},
|
|
event_loop::{ControlFlow, EventLoop},
|
|
window::WindowBuilder,
|
|
};
|
|
|
|
#[path = "util/fill.rs"]
|
|
mod fill;
|
|
|
|
fn main() -> Result<(), impl std::error::Error> {
|
|
SimpleLogger::new().init().unwrap();
|
|
let event_loop = EventLoop::new().unwrap();
|
|
|
|
let window = WindowBuilder::new()
|
|
.with_title("Touchpad gestures")
|
|
.build(&event_loop)
|
|
.unwrap();
|
|
|
|
println!("Only supported on macOS at the moment.");
|
|
|
|
event_loop.run(move |event, _, control_flow| {
|
|
*control_flow = ControlFlow::Wait;
|
|
|
|
if let Event::WindowEvent { event, .. } = event {
|
|
match event {
|
|
WindowEvent::CloseRequested => *control_flow = ControlFlow::Exit,
|
|
WindowEvent::TouchpadMagnify { delta, .. } => {
|
|
if delta > 0.0 {
|
|
println!("Zoomed in {delta}");
|
|
} else {
|
|
println!("Zoomed out {delta}");
|
|
}
|
|
}
|
|
WindowEvent::SmartMagnify { .. } => {
|
|
println!("Smart zoom");
|
|
}
|
|
WindowEvent::TouchpadRotate { delta, .. } => {
|
|
if delta > 0.0 {
|
|
println!("Rotated counterclockwise {delta}");
|
|
} else {
|
|
println!("Rotated clockwise {delta}");
|
|
}
|
|
}
|
|
_ => (),
|
|
}
|
|
} else if let Event::RedrawRequested(_) = event {
|
|
fill::fill_window(&window);
|
|
}
|
|
})
|
|
}
|