2022-06-10 13:43:33 +03:00
|
|
|
#![allow(clippy::single_match)]
|
|
|
|
|
2019-11-22 17:11:04 -07:00
|
|
|
// This example is used by developers to test various window functions.
|
|
|
|
|
2020-09-09 17:58:30 -08:00
|
|
|
use simple_logger::SimpleLogger;
|
2019-11-22 17:11:04 -07:00
|
|
|
use winit::{
|
|
|
|
dpi::{LogicalSize, PhysicalSize},
|
2023-05-28 20:02:59 +02:00
|
|
|
event::{DeviceEvent, ElementState, Event, KeyEvent, RawKeyEvent, WindowEvent},
|
2023-05-30 21:32:31 +02:00
|
|
|
event_loop::{DeviceEvents, EventLoop},
|
2023-05-28 20:02:59 +02:00
|
|
|
keyboard::{Key, KeyCode},
|
2019-11-22 17:11:04 -07:00
|
|
|
window::{Fullscreen, WindowBuilder},
|
|
|
|
};
|
|
|
|
|
2023-06-19 11:46:38 -07:00
|
|
|
#[path = "util/fill.rs"]
|
|
|
|
mod fill;
|
|
|
|
|
2023-04-11 12:50:52 +01:00
|
|
|
fn main() -> Result<(), impl std::error::Error> {
|
2020-09-09 17:58:30 -08:00
|
|
|
SimpleLogger::new().init().unwrap();
|
2023-08-13 23:20:09 +04:00
|
|
|
let event_loop = EventLoop::new().unwrap();
|
2019-11-22 17:11:04 -07:00
|
|
|
|
|
|
|
let window = WindowBuilder::new()
|
|
|
|
.with_title("A fantastic window!")
|
2020-01-04 11:03:44 -07:00
|
|
|
.with_inner_size(LogicalSize::new(100.0, 100.0))
|
2019-11-22 17:11:04 -07:00
|
|
|
.build(&event_loop)
|
|
|
|
.unwrap();
|
|
|
|
|
|
|
|
eprintln!("debugging keys:");
|
|
|
|
eprintln!(" (E) Enter exclusive fullscreen");
|
|
|
|
eprintln!(" (F) Toggle borderless fullscreen");
|
2020-09-22 04:54:47 +03:00
|
|
|
eprintln!(" (P) Toggle borderless fullscreen on system's preffered monitor");
|
2019-11-22 17:11:04 -07: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-30 21:32:31 +02:00
|
|
|
event_loop.listen_device_events(DeviceEvents::Always);
|
2022-06-10 15:39:02 +03:00
|
|
|
|
2019-11-22 17:11:04 -07:00
|
|
|
event_loop.run(move |event, _, control_flow| {
|
2022-04-09 18:32:02 -07:00
|
|
|
control_flow.set_wait();
|
2019-11-22 17:11:04 -07:00
|
|
|
|
|
|
|
match event {
|
2023-05-28 20:02:59 +02:00
|
|
|
// This used to use the virtual key, but the new API
|
|
|
|
// only provides the `physical_key` (`Code`).
|
2019-11-22 17:11:04 -07:00
|
|
|
Event::DeviceEvent {
|
|
|
|
event:
|
2023-05-28 20:02:59 +02:00
|
|
|
DeviceEvent::Key(RawKeyEvent {
|
|
|
|
physical_key,
|
|
|
|
state: ElementState::Released,
|
2019-11-22 17:11:04 -07:00
|
|
|
..
|
|
|
|
}),
|
|
|
|
..
|
2023-05-28 20:02:59 +02:00
|
|
|
} => match physical_key {
|
|
|
|
KeyCode::KeyM => {
|
2019-11-22 17:11:04 -07:00
|
|
|
if minimized {
|
|
|
|
minimized = !minimized;
|
|
|
|
window.set_minimized(minimized);
|
2022-12-09 20:33:11 +02:00
|
|
|
window.focus_window();
|
2019-11-22 17:11:04 -07:00
|
|
|
}
|
|
|
|
}
|
2023-05-28 20:02:59 +02:00
|
|
|
KeyCode::KeyV => {
|
2019-11-22 17:11:04 -07:00
|
|
|
if !visible {
|
|
|
|
visible = !visible;
|
|
|
|
window.set_visible(visible);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
_ => (),
|
|
|
|
},
|
|
|
|
Event::WindowEvent {
|
2022-06-10 13:43:33 +03:00
|
|
|
event:
|
|
|
|
WindowEvent::KeyboardInput {
|
2023-05-28 20:02:59 +02:00
|
|
|
event:
|
|
|
|
KeyEvent {
|
|
|
|
logical_key: Key::Character(key_str),
|
2022-06-10 13:43:33 +03:00
|
|
|
state: ElementState::Pressed,
|
|
|
|
..
|
|
|
|
},
|
|
|
|
..
|
|
|
|
},
|
2019-11-22 17:11:04 -07:00
|
|
|
..
|
2023-05-28 20:02:59 +02: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 13:43:33 +03:00
|
|
|
fn area(size: PhysicalSize<u32>) -> u32 {
|
|
|
|
size.width * size.height
|
2019-11-22 17:11:04 -07:00
|
|
|
}
|
2022-06-10 13:43:33 +03: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-22 17:11:04 -07:00
|
|
|
}
|
2022-06-10 13:43:33 +03:00
|
|
|
}
|
2023-05-28 20:02:59 +02:00
|
|
|
"f" => {
|
2022-06-10 13:43:33 +03: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-22 17:11:04 -07:00
|
|
|
}
|
2022-06-10 13:43:33 +03:00
|
|
|
}
|
2023-05-28 20:02:59 +02:00
|
|
|
"p" => {
|
2022-06-10 13:43:33 +03:00
|
|
|
if window.fullscreen().is_some() {
|
|
|
|
window.set_fullscreen(None);
|
|
|
|
} else {
|
|
|
|
window.set_fullscreen(Some(Fullscreen::Borderless(None)));
|
2019-11-22 17:11:04 -07:00
|
|
|
}
|
2022-06-10 13:43:33 +03:00
|
|
|
}
|
2023-05-28 20:02:59 +02:00
|
|
|
"m" => {
|
2022-06-10 13:43:33 +03:00
|
|
|
minimized = !minimized;
|
|
|
|
window.set_minimized(minimized);
|
|
|
|
}
|
2023-05-28 20:02:59 +02:00
|
|
|
"q" => {
|
2022-06-10 13:43:33 +03:00
|
|
|
control_flow.set_exit();
|
|
|
|
}
|
2023-05-28 20:02:59 +02:00
|
|
|
"v" => {
|
2022-06-10 13:43:33 +03:00
|
|
|
visible = !visible;
|
|
|
|
window.set_visible(visible);
|
|
|
|
}
|
2023-05-28 20:02:59 +02:00
|
|
|
"x" => {
|
2022-06-10 13:43:33 +03:00
|
|
|
let is_maximized = window.is_maximized();
|
|
|
|
window.set_maximized(!is_maximized);
|
|
|
|
}
|
2019-11-22 17:11:04 -07:00
|
|
|
_ => (),
|
|
|
|
},
|
|
|
|
Event::WindowEvent {
|
|
|
|
event: WindowEvent::CloseRequested,
|
|
|
|
window_id,
|
2022-04-09 18:32:02 -07:00
|
|
|
} if window_id == window.id() => control_flow.set_exit(),
|
2023-06-19 11:46:38 -07:00
|
|
|
Event::RedrawRequested(_) => {
|
|
|
|
fill::fill_window(&window);
|
|
|
|
}
|
2019-11-22 17:11:04 -07:00
|
|
|
_ => (),
|
|
|
|
}
|
2023-04-11 12:50:52 +01:00
|
|
|
})
|
2019-11-22 17:11:04 -07:00
|
|
|
}
|