mirror of
https://github.com/italicsjenga/winit-sonoma-fix.git
synced 2025-01-12 05:31:31 +11:00
Merge pull request #223 from Determinant/xim-send-spot
XIM support for sending spot to IME
This commit is contained in:
commit
2066909845
|
@ -40,6 +40,8 @@ pub trait WindowExt {
|
||||||
|
|
||||||
fn get_xlib_xconnection(&self) -> Option<Arc<XConnection>>;
|
fn get_xlib_xconnection(&self) -> Option<Arc<XConnection>>;
|
||||||
|
|
||||||
|
fn send_xim_spot(&self, x: i16, y: i16);
|
||||||
|
|
||||||
/// This function returns the underlying `xcb_connection_t` of an xlib `Display`.
|
/// This function returns the underlying `xcb_connection_t` of an xlib `Display`.
|
||||||
///
|
///
|
||||||
/// Returns `None` if the window doesn't use xlib (if it uses wayland for example).
|
/// Returns `None` if the window doesn't use xlib (if it uses wayland for example).
|
||||||
|
@ -100,6 +102,12 @@ impl WindowExt for Window {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn send_xim_spot(&self, x: i16, y: i16) {
|
||||||
|
if let LinuxWindow::X(ref w) = self.window {
|
||||||
|
w.send_xim_spot(x, y);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
fn get_wayland_surface(&self) -> Option<*mut libc::c_void> {
|
fn get_wayland_surface(&self) -> Option<*mut libc::c_void> {
|
||||||
use wayland_client::Proxy;
|
use wayland_client::Proxy;
|
||||||
|
|
|
@ -699,6 +699,7 @@ impl Window2 {
|
||||||
x_events_loop.windows.lock().unwrap().insert(win.id(), WindowData {
|
x_events_loop.windows.lock().unwrap().insert(win.id(), WindowData {
|
||||||
im: im,
|
im: im,
|
||||||
ic: ic,
|
ic: ic,
|
||||||
|
ic_spot: ffi::XPoint {x: 0, y: 0},
|
||||||
config: None,
|
config: None,
|
||||||
multitouch: window.multitouch,
|
multitouch: window.multitouch,
|
||||||
cursor_pos: None,
|
cursor_pos: None,
|
||||||
|
@ -715,6 +716,26 @@ impl Window2 {
|
||||||
pub fn id(&self) -> WindowId {
|
pub fn id(&self) -> WindowId {
|
||||||
self.window.id()
|
self.window.id()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[inline]
|
||||||
|
pub fn send_xim_spot(&self, x: i16, y: i16) {
|
||||||
|
if let (Some(windows), Some(display)) = (self.windows.upgrade(), self.display.upgrade()) {
|
||||||
|
let nspot = ffi::XPoint{x: x, y: y};
|
||||||
|
let mut windows = windows.lock().unwrap();
|
||||||
|
let mut w = windows.get_mut(&self.window.id()).unwrap();
|
||||||
|
if w.ic_spot.x == x && w.ic_spot.y == y {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
w.ic_spot = nspot;
|
||||||
|
unsafe {
|
||||||
|
let preedit_attr = (display.xlib.XVaCreateNestedList)
|
||||||
|
(0, b"spotLocation\0", &nspot, ptr::null::<()>());
|
||||||
|
(display.xlib.XSetICValues)(w.ic, b"preeditAttributes\0",
|
||||||
|
preedit_attr, ptr::null::<()>());
|
||||||
|
(display.xlib.XFree)(preedit_attr);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Drop for Window2 {
|
impl Drop for Window2 {
|
||||||
|
@ -736,6 +757,7 @@ struct WindowData {
|
||||||
config: Option<WindowConfig>,
|
config: Option<WindowConfig>,
|
||||||
im: ffi::XIM,
|
im: ffi::XIM,
|
||||||
ic: ffi::XIC,
|
ic: ffi::XIC,
|
||||||
|
ic_spot: ffi::XPoint,
|
||||||
multitouch: bool,
|
multitouch: bool,
|
||||||
cursor_pos: Option<(f64, f64)>,
|
cursor_pos: Option<(f64, f64)>,
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue