2022-06-10 20:43:33 +10:00
|
|
|
#![allow(clippy::single_match)]
|
|
|
|
|
2019-11-23 11:11:04 +11:00
|
|
|
// This example is used by developers to test various window functions.
|
|
|
|
|
2020-09-10 11:58:30 +10:00
|
|
|
use simple_logger::SimpleLogger;
|
2019-11-23 11:11:04 +11:00
|
|
|
use winit::{
|
|
|
|
dpi::{LogicalSize, PhysicalSize},
|
2023-05-29 04:02:59 +10:00
|
|
|
event::{DeviceEvent, ElementState, Event, KeyEvent, RawKeyEvent, WindowEvent},
|
2023-05-31 05:32:31 +10:00
|
|
|
event_loop::{DeviceEvents, EventLoop},
|
2023-05-29 04:02:59 +10:00
|
|
|
keyboard::{Key, KeyCode},
|
2019-11-23 11:11:04 +11:00
|
|
|
window::{Fullscreen, WindowBuilder},
|
|
|
|
};
|
|
|
|
|
|
|
|
fn main() {
|
2020-09-10 11:58:30 +10:00
|
|
|
SimpleLogger::new().init().unwrap();
|
2019-11-23 11:11:04 +11:00
|
|
|
let event_loop = EventLoop::new();
|
|
|
|
|
|
|
|
let window = WindowBuilder::new()
|
|
|
|
.with_title("A fantastic window!")
|
2020-01-05 05:03:44 +11:00
|
|
|
.with_inner_size(LogicalSize::new(100.0, 100.0))
|
2019-11-23 11:11:04 +11:00
|
|
|
.build(&event_loop)
|
|
|
|
.unwrap();
|
|
|
|
|
|
|
|
eprintln!("debugging keys:");
|
|
|
|
eprintln!(" (E) Enter exclusive fullscreen");
|
|
|
|
eprintln!(" (F) Toggle borderless fullscreen");
|
2020-09-22 11:54:47 +10:00
|
|
|
eprintln!(" (P) Toggle borderless fullscreen on system's preffered monitor");
|
2019-11-23 11:11:04 +11:00
|
|
|
eprintln!(" (M) Toggle minimized");
|
|
|
|
eprintln!(" (Q) Quit event loop");
|
|
|
|
eprintln!(" (V) Toggle visibility");
|
|
|
|
eprintln!(" (X) Toggle maximized");
|
|
|
|
|
|
|
|
let mut minimized = false;
|
|
|
|
let mut visible = true;
|
|
|
|
|
2023-05-31 05:32:31 +10:00
|
|
|
event_loop.listen_device_events(DeviceEvents::Always);
|
2022-06-10 22:39:02 +10:00
|
|
|
|
2019-11-23 11:11:04 +11:00
|
|
|
event_loop.run(move |event, _, control_flow| {
|
2022-04-10 11:32:02 +10:00
|
|
|
control_flow.set_wait();
|
2019-11-23 11:11:04 +11:00
|
|
|
|
|
|
|
match event {
|
2023-05-29 04:02:59 +10:00
|
|
|
// This used to use the virtual key, but the new API
|
|
|
|
// only provides the `physical_key` (`Code`).
|
2019-11-23 11:11:04 +11:00
|
|
|
Event::DeviceEvent {
|
|
|
|
event:
|
2023-05-29 04:02:59 +10:00
|
|
|
DeviceEvent::Key(RawKeyEvent {
|
|
|
|
physical_key,
|
|
|
|
state: ElementState::Released,
|
2019-11-23 11:11:04 +11:00
|
|
|
..
|
|
|
|
}),
|
|
|
|
..
|
2023-05-29 04:02:59 +10:00
|
|
|
} => match physical_key {
|
|
|
|
KeyCode::KeyM => {
|
2019-11-23 11:11:04 +11:00
|
|
|
if minimized {
|
|
|
|
minimized = !minimized;
|
|
|
|
window.set_minimized(minimized);
|
2022-12-10 05:33:11 +11:00
|
|
|
window.focus_window();
|
2019-11-23 11:11:04 +11:00
|
|
|
}
|
|
|
|
}
|
2023-05-29 04:02:59 +10:00
|
|
|
KeyCode::KeyV => {
|
2019-11-23 11:11:04 +11:00
|
|
|
if !visible {
|
|
|
|
visible = !visible;
|
|
|
|
window.set_visible(visible);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
_ => (),
|
|
|
|
},
|
|
|
|
Event::WindowEvent {
|
2022-06-10 20:43:33 +10:00
|
|
|
event:
|
|
|
|
WindowEvent::KeyboardInput {
|
2023-05-29 04:02:59 +10:00
|
|
|
event:
|
|
|
|
KeyEvent {
|
|
|
|
logical_key: Key::Character(key_str),
|
2022-06-10 20:43:33 +10:00
|
|
|
state: ElementState::Pressed,
|
|
|
|
..
|
|
|
|
},
|
|
|
|
..
|
|
|
|
},
|
2019-11-23 11:11:04 +11:00
|
|
|
..
|
2023-05-29 04:02:59 +10:00
|
|
|
} => match key_str.as_ref() {
|
|
|
|
// WARNING: Consider using `key_without_modifers()` if available on your platform.
|
|
|
|
// See the `key_binding` example
|
|
|
|
"e" => {
|
2022-06-10 20:43:33 +10:00
|
|
|
fn area(size: PhysicalSize<u32>) -> u32 {
|
|
|
|
size.width * size.height
|
2019-11-23 11:11:04 +11:00
|
|
|
}
|
2022-06-10 20:43:33 +10:00
|
|
|
|
|
|
|
let monitor = window.current_monitor().unwrap();
|
|
|
|
if let Some(mode) = monitor
|
|
|
|
.video_modes()
|
|
|
|
.max_by(|a, b| area(a.size()).cmp(&area(b.size())))
|
|
|
|
{
|
|
|
|
window.set_fullscreen(Some(Fullscreen::Exclusive(mode)));
|
|
|
|
} else {
|
|
|
|
eprintln!("no video modes available");
|
2019-11-23 11:11:04 +11:00
|
|
|
}
|
2022-06-10 20:43:33 +10:00
|
|
|
}
|
2023-05-29 04:02:59 +10:00
|
|
|
"f" => {
|
2022-06-10 20:43:33 +10:00
|
|
|
if window.fullscreen().is_some() {
|
|
|
|
window.set_fullscreen(None);
|
|
|
|
} else {
|
|
|
|
let monitor = window.current_monitor();
|
|
|
|
window.set_fullscreen(Some(Fullscreen::Borderless(monitor)));
|
2019-11-23 11:11:04 +11:00
|
|
|
}
|
2022-06-10 20:43:33 +10:00
|
|
|
}
|
2023-05-29 04:02:59 +10:00
|
|
|
"p" => {
|
2022-06-10 20:43:33 +10:00
|
|
|
if window.fullscreen().is_some() {
|
|
|
|
window.set_fullscreen(None);
|
|
|
|
} else {
|
|
|
|
window.set_fullscreen(Some(Fullscreen::Borderless(None)));
|
2019-11-23 11:11:04 +11:00
|
|
|
}
|
2022-06-10 20:43:33 +10:00
|
|
|
}
|
2023-05-29 04:02:59 +10:00
|
|
|
"m" => {
|
2022-06-10 20:43:33 +10:00
|
|
|
minimized = !minimized;
|
|
|
|
window.set_minimized(minimized);
|
|
|
|
}
|
2023-05-29 04:02:59 +10:00
|
|
|
"q" => {
|
2022-06-10 20:43:33 +10:00
|
|
|
control_flow.set_exit();
|
|
|
|
}
|
2023-05-29 04:02:59 +10:00
|
|
|
"v" => {
|
2022-06-10 20:43:33 +10:00
|
|
|
visible = !visible;
|
|
|
|
window.set_visible(visible);
|
|
|
|
}
|
2023-05-29 04:02:59 +10:00
|
|
|
"x" => {
|
2022-06-10 20:43:33 +10:00
|
|
|
let is_maximized = window.is_maximized();
|
|
|
|
window.set_maximized(!is_maximized);
|
|
|
|
}
|
2019-11-23 11:11:04 +11:00
|
|
|
_ => (),
|
|
|
|
},
|
|
|
|
Event::WindowEvent {
|
|
|
|
event: WindowEvent::CloseRequested,
|
|
|
|
window_id,
|
2022-04-10 11:32:02 +10:00
|
|
|
} if window_id == window.id() => control_flow.set_exit(),
|
2019-11-23 11:11:04 +11:00
|
|
|
_ => (),
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|