From c48740a7be2b98847ca419838c56d45900c0b756 Mon Sep 17 00:00:00 2001 From: daxpedda Date: Fri, 26 Jul 2024 15:59:17 +0200 Subject: [PATCH] Android: remove `MonitorHandle` support Because we don't want to force all methods on `VideoModeHandle` to return `Option`, we decided to remove the already incomplete support in Android for both types. --- src/changelog/unreleased.md | 1 + src/platform_impl/android/mod.rs | 75 ++++++++++++-------------------- 2 files changed, 28 insertions(+), 48 deletions(-) diff --git a/src/changelog/unreleased.md b/src/changelog/unreleased.md index 59c3de36a2..7a051b22c0 100644 --- a/src/changelog/unreleased.md +++ b/src/changelog/unreleased.md @@ -106,6 +106,7 @@ changelog entry. - On Web, remove unused `platform::web::CustomCursorError::Animation`. - Remove `MonitorHandle::size()` and `refresh_rate_millihertz()` in favor of `MonitorHandle::current_video_mode()`. +- On Android, remove all `MonitorHandle` support instead of emitting false data. ### Fixed diff --git a/src/platform_impl/android/mod.rs b/src/platform_impl/android/mod.rs index d0cdd07b26..12ee91adc0 100644 --- a/src/platform_impl/android/mod.rs +++ b/src/platform_impl/android/mod.rs @@ -1,5 +1,4 @@ use std::cell::Cell; -use std::collections::VecDeque; use std::hash::Hash; use std::marker::PhantomData; use std::num::{NonZeroU16, NonZeroU32}; @@ -200,9 +199,8 @@ impl EventLoop { app.window_event(self.window_target(), window_id, event); }, MainEvent::ConfigChanged { .. } => { - let monitor = MonitorHandle::new(self.android_app.clone()); - let old_scale_factor = monitor.scale_factor(); - let scale_factor = monitor.scale_factor(); + let old_scale_factor = scale_factor(&self.android_app); + let scale_factor = scale_factor(&self.android_app); if (scale_factor - old_scale_factor).abs() < f64::EPSILON { let new_inner_size = Arc::new(Mutex::new(screen_size(&self.android_app))); let window_id = window::WindowId(WindowId); @@ -587,7 +585,7 @@ impl ActiveEventLoop { } pub fn primary_monitor(&self) -> Option { - Some(MonitorHandle::new(self.app.clone())) + None } pub fn create_custom_cursor(&self, source: CustomCursorSource) -> CustomCursor { @@ -595,10 +593,8 @@ impl ActiveEventLoop { CustomCursor { inner: PlatformCustomCursor } } - pub fn available_monitors(&self) -> VecDeque { - let mut v = VecDeque::with_capacity(1); - v.push_back(MonitorHandle::new(self.app.clone())); - v + pub fn available_monitors(&self) -> Option { + None } #[inline] @@ -723,21 +719,19 @@ impl Window { } pub fn primary_monitor(&self) -> Option { - Some(MonitorHandle::new(self.app.clone())) + None } - pub fn available_monitors(&self) -> VecDeque { - let mut v = VecDeque::with_capacity(1); - v.push_back(MonitorHandle::new(self.app.clone())); - v + pub fn available_monitors(&self) -> Option { + None } pub fn current_monitor(&self) -> Option { - Some(MonitorHandle::new(self.app.clone())) + None } pub fn scale_factor(&self) -> f64 { - MonitorHandle::new(self.app.clone()).scale_factor() + scale_factor(&self.app) } pub fn request_redraw(&self) { @@ -971,68 +965,49 @@ impl Display for OsError { } } -#[derive(Clone, Debug, PartialEq, Eq, Hash)] -pub struct MonitorHandle { - app: AndroidApp, -} -impl PartialOrd for MonitorHandle { - fn partial_cmp(&self, other: &Self) -> Option { - Some(self.cmp(other)) - } -} -impl Ord for MonitorHandle { - fn cmp(&self, _other: &Self) -> std::cmp::Ordering { - std::cmp::Ordering::Equal - } -} +#[derive(Clone, Debug, PartialEq, Eq, PartialOrd, Ord, Hash)] +pub struct MonitorHandle; impl MonitorHandle { - pub(crate) fn new(app: AndroidApp) -> Self { - Self { app } - } - pub fn name(&self) -> Option { - Some("Android Device".to_owned()) + unreachable!() } pub fn position(&self) -> Option> { - None + unreachable!() } pub fn scale_factor(&self) -> f64 { - self.app.config().density().map(|dpi| dpi as f64 / 160.0).unwrap_or(1.0) + unreachable!() } pub fn current_video_mode(&self) -> Option { - Some(VideoModeHandle { size: screen_size(&self.app), monitor: self.clone() }) + unreachable!() } - pub fn video_modes(&self) -> impl Iterator { - self.current_video_mode().into_iter() + pub fn video_modes(&self) -> std::iter::Empty { + unreachable!() } } #[derive(Clone, Debug, Eq, Hash, PartialEq)] -pub struct VideoModeHandle { - size: PhysicalSize, - monitor: MonitorHandle, -} +pub struct VideoModeHandle; impl VideoModeHandle { pub fn size(&self) -> PhysicalSize { - self.size + unreachable!() } pub fn bit_depth(&self) -> Option { - None + unreachable!() } pub fn refresh_rate_millihertz(&self) -> Option { - None + unreachable!() } pub fn monitor(&self) -> MonitorHandle { - self.monitor.clone() + unreachable!() } } @@ -1043,3 +1018,7 @@ fn screen_size(app: &AndroidApp) -> PhysicalSize { PhysicalSize::new(0, 0) } } + +fn scale_factor(app: &AndroidApp) -> f64 { + app.config().density().map(|dpi| dpi as f64 / 160.0).unwrap_or(1.0) +}