From 028d3ec16d2f71e9d60675c395151b9596d2a1b5 Mon Sep 17 00:00:00 2001 From: Osspial Date: Sun, 5 Jan 2020 02:12:03 -0500 Subject: [PATCH] Make examples set control_flow in a more realistic way (#1363) * Make examples set control_flow in a more realistic way * Format --- examples/cursor.rs | 58 +++++++++++++++++++---------------- examples/cursor_grab.rs | 1 + examples/custom_events.rs | 18 ++++++----- examples/min_max_size.rs | 3 +- examples/minimize.rs | 34 +++++++++++--------- examples/multiwindow.rs | 1 + examples/request_redraw.rs | 37 ++++++++++++---------- examples/resizable.rs | 1 + examples/transparent.rs | 3 +- examples/web.rs | 4 ++- examples/window.rs | 3 +- examples/window_icon.rs | 1 + examples/window_run_return.rs | 2 +- 13 files changed, 96 insertions(+), 70 deletions(-) diff --git a/examples/cursor.rs b/examples/cursor.rs index d5bd34a9..70c2ec03 100644 --- a/examples/cursor.rs +++ b/examples/cursor.rs @@ -12,35 +12,39 @@ fn main() { let mut cursor_idx = 0; - event_loop.run(move |event, _, control_flow| match event { - Event::WindowEvent { - event: - WindowEvent::KeyboardInput { - input: - KeyboardInput { - state: ElementState::Pressed, - .. - }, - .. - }, - .. - } => { - println!("Setting cursor to \"{:?}\"", CURSORS[cursor_idx]); - window.set_cursor_icon(CURSORS[cursor_idx]); - if cursor_idx < CURSORS.len() - 1 { - cursor_idx += 1; - } else { - cursor_idx = 0; + event_loop.run(move |event, _, control_flow| { + *control_flow = ControlFlow::Wait; + + match event { + Event::WindowEvent { + event: + WindowEvent::KeyboardInput { + input: + KeyboardInput { + state: ElementState::Pressed, + .. + }, + .. + }, + .. + } => { + println!("Setting cursor to \"{:?}\"", CURSORS[cursor_idx]); + window.set_cursor_icon(CURSORS[cursor_idx]); + if cursor_idx < CURSORS.len() - 1 { + cursor_idx += 1; + } else { + cursor_idx = 0; + } } + Event::WindowEvent { + event: WindowEvent::CloseRequested, + .. + } => { + *control_flow = ControlFlow::Exit; + return; + } + _ => (), } - Event::WindowEvent { - event: WindowEvent::CloseRequested, - .. - } => { - *control_flow = ControlFlow::Exit; - return; - } - _ => (), }); } diff --git a/examples/cursor_grab.rs b/examples/cursor_grab.rs index 13f14282..dd25179c 100644 --- a/examples/cursor_grab.rs +++ b/examples/cursor_grab.rs @@ -16,6 +16,7 @@ fn main() { event_loop.run(move |event, _, control_flow| { *control_flow = ControlFlow::Wait; + match event { Event::WindowEvent { event, .. } => match event { WindowEvent::CloseRequested => *control_flow = ControlFlow::Exit, diff --git a/examples/custom_events.rs b/examples/custom_events.rs index dba43624..3ed0c8b2 100644 --- a/examples/custom_events.rs +++ b/examples/custom_events.rs @@ -31,13 +31,17 @@ fn main() { } }); - event_loop.run(move |event, _, control_flow| match event { - Event::UserEvent(event) => println!("user event: {:?}", event), - Event::WindowEvent { - event: WindowEvent::CloseRequested, - .. - } => *control_flow = ControlFlow::Exit, - _ => *control_flow = ControlFlow::Wait, + event_loop.run(move |event, _, control_flow| { + *control_flow = ControlFlow::Wait; + + match event { + Event::UserEvent(event) => println!("user event: {:?}", event), + Event::WindowEvent { + event: WindowEvent::CloseRequested, + .. + } => *control_flow = ControlFlow::Exit, + _ => (), + } }); } diff --git a/examples/min_max_size.rs b/examples/min_max_size.rs index 4b24d161..8a5b6699 100644 --- a/examples/min_max_size.rs +++ b/examples/min_max_size.rs @@ -14,6 +14,7 @@ fn main() { window.set_max_inner_size(Some(LogicalSize::new(800.0, 400.0))); event_loop.run(move |event, _, control_flow| { + *control_flow = ControlFlow::Wait; println!("{:?}", event); match event { @@ -21,7 +22,7 @@ fn main() { event: WindowEvent::CloseRequested, .. } => *control_flow = ControlFlow::Exit, - _ => *control_flow = ControlFlow::Wait, + _ => (), } }); } diff --git a/examples/minimize.rs b/examples/minimize.rs index 5576f53c..cce72de3 100644 --- a/examples/minimize.rs +++ b/examples/minimize.rs @@ -12,24 +12,28 @@ fn main() { .build(&event_loop) .unwrap(); - event_loop.run(move |event, _, control_flow| match event { - Event::WindowEvent { - event: WindowEvent::CloseRequested, - .. - } => *control_flow = ControlFlow::Exit, + event_loop.run(move |event, _, control_flow| { + *control_flow = ControlFlow::Wait; - // Keyboard input event to handle minimize via a hotkey - Event::WindowEvent { - event: WindowEvent::KeyboardInput { input, .. }, - window_id, - } => { - if window_id == window.id() { - // Pressing the 'M' key will minimize the window - if input.virtual_keycode == Some(VirtualKeyCode::M) { - window.set_minimized(true); + match event { + Event::WindowEvent { + event: WindowEvent::CloseRequested, + .. + } => *control_flow = ControlFlow::Exit, + + // Keyboard input event to handle minimize via a hotkey + Event::WindowEvent { + event: WindowEvent::KeyboardInput { input, .. }, + window_id, + } => { + if window_id == window.id() { + // Pressing the 'M' key will minimize the window + if input.virtual_keycode == Some(VirtualKeyCode::M) { + window.set_minimized(true); + } } } + _ => (), } - _ => *control_flow = ControlFlow::Wait, }); } diff --git a/examples/multiwindow.rs b/examples/multiwindow.rs index 61dc1fd7..57a20c5b 100644 --- a/examples/multiwindow.rs +++ b/examples/multiwindow.rs @@ -16,6 +16,7 @@ fn main() { event_loop.run(move |event, event_loop, control_flow| { *control_flow = ControlFlow::Wait; + match event { Event::WindowEvent { event, window_id } => { match event { diff --git a/examples/request_redraw.rs b/examples/request_redraw.rs index a84cffe9..ea6760d6 100644 --- a/examples/request_redraw.rs +++ b/examples/request_redraw.rs @@ -1,8 +1,5 @@ -use instant::Instant; -use std::time::Duration; - use winit::{ - event::{Event, WindowEvent}, + event::{ElementState, Event, WindowEvent}, event_loop::{ControlFlow, EventLoop}, window::WindowBuilder, }; @@ -15,18 +12,26 @@ fn main() { .build(&event_loop) .unwrap(); - event_loop.run(move |event, _, control_flow| match event { - Event::WindowEvent { - event: WindowEvent::CloseRequested, - .. - } => *control_flow = ControlFlow::Exit, - Event::MainEventsCleared => { - window.request_redraw(); - *control_flow = ControlFlow::WaitUntil(Instant::now() + Duration::new(1, 0)) + event_loop.run(move |event, _, control_flow| { + println!("{:?}", event); + + *control_flow = ControlFlow::Wait; + + match event { + Event::WindowEvent { event, .. } => match event { + WindowEvent::CloseRequested => *control_flow = ControlFlow::Exit, + WindowEvent::MouseInput { + state: ElementState::Released, + .. + } => { + window.request_redraw(); + } + _ => (), + }, + Event::RedrawRequested(_) => { + println!("\nredrawing!\n"); + } + _ => (), } - Event::RedrawRequested(_) => { - println!("{:?}", event); - } - _ => (), }); } diff --git a/examples/resizable.rs b/examples/resizable.rs index 8aa6f706..3ebf26bf 100644 --- a/examples/resizable.rs +++ b/examples/resizable.rs @@ -18,6 +18,7 @@ fn main() { event_loop.run(move |event, _, control_flow| { *control_flow = ControlFlow::Wait; + match event { Event::WindowEvent { event, .. } => match event { WindowEvent::CloseRequested => *control_flow = ControlFlow::Exit, diff --git a/examples/transparent.rs b/examples/transparent.rs index 8eddb902..a1fdefe9 100644 --- a/examples/transparent.rs +++ b/examples/transparent.rs @@ -16,6 +16,7 @@ fn main() { window.set_title("A fantastic window!"); event_loop.run(move |event, _, control_flow| { + *control_flow = ControlFlow::Wait; println!("{:?}", event); match event { @@ -23,7 +24,7 @@ fn main() { event: WindowEvent::CloseRequested, .. } => *control_flow = ControlFlow::Exit, - _ => *control_flow = ControlFlow::Wait, + _ => (), } }); } diff --git a/examples/web.rs b/examples/web.rs index d5b92965..46b024cc 100644 --- a/examples/web.rs +++ b/examples/web.rs @@ -40,6 +40,8 @@ pub fn main() { } event_loop.run(move |event, _, control_flow| { + *control_flow = ControlFlow::Wait; + #[cfg(feature = "web-sys")] log::debug!("{:?}", event); @@ -54,7 +56,7 @@ pub fn main() { Event::MainEventsCleared => { window.request_redraw(); } - _ => *control_flow = ControlFlow::Wait, + _ => (), } }); } diff --git a/examples/window.rs b/examples/window.rs index e2265dbd..02a484a0 100644 --- a/examples/window.rs +++ b/examples/window.rs @@ -13,6 +13,7 @@ fn main() { .unwrap(); event_loop.run(move |event, _, control_flow| { + *control_flow = ControlFlow::Wait; println!("{:?}", event); match event { @@ -23,7 +24,7 @@ fn main() { Event::MainEventsCleared => { window.request_redraw(); } - _ => *control_flow = ControlFlow::Poll, + _ => (), } }); } diff --git a/examples/window_icon.rs b/examples/window_icon.rs index 8fdcdd40..86ea9556 100644 --- a/examples/window_icon.rs +++ b/examples/window_icon.rs @@ -27,6 +27,7 @@ fn main() { event_loop.run(move |event, _, control_flow| { *control_flow = ControlFlow::Wait; + if let Event::WindowEvent { event, .. } = event { use winit::event::WindowEvent::*; match event { diff --git a/examples/window_run_return.rs b/examples/window_run_return.rs index 05f50e9d..703c12ee 100644 --- a/examples/window_run_return.rs +++ b/examples/window_run_return.rs @@ -38,7 +38,6 @@ fn main() { .. } => { quit = true; - *control_flow = ControlFlow::Exit; } Event::MainEventsCleared => { *control_flow = ControlFlow::Exit; @@ -48,6 +47,7 @@ fn main() { }); // Sleep for 1/60 second to simulate rendering + println!("rendering"); sleep(Duration::from_millis(16)); } }