raw_window_handle/
android.rs

1use core::ffi::c_void;
2use core::ptr::NonNull;
3
4use super::DisplayHandle;
5
6/// Raw display handle for Android.
7#[non_exhaustive]
8#[derive(Debug, Clone, Copy, PartialEq, Eq, Hash)]
9pub struct AndroidDisplayHandle {}
10
11impl AndroidDisplayHandle {
12    /// Create a new empty display handle.
13    ///
14    ///
15    /// # Example
16    ///
17    /// ```
18    /// # use raw_window_handle::AndroidDisplayHandle;
19    /// let handle = AndroidDisplayHandle::new();
20    /// ```
21    pub fn new() -> Self {
22        Self {}
23    }
24}
25
26impl DisplayHandle<'static> {
27    /// Create an Android-based display handle.
28    ///
29    /// As no data is borrowed by this handle, it is completely safe to create. This function
30    /// may be useful to windowing framework implementations that want to avoid unsafe code.
31    ///
32    /// # Example
33    ///
34    /// ```
35    /// # use raw_window_handle::{DisplayHandle, HasDisplayHandle};
36    /// # fn do_something(rwh: impl HasDisplayHandle) { let _ = rwh; }
37    /// let handle = DisplayHandle::android();
38    /// do_something(handle);
39    /// ```
40    pub fn android() -> Self {
41        // SAFETY: No data is borrowed.
42        unsafe { Self::borrow_raw(AndroidDisplayHandle::new().into()) }
43    }
44}
45
46/// Raw window handle for Android NDK.
47#[non_exhaustive]
48#[derive(Debug, Clone, Copy, PartialEq, Eq, Hash)]
49pub struct AndroidNdkWindowHandle {
50    /// A pointer to an `ANativeWindow`.
51    pub a_native_window: NonNull<c_void>,
52}
53
54impl AndroidNdkWindowHandle {
55    /// Create a new handle to an `ANativeWindow`.
56    ///
57    ///
58    /// # Example
59    ///
60    /// ```
61    /// # use core::ptr::NonNull;
62    /// # use raw_window_handle::AndroidNdkWindowHandle;
63    /// # type ANativeWindow = ();
64    /// #
65    /// let ptr: NonNull<ANativeWindow>;
66    /// # ptr = NonNull::from(&());
67    /// let handle = AndroidNdkWindowHandle::new(ptr.cast());
68    /// ```
69    pub fn new(a_native_window: NonNull<c_void>) -> Self {
70        Self { a_native_window }
71    }
72}