mirror of
https://github.com/italicsjenga/winit-sonoma-fix.git
synced 2025-01-10 05:01:31 +11:00
0d366ffbda
This re-works the portable `run()` API that consumes the `EventLoop` and runs the loop on the calling thread until the app exits. This can be supported across _all_ platforms and compared to the previous `run() -> !` API is now able to return a `Result` status on all platforms except iOS and Web. Fixes: #2709 By moving away from `run() -> !` we stop calling `std::process::exit()` internally as a means to kill the process without returning which means it's possible to return an exit status and applications can return from their `main()` function normally. This also fixes Android support where an Activity runs in a thread but we can't assume to have full ownership of the process (other services could be running in separate threads). Additionally all examples have generally been updated so that `main()` returns a `Result` from `run()` Fixes: #2709
110 lines
3.7 KiB
Rust
110 lines
3.7 KiB
Rust
#![allow(clippy::single_match)]
|
|
|
|
use log::LevelFilter;
|
|
use simple_logger::SimpleLogger;
|
|
use winit::{
|
|
dpi::{PhysicalPosition, PhysicalSize},
|
|
event::{ElementState, Event, Ime, WindowEvent},
|
|
event_loop::{ControlFlow, EventLoop},
|
|
keyboard::{Key, KeyCode},
|
|
window::{ImePurpose, WindowBuilder},
|
|
};
|
|
|
|
#[path = "util/fill.rs"]
|
|
mod fill;
|
|
|
|
fn main() -> Result<(), impl std::error::Error> {
|
|
SimpleLogger::new()
|
|
.with_level(LevelFilter::Trace)
|
|
.init()
|
|
.unwrap();
|
|
|
|
println!("IME position will system default");
|
|
println!("Click to set IME position to cursor's");
|
|
println!("Press F2 to toggle IME. See the documentation of `set_ime_allowed` for more info");
|
|
println!("Press F3 to cycle through IME purposes.");
|
|
|
|
let event_loop = EventLoop::new();
|
|
|
|
let window = WindowBuilder::new()
|
|
.with_inner_size(winit::dpi::LogicalSize::new(256f64, 128f64))
|
|
.build(&event_loop)
|
|
.unwrap();
|
|
|
|
let mut ime_purpose = ImePurpose::Normal;
|
|
let mut ime_allowed = true;
|
|
window.set_ime_allowed(ime_allowed);
|
|
|
|
let mut may_show_ime = false;
|
|
let mut cursor_position = PhysicalPosition::new(0.0, 0.0);
|
|
let mut ime_pos = PhysicalPosition::new(0.0, 0.0);
|
|
|
|
event_loop.run(move |event, _, control_flow| {
|
|
*control_flow = ControlFlow::Wait;
|
|
match event {
|
|
Event::WindowEvent {
|
|
event: WindowEvent::CloseRequested,
|
|
..
|
|
} => *control_flow = ControlFlow::Exit,
|
|
Event::WindowEvent {
|
|
event: WindowEvent::CursorMoved { position, .. },
|
|
..
|
|
} => {
|
|
cursor_position = position;
|
|
}
|
|
Event::WindowEvent {
|
|
event:
|
|
WindowEvent::MouseInput {
|
|
state: ElementState::Released,
|
|
..
|
|
},
|
|
..
|
|
} => {
|
|
println!(
|
|
"Setting ime position to {}, {}",
|
|
cursor_position.x, cursor_position.y
|
|
);
|
|
ime_pos = cursor_position;
|
|
if may_show_ime {
|
|
window.set_ime_cursor_area(ime_pos, PhysicalSize::new(10, 10));
|
|
}
|
|
}
|
|
Event::WindowEvent {
|
|
event: WindowEvent::Ime(event),
|
|
..
|
|
} => {
|
|
println!("{event:?}");
|
|
may_show_ime = event != Ime::Disabled;
|
|
if may_show_ime {
|
|
window.set_ime_cursor_area(ime_pos, PhysicalSize::new(10, 10));
|
|
}
|
|
}
|
|
Event::WindowEvent {
|
|
event: WindowEvent::KeyboardInput { event, .. },
|
|
..
|
|
} => {
|
|
println!("key: {event:?}");
|
|
|
|
if event.state == ElementState::Pressed && event.physical_key == KeyCode::F2 {
|
|
ime_allowed = !ime_allowed;
|
|
window.set_ime_allowed(ime_allowed);
|
|
println!("\nIME allowed: {ime_allowed}\n");
|
|
}
|
|
if event.state == ElementState::Pressed && event.logical_key == Key::F3 {
|
|
ime_purpose = match ime_purpose {
|
|
ImePurpose::Normal => ImePurpose::Password,
|
|
ImePurpose::Password => ImePurpose::Terminal,
|
|
_ => ImePurpose::Normal,
|
|
};
|
|
window.set_ime_purpose(ime_purpose);
|
|
println!("\nIME purpose: {ime_purpose:?}\n");
|
|
}
|
|
}
|
|
Event::RedrawRequested(_) => {
|
|
fill::fill_window(&window);
|
|
}
|
|
_ => (),
|
|
}
|
|
})
|
|
}
|