mirror of
https://github.com/italicsjenga/winit-sonoma-fix.git
synced 2025-01-11 13:31:29 +11:00
Update raw-window-handle to v0.5.0
This updates raw-window-handle to v0.5.0.
This commit is contained in:
parent
3e991e13dc
commit
653bc59813
|
@ -72,6 +72,7 @@ And please only add new entries to the top of this list, right below the `# Unre
|
||||||
- **Breaking**, Replaced `VideoMode::refresh_rate` with `VideoMode::refresh_rate_millihertz` providing better precision.
|
- **Breaking**, Replaced `VideoMode::refresh_rate` with `VideoMode::refresh_rate_millihertz` providing better precision.
|
||||||
- On Web, add `with_prevent_default` and `with_focusable` to `WindowBuilderExtWebSys` to control whether events should be propagated.
|
- On Web, add `with_prevent_default` and `with_focusable` to `WindowBuilderExtWebSys` to control whether events should be propagated.
|
||||||
- On Windows, fix focus events being sent to inactive windows.
|
- On Windows, fix focus events being sent to inactive windows.
|
||||||
|
- **Breaking**, update `raw-window-handle` to `v0.5` and implement `HasRawDisplayHandle` for `Window` and `EventLoopWindowTarget`.
|
||||||
|
|
||||||
# 0.26.1 (2022-01-05)
|
# 0.26.1 (2022-01-05)
|
||||||
|
|
||||||
|
|
|
@ -45,7 +45,7 @@ instant = { version = "0.1", features = ["wasm-bindgen"] }
|
||||||
once_cell = "1.12"
|
once_cell = "1.12"
|
||||||
log = "0.4"
|
log = "0.4"
|
||||||
serde = { version = "1", optional = true, features = ["serde_derive"] }
|
serde = { version = "1", optional = true, features = ["serde_derive"] }
|
||||||
raw-window-handle = "0.4.2"
|
raw-window-handle = "0.5.0"
|
||||||
bitflags = "1"
|
bitflags = "1"
|
||||||
mint = { version = "0.5.6", optional = true }
|
mint = { version = "0.5.6", optional = true }
|
||||||
|
|
||||||
|
@ -55,8 +55,8 @@ simple_logger = "2.1.0"
|
||||||
|
|
||||||
[target.'cfg(target_os = "android")'.dependencies]
|
[target.'cfg(target_os = "android")'.dependencies]
|
||||||
# Coordinate the next winit release with android-ndk-rs: https://github.com/rust-windowing/winit/issues/1995
|
# Coordinate the next winit release with android-ndk-rs: https://github.com/rust-windowing/winit/issues/1995
|
||||||
ndk = { git = "https://github.com/rust-windowing/android-ndk-rs", rev = "a0c5e99" }
|
ndk = { git = "https://github.com/rust-windowing/android-ndk-rs", rev = "814be08" }
|
||||||
ndk-glue = { git = "https://github.com/rust-windowing/android-ndk-rs", rev = "a0c5e99" }
|
ndk-glue = { git = "https://github.com/rust-windowing/android-ndk-rs", rev = "814be08" }
|
||||||
|
|
||||||
[target.'cfg(any(target_os = "ios", target_os = "macos"))'.dependencies]
|
[target.'cfg(any(target_os = "ios", target_os = "macos"))'.dependencies]
|
||||||
objc = "0.2.7"
|
objc = "0.2.7"
|
||||||
|
|
|
@ -13,6 +13,7 @@ use std::{error, fmt};
|
||||||
|
|
||||||
use instant::Instant;
|
use instant::Instant;
|
||||||
use once_cell::sync::OnceCell;
|
use once_cell::sync::OnceCell;
|
||||||
|
use raw_window_handle::{HasRawDisplayHandle, RawDisplayHandle};
|
||||||
|
|
||||||
use crate::{event::Event, monitor::MonitorHandle, platform_impl};
|
use crate::{event::Event, monitor::MonitorHandle, platform_impl};
|
||||||
|
|
||||||
|
@ -337,6 +338,13 @@ impl<T> EventLoopWindowTarget<T> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
unsafe impl<T> HasRawDisplayHandle for EventLoopWindowTarget<T> {
|
||||||
|
/// Returns a [`raw_window_handle::RawDisplayHandle`] for the event loop.
|
||||||
|
fn raw_display_handle(&self) -> RawDisplayHandle {
|
||||||
|
self.p.raw_display_handle()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/// Used to send custom events to [`EventLoop`].
|
/// Used to send custom events to [`EventLoop`].
|
||||||
pub struct EventLoopProxy<T: 'static> {
|
pub struct EventLoopProxy<T: 'static> {
|
||||||
event_loop_proxy: platform_impl::EventLoopProxy<T>,
|
event_loop_proxy: platform_impl::EventLoopProxy<T>,
|
||||||
|
|
|
@ -98,9 +98,9 @@
|
||||||
//! # Drawing on the window
|
//! # Drawing on the window
|
||||||
//!
|
//!
|
||||||
//! Winit doesn't directly provide any methods for drawing on a [`Window`]. However it allows you to
|
//! Winit doesn't directly provide any methods for drawing on a [`Window`]. However it allows you to
|
||||||
//! retrieve the raw handle of the window (see the [`platform`] module and/or the
|
//! retrieve the raw handle of the window and display (see the [`platform`] module and/or the
|
||||||
//! [`raw_window_handle`] method), which in turn allows you to create an
|
//! [`raw_window_handle`] and [`raw_display_handle`] methods), which in turn allows
|
||||||
//! OpenGL/Vulkan/DirectX/Metal/etc. context that can be used to render graphics.
|
//! you to create an OpenGL/Vulkan/DirectX/Metal/etc. context that can be used to render graphics.
|
||||||
//!
|
//!
|
||||||
//! Note that many platforms will display garbage data in the window's client area if the
|
//! Note that many platforms will display garbage data in the window's client area if the
|
||||||
//! application doesn't render anything to the window by the time the desktop compositor is ready to
|
//! application doesn't render anything to the window by the time the desktop compositor is ready to
|
||||||
|
@ -129,6 +129,7 @@
|
||||||
//! [`LoopDestroyed`]: event::Event::LoopDestroyed
|
//! [`LoopDestroyed`]: event::Event::LoopDestroyed
|
||||||
//! [`platform`]: platform
|
//! [`platform`]: platform
|
||||||
//! [`raw_window_handle`]: ./window/struct.Window.html#method.raw_window_handle
|
//! [`raw_window_handle`]: ./window/struct.Window.html#method.raw_window_handle
|
||||||
|
//! [`raw_display_handle`]: ./window/struct.Window.html#method.raw_display_handle
|
||||||
|
|
||||||
#![deny(rust_2018_idioms)]
|
#![deny(rust_2018_idioms)]
|
||||||
#![deny(rustdoc::broken_intra_doc_links)]
|
#![deny(rustdoc::broken_intra_doc_links)]
|
||||||
|
|
|
@ -14,7 +14,9 @@ use ndk::{
|
||||||
};
|
};
|
||||||
use ndk_glue::{Event, LockReadGuard, Rect};
|
use ndk_glue::{Event, LockReadGuard, Rect};
|
||||||
use once_cell::sync::Lazy;
|
use once_cell::sync::Lazy;
|
||||||
use raw_window_handle::{HasRawWindowHandle, RawWindowHandle};
|
use raw_window_handle::{
|
||||||
|
AndroidDisplayHandle, HasRawWindowHandle, RawDisplayHandle, RawWindowHandle,
|
||||||
|
};
|
||||||
|
|
||||||
use crate::{
|
use crate::{
|
||||||
dpi::{PhysicalPosition, PhysicalSize, Position, Size},
|
dpi::{PhysicalPosition, PhysicalSize, Position, Size},
|
||||||
|
@ -645,6 +647,10 @@ impl<T: 'static> EventLoopWindowTarget<T> {
|
||||||
v.push_back(MonitorHandle);
|
v.push_back(MonitorHandle);
|
||||||
v
|
v
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn raw_display_handle(&self) -> RawDisplayHandle {
|
||||||
|
RawDisplayHandle::Android(AndroidDisplayHandle::empty())
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Clone, Copy, Debug, Eq, Hash, Ord, PartialEq, PartialOrd)]
|
#[derive(Clone, Copy, Debug, Eq, Hash, Ord, PartialEq, PartialOrd)]
|
||||||
|
@ -835,6 +841,10 @@ impl Window {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn raw_display_handle(&self) -> RawDisplayHandle {
|
||||||
|
RawDisplayHandle::Android(AndroidDisplayHandle::empty())
|
||||||
|
}
|
||||||
|
|
||||||
pub fn config(&self) -> Configuration {
|
pub fn config(&self) -> Configuration {
|
||||||
CONFIG.read().unwrap().clone()
|
CONFIG.read().unwrap().clone()
|
||||||
}
|
}
|
||||||
|
|
|
@ -7,6 +7,8 @@ use std::{
|
||||||
sync::mpsc::{self, Receiver, Sender},
|
sync::mpsc::{self, Receiver, Sender},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
use raw_window_handle::{RawDisplayHandle, UiKitDisplayHandle};
|
||||||
|
|
||||||
use crate::{
|
use crate::{
|
||||||
dpi::LogicalSize,
|
dpi::LogicalSize,
|
||||||
event::Event,
|
event::Event,
|
||||||
|
@ -63,6 +65,10 @@ impl<T: 'static> EventLoopWindowTarget<T> {
|
||||||
|
|
||||||
Some(RootMonitorHandle { inner: monitor })
|
Some(RootMonitorHandle { inner: monitor })
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn raw_display_handle(&self) -> RawDisplayHandle {
|
||||||
|
RawDisplayHandle::UiKit(UiKitDisplayHandle::empty())
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub struct EventLoop<T: 'static> {
|
pub struct EventLoop<T: 'static> {
|
||||||
|
|
|
@ -1,10 +1,10 @@
|
||||||
use raw_window_handle::{RawWindowHandle, UiKitHandle};
|
|
||||||
use std::{
|
use std::{
|
||||||
collections::VecDeque,
|
collections::VecDeque,
|
||||||
ops::{Deref, DerefMut},
|
ops::{Deref, DerefMut},
|
||||||
};
|
};
|
||||||
|
|
||||||
use objc::runtime::{Class, Object, BOOL, NO, YES};
|
use objc::runtime::{Class, Object, BOOL, NO, YES};
|
||||||
|
use raw_window_handle::{RawDisplayHandle, RawWindowHandle, UiKitDisplayHandle, UiKitWindowHandle};
|
||||||
|
|
||||||
use crate::{
|
use crate::{
|
||||||
dpi::{self, LogicalPosition, LogicalSize, PhysicalPosition, PhysicalSize, Position, Size},
|
dpi::{self, LogicalPosition, LogicalSize, PhysicalPosition, PhysicalSize, Position, Size},
|
||||||
|
@ -332,11 +332,15 @@ impl Inner {
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn raw_window_handle(&self) -> RawWindowHandle {
|
pub fn raw_window_handle(&self) -> RawWindowHandle {
|
||||||
let mut handle = UiKitHandle::empty();
|
let mut window_handle = UiKitWindowHandle::empty();
|
||||||
handle.ui_window = self.window as _;
|
window_handle.ui_window = self.window as _;
|
||||||
handle.ui_view = self.view as _;
|
window_handle.ui_view = self.view as _;
|
||||||
handle.ui_view_controller = self.view_controller as _;
|
window_handle.ui_view_controller = self.view_controller as _;
|
||||||
RawWindowHandle::UiKit(handle)
|
RawWindowHandle::UiKit(window_handle)
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn raw_display_handle(&self) -> RawDisplayHandle {
|
||||||
|
RawDisplayHandle::UiKit(UiKitDisplayHandle::empty())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -20,7 +20,7 @@ use std::{ffi::CStr, mem::MaybeUninit, os::raw::*, sync::Arc};
|
||||||
use once_cell::sync::Lazy;
|
use once_cell::sync::Lazy;
|
||||||
#[cfg(feature = "x11")]
|
#[cfg(feature = "x11")]
|
||||||
use parking_lot::Mutex;
|
use parking_lot::Mutex;
|
||||||
use raw_window_handle::RawWindowHandle;
|
use raw_window_handle::{RawDisplayHandle, RawWindowHandle};
|
||||||
|
|
||||||
#[cfg(feature = "x11")]
|
#[cfg(feature = "x11")]
|
||||||
pub use self::x11::XNotSupported;
|
pub use self::x11::XNotSupported;
|
||||||
|
@ -572,13 +572,14 @@ impl Window {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[inline]
|
||||||
pub fn raw_window_handle(&self) -> RawWindowHandle {
|
pub fn raw_window_handle(&self) -> RawWindowHandle {
|
||||||
match self {
|
x11_or_wayland!(match self; Window(window) => window.raw_window_handle())
|
||||||
#[cfg(feature = "x11")]
|
|
||||||
Window::X(ref window) => RawWindowHandle::Xlib(window.raw_window_handle()),
|
|
||||||
#[cfg(feature = "wayland")]
|
|
||||||
Window::Wayland(ref window) => RawWindowHandle::Wayland(window.raw_window_handle()),
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[inline]
|
||||||
|
pub fn raw_display_handle(&self) -> RawDisplayHandle {
|
||||||
|
x11_or_wayland!(match self; Window(window) => window.raw_display_handle())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -810,6 +811,10 @@ impl<T> EventLoopWindowTarget<T> {
|
||||||
EventLoopWindowTarget::X(ref evlp) => evlp.set_device_event_filter(_filter),
|
EventLoopWindowTarget::X(ref evlp) => evlp.set_device_event_filter(_filter),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn raw_display_handle(&self) -> raw_window_handle::RawDisplayHandle {
|
||||||
|
x11_or_wayland!(match self; Self(evlp) => evlp.raw_display_handle())
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn sticky_exit_callback<T, F>(
|
fn sticky_exit_callback<T, F>(
|
||||||
|
|
|
@ -6,6 +6,8 @@ use std::process;
|
||||||
use std::rc::Rc;
|
use std::rc::Rc;
|
||||||
use std::time::{Duration, Instant};
|
use std::time::{Duration, Instant};
|
||||||
|
|
||||||
|
use raw_window_handle::{RawDisplayHandle, WaylandDisplayHandle};
|
||||||
|
|
||||||
use sctk::reexports::client::protocol::wl_compositor::WlCompositor;
|
use sctk::reexports::client::protocol::wl_compositor::WlCompositor;
|
||||||
use sctk::reexports::client::protocol::wl_shm::WlShm;
|
use sctk::reexports::client::protocol::wl_shm::WlShm;
|
||||||
use sctk::reexports::client::Display;
|
use sctk::reexports::client::Display;
|
||||||
|
@ -71,6 +73,14 @@ pub struct EventLoopWindowTarget<T> {
|
||||||
_marker: std::marker::PhantomData<T>,
|
_marker: std::marker::PhantomData<T>,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
impl<T> EventLoopWindowTarget<T> {
|
||||||
|
pub fn raw_display_handle(&self) -> RawDisplayHandle {
|
||||||
|
let mut display_handle = WaylandDisplayHandle::empty();
|
||||||
|
display_handle.display = self.display.get_display_ptr() as *mut _;
|
||||||
|
RawDisplayHandle::Wayland(display_handle)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
pub struct EventLoop<T: 'static> {
|
pub struct EventLoop<T: 'static> {
|
||||||
/// Event loop.
|
/// Event loop.
|
||||||
event_loop: calloop::EventLoop<'static, WinitState>,
|
event_loop: calloop::EventLoop<'static, WinitState>,
|
||||||
|
|
|
@ -7,7 +7,9 @@ use sctk::reexports::client::Display;
|
||||||
|
|
||||||
use sctk::reexports::calloop;
|
use sctk::reexports::calloop;
|
||||||
|
|
||||||
use raw_window_handle::WaylandHandle;
|
use raw_window_handle::{
|
||||||
|
RawDisplayHandle, RawWindowHandle, WaylandDisplayHandle, WaylandWindowHandle,
|
||||||
|
};
|
||||||
use sctk::window::Decorations;
|
use sctk::window::Decorations;
|
||||||
|
|
||||||
use crate::dpi::{LogicalSize, PhysicalPosition, PhysicalSize, Position, Size};
|
use crate::dpi::{LogicalSize, PhysicalPosition, PhysicalSize, Position, Size};
|
||||||
|
@ -579,11 +581,17 @@ impl Window {
|
||||||
}
|
}
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
pub fn raw_window_handle(&self) -> WaylandHandle {
|
pub fn raw_window_handle(&self) -> RawWindowHandle {
|
||||||
let mut handle = WaylandHandle::empty();
|
let mut window_handle = WaylandWindowHandle::empty();
|
||||||
handle.display = self.display.get_display_ptr() as *mut _;
|
window_handle.surface = self.surface.as_ref().c_ptr() as *mut _;
|
||||||
handle.surface = self.surface.as_ref().c_ptr() as *mut _;
|
RawWindowHandle::Wayland(window_handle)
|
||||||
handle
|
}
|
||||||
|
|
||||||
|
#[inline]
|
||||||
|
pub fn raw_display_handle(&self) -> RawDisplayHandle {
|
||||||
|
let mut display_handle = WaylandDisplayHandle::empty();
|
||||||
|
display_handle.display = self.display.get_display_ptr() as *mut _;
|
||||||
|
RawDisplayHandle::Wayland(display_handle)
|
||||||
}
|
}
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
|
|
|
@ -40,6 +40,7 @@ use std::{
|
||||||
use libc::{self, setlocale, LC_CTYPE};
|
use libc::{self, setlocale, LC_CTYPE};
|
||||||
|
|
||||||
use mio::{unix::SourceFd, Events, Interest, Poll, Token, Waker};
|
use mio::{unix::SourceFd, Events, Interest, Poll, Token, Waker};
|
||||||
|
use raw_window_handle::{RawDisplayHandle, XlibDisplayHandle};
|
||||||
|
|
||||||
use self::{
|
use self::{
|
||||||
dnd::{Dnd, DndState},
|
dnd::{Dnd, DndState},
|
||||||
|
@ -558,6 +559,14 @@ impl<T> EventLoopWindowTarget<T> {
|
||||||
.select_xinput_events(self.root, ffi::XIAllMasterDevices, mask)
|
.select_xinput_events(self.root, ffi::XIAllMasterDevices, mask)
|
||||||
.queue();
|
.queue();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn raw_display_handle(&self) -> raw_window_handle::RawDisplayHandle {
|
||||||
|
let mut display_handle = XlibDisplayHandle::empty();
|
||||||
|
display_handle.display = self.xconn.display as *mut _;
|
||||||
|
display_handle.screen =
|
||||||
|
unsafe { (self.xconn.xlib.XDefaultScreen)(self.xconn.display as *mut _) };
|
||||||
|
RawDisplayHandle::Xlib(display_handle)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<T: 'static> EventLoopProxy<T> {
|
impl<T: 'static> EventLoopProxy<T> {
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
use raw_window_handle::XlibHandle;
|
|
||||||
use std::{
|
use std::{
|
||||||
cmp, env,
|
cmp, env,
|
||||||
ffi::CString,
|
ffi::CString,
|
||||||
|
@ -8,10 +7,11 @@ use std::{
|
||||||
ptr, slice,
|
ptr, slice,
|
||||||
sync::Arc,
|
sync::Arc,
|
||||||
};
|
};
|
||||||
use x11_dl::xlib::TrueColor;
|
|
||||||
|
|
||||||
use libc;
|
use libc;
|
||||||
use parking_lot::Mutex;
|
use parking_lot::Mutex;
|
||||||
|
use raw_window_handle::{RawDisplayHandle, RawWindowHandle, XlibDisplayHandle, XlibWindowHandle};
|
||||||
|
use x11_dl::xlib::TrueColor;
|
||||||
|
|
||||||
use crate::{
|
use crate::{
|
||||||
dpi::{PhysicalPosition, PhysicalSize, Position, Size},
|
dpi::{PhysicalPosition, PhysicalSize, Position, Size},
|
||||||
|
@ -1509,10 +1509,17 @@ impl UnownedWindow {
|
||||||
}
|
}
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
pub fn raw_window_handle(&self) -> XlibHandle {
|
pub fn raw_window_handle(&self) -> RawWindowHandle {
|
||||||
let mut handle = XlibHandle::empty();
|
let mut window_handle = XlibWindowHandle::empty();
|
||||||
handle.window = self.xlib_window();
|
window_handle.window = self.xlib_window();
|
||||||
handle.display = self.xlib_display();
|
RawWindowHandle::Xlib(window_handle)
|
||||||
handle
|
}
|
||||||
|
|
||||||
|
#[inline]
|
||||||
|
pub fn raw_display_handle(&self) -> RawDisplayHandle {
|
||||||
|
let mut display_handle = XlibDisplayHandle::empty();
|
||||||
|
display_handle.display = self.xlib_display();
|
||||||
|
display_handle.screen = self.screen_id;
|
||||||
|
RawDisplayHandle::Xlib(display_handle)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,6 +17,7 @@ use cocoa::{
|
||||||
foundation::{NSInteger, NSPoint, NSTimeInterval},
|
foundation::{NSInteger, NSPoint, NSTimeInterval},
|
||||||
};
|
};
|
||||||
use objc::rc::autoreleasepool;
|
use objc::rc::autoreleasepool;
|
||||||
|
use raw_window_handle::{AppKitDisplayHandle, RawDisplayHandle};
|
||||||
|
|
||||||
use crate::{
|
use crate::{
|
||||||
event::Event,
|
event::Event,
|
||||||
|
@ -87,6 +88,11 @@ impl<T: 'static> EventLoopWindowTarget<T> {
|
||||||
let monitor = monitor::primary_monitor();
|
let monitor = monitor::primary_monitor();
|
||||||
Some(RootMonitorHandle { inner: monitor })
|
Some(RootMonitorHandle { inner: monitor })
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[inline]
|
||||||
|
pub fn raw_display_handle(&self) -> RawDisplayHandle {
|
||||||
|
RawDisplayHandle::AppKit(AppKitDisplayHandle::empty())
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<T> EventLoopWindowTarget<T> {
|
impl<T> EventLoopWindowTarget<T> {
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
use raw_window_handle::{AppKitHandle, RawWindowHandle};
|
|
||||||
use std::{
|
use std::{
|
||||||
collections::VecDeque,
|
collections::VecDeque,
|
||||||
convert::TryInto,
|
convert::TryInto,
|
||||||
|
@ -10,6 +9,10 @@ use std::{
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
use raw_window_handle::{
|
||||||
|
AppKitDisplayHandle, AppKitWindowHandle, RawDisplayHandle, RawWindowHandle,
|
||||||
|
};
|
||||||
|
|
||||||
use crate::{
|
use crate::{
|
||||||
dpi::{
|
dpi::{
|
||||||
LogicalPosition, LogicalSize, PhysicalPosition, PhysicalSize, Position, Size, Size::Logical,
|
LogicalPosition, LogicalSize, PhysicalPosition, PhysicalSize, Position, Size, Size::Logical,
|
||||||
|
@ -1144,10 +1147,15 @@ impl UnownedWindow {
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
pub fn raw_window_handle(&self) -> RawWindowHandle {
|
pub fn raw_window_handle(&self) -> RawWindowHandle {
|
||||||
let mut handle = AppKitHandle::empty();
|
let mut window_handle = AppKitWindowHandle::empty();
|
||||||
handle.ns_window = *self.ns_window as *mut _;
|
window_handle.ns_window = *self.ns_window as *mut _;
|
||||||
handle.ns_view = *self.ns_view as *mut _;
|
window_handle.ns_view = *self.ns_view as *mut _;
|
||||||
RawWindowHandle::AppKit(handle)
|
RawWindowHandle::AppKit(window_handle)
|
||||||
|
}
|
||||||
|
|
||||||
|
#[inline]
|
||||||
|
pub fn raw_display_handle(&self) -> RawDisplayHandle {
|
||||||
|
RawDisplayHandle::AppKit(AppKitDisplayHandle::empty())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,3 +1,10 @@
|
||||||
|
use std::cell::RefCell;
|
||||||
|
use std::clone::Clone;
|
||||||
|
use std::collections::{vec_deque::IntoIter as VecDequeIter, VecDeque};
|
||||||
|
use std::rc::Rc;
|
||||||
|
|
||||||
|
use raw_window_handle::{RawDisplayHandle, WebDisplayHandle};
|
||||||
|
|
||||||
use super::{
|
use super::{
|
||||||
super::monitor::MonitorHandle, backend, device::DeviceId, proxy::EventLoopProxy, runner,
|
super::monitor::MonitorHandle, backend, device::DeviceId, proxy::EventLoopProxy, runner,
|
||||||
window::WindowId,
|
window::WindowId,
|
||||||
|
@ -10,10 +17,6 @@ use crate::event::{
|
||||||
use crate::event_loop::ControlFlow;
|
use crate::event_loop::ControlFlow;
|
||||||
use crate::monitor::MonitorHandle as RootMH;
|
use crate::monitor::MonitorHandle as RootMH;
|
||||||
use crate::window::{Theme, WindowId as RootWindowId};
|
use crate::window::{Theme, WindowId as RootWindowId};
|
||||||
use std::cell::RefCell;
|
|
||||||
use std::clone::Clone;
|
|
||||||
use std::collections::{vec_deque::IntoIter as VecDequeIter, VecDeque};
|
|
||||||
use std::rc::Rc;
|
|
||||||
|
|
||||||
pub struct EventLoopWindowTarget<T: 'static> {
|
pub struct EventLoopWindowTarget<T: 'static> {
|
||||||
pub(crate) runner: runner::Shared<T>,
|
pub(crate) runner: runner::Shared<T>,
|
||||||
|
@ -279,4 +282,8 @@ impl<T> EventLoopWindowTarget<T> {
|
||||||
inner: MonitorHandle,
|
inner: MonitorHandle,
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn raw_display_handle(&self) -> RawDisplayHandle {
|
||||||
|
RawDisplayHandle::Web(WebDisplayHandle::empty())
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -7,7 +7,7 @@ use crate::window::{
|
||||||
CursorGrabMode, CursorIcon, Fullscreen, UserAttentionType, WindowAttributes, WindowId as RootWI,
|
CursorGrabMode, CursorIcon, Fullscreen, UserAttentionType, WindowAttributes, WindowId as RootWI,
|
||||||
};
|
};
|
||||||
|
|
||||||
use raw_window_handle::{RawWindowHandle, WebHandle};
|
use raw_window_handle::{RawDisplayHandle, RawWindowHandle, WebDisplayHandle, WebWindowHandle};
|
||||||
|
|
||||||
use super::{backend, monitor::MonitorHandle, EventLoopWindowTarget};
|
use super::{backend, monitor::MonitorHandle, EventLoopWindowTarget};
|
||||||
|
|
||||||
|
@ -359,9 +359,14 @@ impl Window {
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
pub fn raw_window_handle(&self) -> RawWindowHandle {
|
pub fn raw_window_handle(&self) -> RawWindowHandle {
|
||||||
let mut handle = WebHandle::empty();
|
let mut window_handle = WebWindowHandle::empty();
|
||||||
handle.id = self.id.0;
|
window_handle.id = self.id.0;
|
||||||
RawWindowHandle::Web(handle)
|
RawWindowHandle::Web(window_handle)
|
||||||
|
}
|
||||||
|
|
||||||
|
#[inline]
|
||||||
|
pub fn raw_display_handle(&self) -> RawDisplayHandle {
|
||||||
|
RawDisplayHandle::Web(WebDisplayHandle::empty())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -2,8 +2,6 @@
|
||||||
|
|
||||||
mod runner;
|
mod runner;
|
||||||
|
|
||||||
use once_cell::sync::Lazy;
|
|
||||||
use parking_lot::Mutex;
|
|
||||||
use std::{
|
use std::{
|
||||||
cell::Cell,
|
cell::Cell,
|
||||||
collections::VecDeque,
|
collections::VecDeque,
|
||||||
|
@ -19,6 +17,10 @@ use std::{
|
||||||
time::{Duration, Instant},
|
time::{Duration, Instant},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
use once_cell::sync::Lazy;
|
||||||
|
use parking_lot::Mutex;
|
||||||
|
use raw_window_handle::{RawDisplayHandle, WindowsDisplayHandle};
|
||||||
|
|
||||||
use windows_sys::Win32::{
|
use windows_sys::Win32::{
|
||||||
Devices::HumanInterfaceDevice::MOUSE_MOVE_RELATIVE,
|
Devices::HumanInterfaceDevice::MOUSE_MOVE_RELATIVE,
|
||||||
Foundation::{BOOL, HANDLE, HWND, LPARAM, LRESULT, POINT, RECT, WAIT_TIMEOUT, WPARAM},
|
Foundation::{BOOL, HANDLE, HWND, LPARAM, LRESULT, POINT, RECT, WAIT_TIMEOUT, WPARAM},
|
||||||
|
@ -314,6 +316,10 @@ impl<T> EventLoopWindowTarget<T> {
|
||||||
let monitor = monitor::primary_monitor();
|
let monitor = monitor::primary_monitor();
|
||||||
Some(RootMonitorHandle { inner: monitor })
|
Some(RootMonitorHandle { inner: monitor })
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn raw_display_handle(&self) -> RawDisplayHandle {
|
||||||
|
RawDisplayHandle::Windows(WindowsDisplayHandle::empty())
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Returns the id of the main thread.
|
/// Returns the id of the main thread.
|
||||||
|
|
|
@ -1,7 +1,9 @@
|
||||||
#![cfg(target_os = "windows")]
|
#![cfg(target_os = "windows")]
|
||||||
|
|
||||||
use parking_lot::Mutex;
|
use parking_lot::Mutex;
|
||||||
use raw_window_handle::{RawWindowHandle, Win32Handle};
|
use raw_window_handle::{
|
||||||
|
RawDisplayHandle, RawWindowHandle, Win32WindowHandle, WindowsDisplayHandle,
|
||||||
|
};
|
||||||
use std::{
|
use std::{
|
||||||
cell::Cell,
|
cell::Cell,
|
||||||
ffi::c_void,
|
ffi::c_void,
|
||||||
|
@ -260,10 +262,15 @@ impl Window {
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
pub fn raw_window_handle(&self) -> RawWindowHandle {
|
pub fn raw_window_handle(&self) -> RawWindowHandle {
|
||||||
let mut handle = Win32Handle::empty();
|
let mut window_handle = Win32WindowHandle::empty();
|
||||||
handle.hwnd = self.window.0 as *mut _;
|
window_handle.hwnd = self.window.0 as *mut _;
|
||||||
handle.hinstance = self.hinstance() as *mut _;
|
window_handle.hinstance = self.hinstance() as *mut _;
|
||||||
RawWindowHandle::Win32(handle)
|
RawWindowHandle::Win32(window_handle)
|
||||||
|
}
|
||||||
|
|
||||||
|
#[inline]
|
||||||
|
pub fn raw_display_handle(&self) -> RawDisplayHandle {
|
||||||
|
RawDisplayHandle::Windows(WindowsDisplayHandle::empty())
|
||||||
}
|
}
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
|
|
|
@ -1,6 +1,10 @@
|
||||||
//! The [`Window`] struct and associated types.
|
//! The [`Window`] struct and associated types.
|
||||||
use std::fmt;
|
use std::fmt;
|
||||||
|
|
||||||
|
use raw_window_handle::{
|
||||||
|
HasRawDisplayHandle, HasRawWindowHandle, RawDisplayHandle, RawWindowHandle,
|
||||||
|
};
|
||||||
|
|
||||||
use crate::{
|
use crate::{
|
||||||
dpi::{PhysicalPosition, PhysicalSize, Position, Size},
|
dpi::{PhysicalPosition, PhysicalSize, Position, Size},
|
||||||
error::{ExternalError, NotSupportedError, OsError},
|
error::{ExternalError, NotSupportedError, OsError},
|
||||||
|
@ -1032,8 +1036,7 @@ impl Window {
|
||||||
self.window.primary_monitor()
|
self.window.primary_monitor()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
unsafe impl HasRawWindowHandle for Window {
|
||||||
unsafe impl raw_window_handle::HasRawWindowHandle for Window {
|
|
||||||
/// Returns a [`raw_window_handle::RawWindowHandle`] for the Window
|
/// Returns a [`raw_window_handle::RawWindowHandle`] for the Window
|
||||||
///
|
///
|
||||||
/// ## Platform-specific
|
/// ## Platform-specific
|
||||||
|
@ -1049,11 +1052,21 @@ unsafe impl raw_window_handle::HasRawWindowHandle for Window {
|
||||||
///
|
///
|
||||||
/// [`Event::Resumed`]: crate::event::Event::Resumed
|
/// [`Event::Resumed`]: crate::event::Event::Resumed
|
||||||
/// [`Event::Suspended`]: crate::event::Event::Suspended
|
/// [`Event::Suspended`]: crate::event::Event::Suspended
|
||||||
fn raw_window_handle(&self) -> raw_window_handle::RawWindowHandle {
|
fn raw_window_handle(&self) -> RawWindowHandle {
|
||||||
self.window.raw_window_handle()
|
self.window.raw_window_handle()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
unsafe impl HasRawDisplayHandle for Window {
|
||||||
|
/// Returns a [`raw_window_handle::RawDisplayHandle`] used by the [`EventLoop`] that
|
||||||
|
/// created a window.
|
||||||
|
///
|
||||||
|
/// [`EventLoop`]: crate::event_loop::EventLoop
|
||||||
|
fn raw_display_handle(&self) -> RawDisplayHandle {
|
||||||
|
self.window.raw_display_handle()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/// The behavior of cursor grabbing.
|
/// The behavior of cursor grabbing.
|
||||||
///
|
///
|
||||||
/// Use this enum with [`Window::set_cursor_grab`] to grab the cursor.
|
/// Use this enum with [`Window::set_cursor_grab`] to grab the cursor.
|
||||||
|
|
Loading…
Reference in a new issue