1 | use core::ffi::c_void; |
2 | use core::ptr::NonNull; |
3 | |
4 | use super::DisplayHandle; |
5 | |
6 | /// Raw display handle for Android. |
7 | #[non_exhaustive ] |
8 | #[derive (Debug, Clone, Copy, PartialEq, Eq, Hash)] |
9 | pub struct AndroidDisplayHandle {} |
10 | |
11 | impl 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 | |
26 | impl 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)] |
49 | pub struct AndroidNdkWindowHandle { |
50 | /// A pointer to an `ANativeWindow`. |
51 | pub a_native_window: NonNull<c_void>, |
52 | } |
53 | |
54 | impl 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 | } |
73 | |