2022-06-10 20:43:33 +10:00
|
|
|
#![allow(clippy::single_match)]
|
|
|
|
|
2019-07-30 04:16:14 +10:00
|
|
|
use std::io::{stdin, stdout, Write};
|
2020-09-10 11:58:30 +10:00
|
|
|
|
|
|
|
use simple_logger::SimpleLogger;
|
2019-07-30 04:16:14 +10:00
|
|
|
use winit::event::{ElementState, Event, KeyboardInput, VirtualKeyCode, WindowEvent};
|
2022-04-10 11:32:02 +10:00
|
|
|
use winit::event_loop::EventLoop;
|
2019-07-30 04:16:14 +10:00
|
|
|
use winit::monitor::{MonitorHandle, VideoMode};
|
|
|
|
use winit::window::{Fullscreen, WindowBuilder};
|
2014-07-31 17:56:53 +10:00
|
|
|
|
|
|
|
fn main() {
|
2020-09-10 11:58:30 +10:00
|
|
|
SimpleLogger::new().init().unwrap();
|
2019-02-06 02:30:33 +11:00
|
|
|
let event_loop = EventLoop::new();
|
2017-09-01 19:04:57 +10:00
|
|
|
|
2019-07-30 04:16:14 +10:00
|
|
|
print!("Please choose the fullscreen mode: (1) exclusive, (2) borderless: ");
|
|
|
|
stdout().flush().unwrap();
|
2014-07-31 17:56:53 +10:00
|
|
|
|
2019-07-30 04:16:14 +10:00
|
|
|
let mut num = String::new();
|
|
|
|
stdin().read_line(&mut num).unwrap();
|
2022-01-01 13:00:11 +11:00
|
|
|
let num = num.trim().parse().expect("Please enter a number");
|
2019-07-30 04:16:14 +10:00
|
|
|
|
|
|
|
let fullscreen = Some(match num {
|
|
|
|
1 => Fullscreen::Exclusive(prompt_for_video_mode(&prompt_for_monitor(&event_loop))),
|
2020-09-22 11:54:47 +10:00
|
|
|
2 => Fullscreen::Borderless(Some(prompt_for_monitor(&event_loop))),
|
2019-07-30 04:16:14 +10:00
|
|
|
_ => panic!("Please enter a valid number"),
|
|
|
|
});
|
2014-07-31 17:56:53 +10:00
|
|
|
|
2018-12-19 15:07:33 +11:00
|
|
|
let mut decorations = true;
|
|
|
|
|
2019-02-06 02:30:33 +11:00
|
|
|
let window = WindowBuilder::new()
|
2016-05-08 17:28:42 +10:00
|
|
|
.with_title("Hello world!")
|
2019-07-30 04:16:14 +10:00
|
|
|
.with_fullscreen(fullscreen.clone())
|
2019-02-06 02:30:33 +11:00
|
|
|
.build(&event_loop)
|
2014-08-02 16:24:30 +10:00
|
|
|
.unwrap();
|
2014-07-31 17:56:53 +10:00
|
|
|
|
2019-02-06 02:30:33 +11:00
|
|
|
event_loop.run(move |event, _, control_flow| {
|
2022-04-10 11:32:02 +10:00
|
|
|
control_flow.set_wait();
|
2015-06-16 21:48:08 +10:00
|
|
|
|
|
|
|
match event {
|
2019-06-25 02:14:55 +10:00
|
|
|
Event::WindowEvent { event, .. } => match event {
|
2022-04-10 11:32:02 +10:00
|
|
|
WindowEvent::CloseRequested => control_flow.set_exit(),
|
2019-06-25 02:14:55 +10:00
|
|
|
WindowEvent::KeyboardInput {
|
|
|
|
input:
|
|
|
|
KeyboardInput {
|
|
|
|
virtual_keycode: Some(virtual_code),
|
|
|
|
state,
|
|
|
|
..
|
|
|
|
},
|
|
|
|
..
|
|
|
|
} => match (virtual_code, state) {
|
2022-04-10 11:32:02 +10:00
|
|
|
(VirtualKeyCode::Escape, _) => control_flow.set_exit(),
|
2019-06-25 02:14:55 +10:00
|
|
|
(VirtualKeyCode::F, ElementState::Pressed) => {
|
2019-07-30 04:16:14 +10:00
|
|
|
if window.fullscreen().is_some() {
|
2019-06-25 02:14:55 +10:00
|
|
|
window.set_fullscreen(None);
|
|
|
|
} else {
|
2019-07-30 04:16:14 +10:00
|
|
|
window.set_fullscreen(fullscreen.clone());
|
2019-06-25 02:14:55 +10:00
|
|
|
}
|
|
|
|
}
|
|
|
|
(VirtualKeyCode::S, ElementState::Pressed) => {
|
|
|
|
println!("window.fullscreen {:?}", window.fullscreen());
|
|
|
|
}
|
|
|
|
(VirtualKeyCode::M, ElementState::Pressed) => {
|
2021-01-28 05:01:17 +11:00
|
|
|
let is_maximized = window.is_maximized();
|
|
|
|
window.set_maximized(!is_maximized);
|
2019-06-25 02:14:55 +10:00
|
|
|
}
|
|
|
|
(VirtualKeyCode::D, ElementState::Pressed) => {
|
|
|
|
decorations = !decorations;
|
|
|
|
window.set_decorations(decorations);
|
|
|
|
}
|
2018-04-13 03:12:15 +10:00
|
|
|
_ => (),
|
2019-06-25 02:14:55 +10:00
|
|
|
},
|
|
|
|
_ => (),
|
2017-01-29 01:45:01 +11:00
|
|
|
},
|
2019-06-25 02:14:55 +10:00
|
|
|
_ => {}
|
2015-06-16 21:48:08 +10:00
|
|
|
}
|
2017-01-29 01:45:01 +11:00
|
|
|
});
|
2014-07-31 17:56:53 +10:00
|
|
|
}
|
2018-12-19 15:07:33 +11:00
|
|
|
|
|
|
|
// Enumerate monitors and prompt user to choose one
|
2019-02-06 02:30:33 +11:00
|
|
|
fn prompt_for_monitor(event_loop: &EventLoop<()>) -> MonitorHandle {
|
2019-05-30 11:29:54 +10:00
|
|
|
for (num, monitor) in event_loop.available_monitors().enumerate() {
|
|
|
|
println!("Monitor #{}: {:?}", num, monitor.name());
|
2018-12-19 15:07:33 +11:00
|
|
|
}
|
|
|
|
|
|
|
|
print!("Please write the number of the monitor to use: ");
|
2019-07-30 04:16:14 +10:00
|
|
|
stdout().flush().unwrap();
|
2018-12-19 15:07:33 +11:00
|
|
|
|
|
|
|
let mut num = String::new();
|
2019-07-30 04:16:14 +10:00
|
|
|
stdin().read_line(&mut num).unwrap();
|
2022-01-01 13:00:11 +11:00
|
|
|
let num = num.trim().parse().expect("Please enter a number");
|
2019-06-22 01:33:15 +10:00
|
|
|
let monitor = event_loop
|
|
|
|
.available_monitors()
|
|
|
|
.nth(num)
|
|
|
|
.expect("Please enter a valid ID");
|
2018-12-19 15:07:33 +11:00
|
|
|
|
2019-05-30 11:29:54 +10:00
|
|
|
println!("Using {:?}", monitor.name());
|
2018-12-19 15:07:33 +11:00
|
|
|
|
|
|
|
monitor
|
|
|
|
}
|
2019-07-30 04:16:14 +10:00
|
|
|
|
|
|
|
fn prompt_for_video_mode(monitor: &MonitorHandle) -> VideoMode {
|
|
|
|
for (i, video_mode) in monitor.video_modes().enumerate() {
|
|
|
|
println!("Video mode #{}: {}", i, video_mode);
|
|
|
|
}
|
|
|
|
|
|
|
|
print!("Please write the number of the video mode to use: ");
|
|
|
|
stdout().flush().unwrap();
|
|
|
|
|
|
|
|
let mut num = String::new();
|
|
|
|
stdin().read_line(&mut num).unwrap();
|
2022-01-01 13:00:11 +11:00
|
|
|
let num = num.trim().parse().expect("Please enter a number");
|
2019-07-30 04:16:14 +10:00
|
|
|
let video_mode = monitor
|
|
|
|
.video_modes()
|
|
|
|
.nth(num)
|
|
|
|
.expect("Please enter a valid ID");
|
|
|
|
|
|
|
|
println!("Using {}", video_mode);
|
|
|
|
|
|
|
|
video_mode
|
|
|
|
}
|