mirror of
https://github.com/italicsjenga/winit-sonoma-fix.git
synced 2025-01-12 05:31:31 +11:00
x11: Poll the window until it is really visible
Fixes #697 It seems that `XSync` doesn't really makes the window viewable. This feels hacky, other option to do it could be using `XIfEvent` or similar to listen to `MapNotify` events, but we'll have a loop still. In practice, this lasts between two and thre iterations on my machine, which is something not noticeable.
This commit is contained in:
parent
9ba16e31a9
commit
4d729164c7
|
@ -9,6 +9,8 @@ use std::sync::atomic::AtomicBool;
|
|||
use std::collections::VecDeque;
|
||||
use std::sync::{Arc, Mutex};
|
||||
use std::os::raw::c_long;
|
||||
use std::thread;
|
||||
use std::time::Duration;
|
||||
|
||||
use Api;
|
||||
use ContextError;
|
||||
|
@ -642,8 +644,13 @@ impl Window {
|
|||
let ref x_window: &XWindow = window.x.borrow();
|
||||
|
||||
// XSetInputFocus generates an error if the window is not visible,
|
||||
// therefore we call XSync before to make sure it's the case
|
||||
(display.xlib.XSync)(display.display, 0);
|
||||
// therefore we wait until it's the case.
|
||||
loop {
|
||||
let mut window_attributes = mem::uninitialized();
|
||||
(display.xlib.XGetWindowAttributes)(display.display, x_window.window, &mut window_attributes);
|
||||
display.check_errors().expect("Failed to call XGetWindowAttributes");
|
||||
|
||||
if window_attributes.map_state == ffi::IsViewable {
|
||||
(display.xlib.XSetInputFocus)(
|
||||
display.display,
|
||||
x_window.window,
|
||||
|
@ -651,6 +658,12 @@ impl Window {
|
|||
ffi::CurrentTime
|
||||
);
|
||||
display.check_errors().expect("Failed to call XSetInputFocus");
|
||||
break;
|
||||
}
|
||||
|
||||
// Wait about a frame to avoid too-busy waiting
|
||||
thread::sleep(Duration::from_millis(16));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue