Struct wgpu::rwh::DisplayHandle

pub struct DisplayHandle<'a> { /* private fields */ }
Expand description

The handle to the display controller of the windowing system.

This is the primary return type of the HasDisplayHandle trait. It is guaranteed to contain a valid platform-specific display handle for its lifetime.

Implementations§

§

impl DisplayHandle<'static>

pub fn android() -> DisplayHandle<'static>

Create an Android-based display handle.

As no data is borrowed by this handle, it is completely safe to create. This function may be useful to windowing framework implementations that want to avoid unsafe code.

Example
let handle = DisplayHandle::android();
do_something(handle);
§

impl DisplayHandle<'static>

pub fn appkit() -> DisplayHandle<'static>

Create an AppKit-based display handle.

As no data is borrowed by this handle, it is completely safe to create. This function may be useful to windowing framework implementations that want to avoid unsafe code.

Example
let handle = DisplayHandle::appkit();
do_something(handle);
§

impl<'a> DisplayHandle<'a>

pub unsafe fn borrow_raw(raw: RawDisplayHandle) -> DisplayHandle<'a>

Create a DisplayHandle from a RawDisplayHandle.

Safety

Users can safely assume that non-null/0 fields are valid handles, and it is up to the implementer of this trait to ensure that condition is upheld.

Despite that qualification, implementors should still make a best-effort attempt to fill in all available fields. If an implementation doesn’t, and a downstream user needs the field, it should try to derive the field from other fields the implementer does provide via whatever methods the platform provides.

It is not possible to invalidate a DisplayHandle on any platform without additional unsafe code.

pub fn as_raw(&self) -> RawDisplayHandle

Get the underlying raw display handle.

§

impl DisplayHandle<'static>

pub fn haiku() -> DisplayHandle<'static>

Create an Haiku-based display handle.

As no data is borrowed by this handle, it is completely safe to create. This function may be useful to windowing framework implementations that want to avoid unsafe code.

Example
let handle = DisplayHandle::haiku();
do_something(handle);
§

impl DisplayHandle<'static>

pub fn orbital() -> DisplayHandle<'static>

Create an Orbital-based display handle.

As no data is borrowed by this handle, it is completely safe to create. This function may be useful to windowing framework implementations that want to avoid unsafe code.

Example
let handle = DisplayHandle::orbital();
do_something(handle);
§

impl DisplayHandle<'static>

pub fn uikit() -> DisplayHandle<'static>

Create a UiKit-based display handle.

As no data is borrowed by this handle, it is completely safe to create. This function may be useful to windowing framework implementations that want to avoid unsafe code.

Example
let handle = DisplayHandle::uikit();
do_something(handle);
§

impl DisplayHandle<'static>

pub fn web() -> DisplayHandle<'static>

Create a Web-based display handle.

As no data is borrowed by this handle, it is completely safe to create. This function may be useful to windowing framework implementations that want to avoid unsafe code.

Example
let handle = DisplayHandle::web();
do_something(handle);
§

impl DisplayHandle<'static>

pub fn windows() -> DisplayHandle<'static>

Create a Windows-based display handle.

As no data is borrowed by this handle, it is completely safe to create. This function may be useful to windowing framework implementations that want to avoid unsafe code.

Example
let handle = DisplayHandle::windows();
do_something(handle);

Trait Implementations§

§

impl AsRef<RawDisplayHandle> for DisplayHandle<'_>

§

fn as_ref(&self) -> &RawDisplayHandle

Converts this type into a shared reference of the (usually inferred) input type.
§

impl Borrow<RawDisplayHandle> for DisplayHandle<'_>

§

fn borrow(&self) -> &RawDisplayHandle

Immutably borrows from an owned value. Read more
§

impl<'a> Clone for DisplayHandle<'a>

§

fn clone(&self) -> DisplayHandle<'a>

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
§

impl Debug for DisplayHandle<'_>

§

fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>

Formats the value using the given formatter. Read more
§

impl From<DisplayHandle<'_>> for RawDisplayHandle

§

fn from(handle: DisplayHandle<'_>) -> RawDisplayHandle

Converts to this type from the input type.
§

impl<'a> HasDisplayHandle for DisplayHandle<'a>

§

fn display_handle(&self) -> Result<DisplayHandle<'_>, HandleError>

Get a handle to the display controller of the windowing system.
§

impl<'a> Hash for DisplayHandle<'a>

§

fn hash<__H>(&self, state: &mut __H)
where __H: Hasher,

Feeds this value into the given Hasher. Read more
1.3.0 · source§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
§

impl<'a> PartialEq for DisplayHandle<'a>

§

fn eq(&self, other: &DisplayHandle<'a>) -> bool

This method tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

impl<'a> Copy for DisplayHandle<'a>

§

impl<'a> Eq for DisplayHandle<'a>

§

impl<'a> StructuralEq for DisplayHandle<'a>

§

impl<'a> StructuralPartialEq for DisplayHandle<'a>

Auto Trait Implementations§

§

impl<'a> RefUnwindSafe for DisplayHandle<'a>

§

impl<'a> !Send for DisplayHandle<'a>

§

impl<'a> !Sync for DisplayHandle<'a>

§

impl<'a> Unpin for DisplayHandle<'a>

§

impl<'a> UnwindSafe for DisplayHandle<'a>

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
§

impl<T> Downcast<T> for T

§

fn downcast(&self) -> &T

§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

§

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. Read more
§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

§

fn equivalent(&self, key: &K) -> bool

Compare self to key and return true if they are equal.
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T> HasRawDisplayHandle for T
where T: HasDisplayHandle + ?Sized,

§

fn raw_display_handle(&self) -> Result<RawDisplayHandle, HandleError>

👎Deprecated: Use HasDisplayHandle instead
source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
§

impl<T> Upcast<T> for T

§

fn upcast(&self) -> Option<&T>