mirror of
https://github.com/italicsjenga/winit-sonoma-fix.git
synced 2025-01-12 05:31:31 +11:00
Implement some more functions for wayland.
- set/get_inner_size() - set_title
This commit is contained in:
parent
1278d9779d
commit
40322a2c69
|
@ -50,15 +50,15 @@ kernel32-sys = "0.1"
|
||||||
|
|
||||||
[target.i686-unknown-linux-gnu.dependencies]
|
[target.i686-unknown-linux-gnu.dependencies]
|
||||||
osmesa-sys = "0.0.5"
|
osmesa-sys = "0.0.5"
|
||||||
wayland-client = "0.1.4"
|
wayland-client = "0.1.5"
|
||||||
x11-dl = "=1.0.1"
|
x11-dl = "=1.0.1"
|
||||||
|
|
||||||
[target.x86_64-unknown-linux-gnu.dependencies]
|
[target.x86_64-unknown-linux-gnu.dependencies]
|
||||||
osmesa-sys = "0.0.5"
|
osmesa-sys = "0.0.5"
|
||||||
wayland-client = "0.1.4"
|
wayland-client = "0.1.5"
|
||||||
x11-dl = "=1.0.1"
|
x11-dl = "=1.0.1"
|
||||||
|
|
||||||
[target.arm-unknown-linux-gnueabihf.dependencies]
|
[target.arm-unknown-linux-gnueabihf.dependencies]
|
||||||
osmesa-sys = "0.0.5"
|
osmesa-sys = "0.0.5"
|
||||||
wayland-client = "0.1.4"
|
wayland-client = "0.1.5"
|
||||||
x11-dl = "=1.0.1"
|
x11-dl = "=1.0.1"
|
||||||
|
|
|
@ -157,10 +157,6 @@ pub struct Window {
|
||||||
pub context: EglContext,
|
pub context: EglContext,
|
||||||
}
|
}
|
||||||
|
|
||||||
// It is okay, as the window is completely self-owned: it has its
|
|
||||||
// own wayland connexion.
|
|
||||||
unsafe impl Send for Window {}
|
|
||||||
|
|
||||||
#[derive(Clone)]
|
#[derive(Clone)]
|
||||||
pub struct WindowProxy;
|
pub struct WindowProxy;
|
||||||
|
|
||||||
|
@ -300,16 +296,21 @@ impl Window {
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn is_closed(&self) -> bool {
|
pub fn is_closed(&self) -> bool {
|
||||||
|
// TODO
|
||||||
false
|
false
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn set_title(&self, title: &str) {
|
pub fn set_title(&self, title: &str) {
|
||||||
|
let ctitle = CString::new(title).unwrap();
|
||||||
|
self.shell_surface.set_title(&ctitle);
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn show(&self) {
|
pub fn show(&self) {
|
||||||
|
// TODO
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn hide(&self) {
|
pub fn hide(&self) {
|
||||||
|
// TODO
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn get_position(&self) -> Option<(i32, i32)> {
|
pub fn get_position(&self) -> Option<(i32, i32)> {
|
||||||
|
@ -322,15 +323,18 @@ impl Window {
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn get_inner_size(&self) -> Option<(u32, u32)> {
|
pub fn get_inner_size(&self) -> Option<(u32, u32)> {
|
||||||
unimplemented!()
|
let (w, h) = self.shell_surface.get_attached_size();
|
||||||
|
Some((w as u32, h as u32))
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn get_outer_size(&self) -> Option<(u32, u32)> {
|
pub fn get_outer_size(&self) -> Option<(u32, u32)> {
|
||||||
unimplemented!()
|
// maybe available if we draw the border ourselves ?
|
||||||
|
// but for now, no.
|
||||||
|
None
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn set_inner_size(&self, _x: u32, _y: u32) {
|
pub fn set_inner_size(&self, x: u32, y: u32) {
|
||||||
unimplemented!()
|
self.shell_surface.resize(x as i32, y as i32, 0, 0)
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn create_window_proxy(&self) -> WindowProxy {
|
pub fn create_window_proxy(&self) -> WindowProxy {
|
||||||
|
@ -349,13 +353,24 @@ impl Window {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn set_window_resize_callback(&mut self, _: Option<fn(u32, u32)>) {
|
pub fn set_window_resize_callback(&mut self, callback: Option<fn(u32, u32)>) {
|
||||||
|
if let Some(callback) = callback {
|
||||||
|
self.shell_surface.set_configure_callback(
|
||||||
|
move |_,w,h| { callback(w as u32, h as u32) }
|
||||||
|
);
|
||||||
|
} else {
|
||||||
|
self.shell_surface.set_configure_callback(
|
||||||
|
move |_,_,_| {}
|
||||||
|
);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn set_cursor(&self, cursor: MouseCursor) {
|
pub fn set_cursor(&self, cursor: MouseCursor) {
|
||||||
|
// TODO
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn set_cursor_state(&self, state: CursorState) -> Result<(), String> {
|
pub fn set_cursor_state(&self, state: CursorState) -> Result<(), String> {
|
||||||
|
// TODO
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -364,6 +379,7 @@ impl Window {
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn set_cursor_position(&self, x: i32, y: i32) -> Result<(), ()> {
|
pub fn set_cursor_position(&self, x: i32, y: i32) -> Result<(), ()> {
|
||||||
|
// TODO
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue