2018-06-15 09:42:18 +10:00
|
|
|
#![cfg(target_os = "ios")]
|
|
|
|
|
|
|
|
use std::os::raw::c_void;
|
|
|
|
|
2019-06-22 01:33:15 +10:00
|
|
|
use crate::{
|
|
|
|
event_loop::EventLoop,
|
|
|
|
monitor::MonitorHandle,
|
|
|
|
window::{Window, WindowBuilder},
|
|
|
|
};
|
2019-05-26 11:10:41 +10:00
|
|
|
|
|
|
|
/// Additional methods on `EventLoop` that are specific to iOS.
|
|
|
|
pub trait EventLoopExtIOS {
|
|
|
|
/// Returns the idiom (phone/tablet/tv/etc) for the current device.
|
2019-05-30 11:29:54 +10:00
|
|
|
fn idiom(&self) -> Idiom;
|
2019-05-26 11:10:41 +10:00
|
|
|
}
|
|
|
|
|
|
|
|
impl<T: 'static> EventLoopExtIOS for EventLoop<T> {
|
2019-05-30 11:29:54 +10:00
|
|
|
fn idiom(&self) -> Idiom {
|
|
|
|
self.event_loop.idiom()
|
2019-05-26 11:10:41 +10:00
|
|
|
}
|
|
|
|
}
|
2018-06-15 09:42:18 +10:00
|
|
|
|
|
|
|
/// Additional methods on `Window` that are specific to iOS.
|
2019-02-06 02:30:33 +11:00
|
|
|
pub trait WindowExtIOS {
|
2018-06-15 09:42:18 +10:00
|
|
|
/// Returns a pointer to the `UIWindow` that is used by this window.
|
|
|
|
///
|
|
|
|
/// The pointer will become invalid when the `Window` is destroyed.
|
2019-05-30 11:29:54 +10:00
|
|
|
fn ui_window(&self) -> *mut c_void;
|
2018-06-15 09:42:18 +10:00
|
|
|
|
2019-05-26 11:10:41 +10:00
|
|
|
/// Returns a pointer to the `UIViewController` that is used by this window.
|
|
|
|
///
|
|
|
|
/// The pointer will become invalid when the `Window` is destroyed.
|
2019-05-30 11:29:54 +10:00
|
|
|
fn ui_view_controller(&self) -> *mut c_void;
|
2019-05-26 11:10:41 +10:00
|
|
|
|
2018-06-15 09:42:18 +10:00
|
|
|
/// Returns a pointer to the `UIView` that is used by this window.
|
|
|
|
///
|
|
|
|
/// The pointer will become invalid when the `Window` is destroyed.
|
2019-05-30 11:29:54 +10:00
|
|
|
fn ui_view(&self) -> *mut c_void;
|
2019-05-26 11:10:41 +10:00
|
|
|
|
|
|
|
/// Sets the HiDpi factor used by this window.
|
2019-05-30 11:29:54 +10:00
|
|
|
///
|
2019-05-26 11:10:41 +10:00
|
|
|
/// This translates to `-[UIWindow setContentScaleFactor:hidpi_factor]`.
|
|
|
|
fn set_hidpi_factor(&self, hidpi_factor: f64);
|
|
|
|
|
|
|
|
/// Sets the valid orientations for screens showing this `Window`.
|
2019-05-30 11:29:54 +10:00
|
|
|
///
|
2019-05-26 11:10:41 +10:00
|
|
|
/// On iPhones and iPods upside down portrait is never enabled.
|
|
|
|
fn set_valid_orientations(&self, valid_orientations: ValidOrientations);
|
2018-06-15 09:42:18 +10:00
|
|
|
}
|
|
|
|
|
2019-02-06 02:30:33 +11:00
|
|
|
impl WindowExtIOS for Window {
|
2018-06-15 09:42:18 +10:00
|
|
|
#[inline]
|
2019-05-30 11:29:54 +10:00
|
|
|
fn ui_window(&self) -> *mut c_void {
|
|
|
|
self.window.ui_window() as _
|
2018-06-15 09:42:18 +10:00
|
|
|
}
|
|
|
|
|
2019-05-26 11:10:41 +10:00
|
|
|
#[inline]
|
2019-05-30 11:29:54 +10:00
|
|
|
fn ui_view_controller(&self) -> *mut c_void {
|
|
|
|
self.window.ui_view_controller() as _
|
2019-05-26 11:10:41 +10:00
|
|
|
}
|
|
|
|
|
2018-06-15 09:42:18 +10:00
|
|
|
#[inline]
|
2019-05-30 11:29:54 +10:00
|
|
|
fn ui_view(&self) -> *mut c_void {
|
|
|
|
self.window.ui_view() as _
|
2018-06-15 09:42:18 +10:00
|
|
|
}
|
2019-05-26 11:10:41 +10:00
|
|
|
|
|
|
|
#[inline]
|
|
|
|
fn set_hidpi_factor(&self, hidpi_factor: f64) {
|
|
|
|
self.window.set_hidpi_factor(hidpi_factor)
|
|
|
|
}
|
|
|
|
|
|
|
|
#[inline]
|
|
|
|
fn set_valid_orientations(&self, valid_orientations: ValidOrientations) {
|
|
|
|
self.window.set_valid_orientations(valid_orientations)
|
|
|
|
}
|
2018-06-15 09:42:18 +10:00
|
|
|
}
|
|
|
|
|
2018-07-26 04:49:46 +10:00
|
|
|
/// Additional methods on `WindowBuilder` that are specific to iOS.
|
2019-02-06 02:30:33 +11:00
|
|
|
pub trait WindowBuilderExtIOS {
|
2018-07-26 04:49:46 +10:00
|
|
|
/// Sets the root view class used by the `Window`, otherwise a barebones `UIView` is provided.
|
|
|
|
///
|
|
|
|
/// The class will be initialized by calling `[root_view initWithFrame:CGRect]`
|
|
|
|
fn with_root_view_class(self, root_view_class: *const c_void) -> WindowBuilder;
|
2019-05-30 11:29:54 +10:00
|
|
|
|
2019-05-26 11:10:41 +10:00
|
|
|
/// Sets the `contentScaleFactor` of the underlying `UIWindow` to `hidpi_factor`.
|
2019-05-30 11:29:54 +10:00
|
|
|
///
|
2019-05-26 11:10:41 +10:00
|
|
|
/// The default value is device dependent, and it's recommended GLES or Metal applications set
|
2019-05-30 11:29:54 +10:00
|
|
|
/// this to `MonitorHandle::hidpi_factor()`.
|
2019-05-26 11:10:41 +10:00
|
|
|
fn with_hidpi_factor(self, hidpi_factor: f64) -> WindowBuilder;
|
2019-05-30 11:29:54 +10:00
|
|
|
|
2019-05-26 11:10:41 +10:00
|
|
|
/// Sets the valid orientations for the `Window`.
|
|
|
|
fn with_valid_orientations(self, valid_orientations: ValidOrientations) -> WindowBuilder;
|
2018-07-26 04:49:46 +10:00
|
|
|
}
|
|
|
|
|
2019-02-06 02:30:33 +11:00
|
|
|
impl WindowBuilderExtIOS for WindowBuilder {
|
2018-07-26 04:49:46 +10:00
|
|
|
#[inline]
|
|
|
|
fn with_root_view_class(mut self, root_view_class: *const c_void) -> WindowBuilder {
|
|
|
|
self.platform_specific.root_view_class = unsafe { &*(root_view_class as *const _) };
|
|
|
|
self
|
|
|
|
}
|
2019-05-26 11:10:41 +10:00
|
|
|
|
|
|
|
#[inline]
|
|
|
|
fn with_hidpi_factor(mut self, hidpi_factor: f64) -> WindowBuilder {
|
|
|
|
self.platform_specific.hidpi_factor = Some(hidpi_factor);
|
|
|
|
self
|
|
|
|
}
|
|
|
|
|
|
|
|
#[inline]
|
|
|
|
fn with_valid_orientations(mut self, valid_orientations: ValidOrientations) -> WindowBuilder {
|
|
|
|
self.platform_specific.valid_orientations = valid_orientations;
|
|
|
|
self
|
|
|
|
}
|
2018-07-26 04:49:46 +10:00
|
|
|
}
|
|
|
|
|
2019-02-06 02:30:33 +11:00
|
|
|
/// Additional methods on `MonitorHandle` that are specific to iOS.
|
|
|
|
pub trait MonitorHandleExtIOS {
|
2018-06-15 09:42:18 +10:00
|
|
|
/// Returns a pointer to the `UIScreen` that is used by this monitor.
|
2019-05-30 11:29:54 +10:00
|
|
|
fn ui_screen(&self) -> *mut c_void;
|
2018-06-15 09:42:18 +10:00
|
|
|
}
|
|
|
|
|
2019-02-06 02:30:33 +11:00
|
|
|
impl MonitorHandleExtIOS for MonitorHandle {
|
2018-06-15 09:42:18 +10:00
|
|
|
#[inline]
|
2019-05-30 11:29:54 +10:00
|
|
|
fn ui_screen(&self) -> *mut c_void {
|
|
|
|
self.inner.ui_screen() as _
|
2018-06-15 09:42:18 +10:00
|
|
|
}
|
|
|
|
}
|
2019-05-26 11:10:41 +10:00
|
|
|
|
|
|
|
/// Valid orientations for a particular `Window`.
|
|
|
|
#[derive(Clone, Copy, Debug)]
|
|
|
|
pub enum ValidOrientations {
|
|
|
|
/// Excludes `PortraitUpsideDown` on iphone
|
|
|
|
LandscapeAndPortrait,
|
|
|
|
|
|
|
|
Landscape,
|
2019-05-30 11:29:54 +10:00
|
|
|
|
2019-05-26 11:10:41 +10:00
|
|
|
/// Excludes `PortraitUpsideDown` on iphone
|
|
|
|
Portrait,
|
|
|
|
}
|
|
|
|
|
|
|
|
impl Default for ValidOrientations {
|
|
|
|
#[inline]
|
|
|
|
fn default() -> ValidOrientations {
|
|
|
|
ValidOrientations::LandscapeAndPortrait
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/// The device [idiom].
|
2019-05-30 11:29:54 +10:00
|
|
|
///
|
2019-05-26 11:10:41 +10:00
|
|
|
/// [idiom]: https://developer.apple.com/documentation/uikit/uidevice/1620037-userinterfaceidiom?language=objc
|
|
|
|
#[derive(Clone, Copy, Debug, PartialEq, Eq)]
|
|
|
|
pub enum Idiom {
|
|
|
|
Unspecified,
|
|
|
|
|
|
|
|
/// iPhone and iPod touch.
|
|
|
|
Phone,
|
|
|
|
|
|
|
|
/// iPad.
|
|
|
|
Pad,
|
|
|
|
|
|
|
|
/// tvOS and Apple TV.
|
|
|
|
TV,
|
|
|
|
CarPlay,
|
|
|
|
}
|