2019-06-25 03:15:34 +02:00
|
|
|
mod canvas;
|
2019-06-25 18:07:47 +02:00
|
|
|
mod event;
|
2019-06-25 03:15:34 +02:00
|
|
|
mod timeout;
|
|
|
|
|
|
|
|
|
|
pub use self::canvas::Canvas;
|
2020-04-11 22:49:07 +03:00
|
|
|
pub use self::timeout::{AnimationFrameRequest, Timeout};
|
2019-06-25 03:15:34 +02:00
|
|
|
|
2019-12-31 14:39:33 -08:00
|
|
|
use crate::dpi::{LogicalSize, Size};
|
2019-06-25 18:07:47 +02:00
|
|
|
use crate::platform::web::WindowExtWebSys;
|
|
|
|
|
use crate::window::Window;
|
2019-09-11 11:47:03 -04:00
|
|
|
use wasm_bindgen::{closure::Closure, JsCast};
|
2019-10-11 11:45:07 -04:00
|
|
|
use web_sys::{window, BeforeUnloadEvent, Element, HtmlCanvasElement};
|
2019-06-25 18:07:47 +02:00
|
|
|
|
2019-06-25 03:15:34 +02:00
|
|
|
pub fn throw(msg: &str) {
|
|
|
|
|
wasm_bindgen::throw_str(msg);
|
|
|
|
|
}
|
2019-06-25 18:07:47 +02:00
|
|
|
|
2019-10-11 11:45:07 -04:00
|
|
|
pub fn exit_fullscreen() {
|
|
|
|
|
let window = web_sys::window().expect("Failed to obtain window");
|
|
|
|
|
let document = window.document().expect("Failed to obtain document");
|
|
|
|
|
|
|
|
|
|
document.exit_fullscreen();
|
|
|
|
|
}
|
|
|
|
|
|
2019-09-11 11:47:03 -04:00
|
|
|
pub fn on_unload(mut handler: impl FnMut() + 'static) {
|
|
|
|
|
let window = web_sys::window().expect("Failed to obtain window");
|
|
|
|
|
|
|
|
|
|
let closure = Closure::wrap(
|
|
|
|
|
Box::new(move |_: BeforeUnloadEvent| handler()) as Box<dyn FnMut(BeforeUnloadEvent)>
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
window
|
|
|
|
|
.add_event_listener_with_callback("beforeunload", &closure.as_ref().unchecked_ref())
|
|
|
|
|
.expect("Failed to add close listener");
|
|
|
|
|
}
|
|
|
|
|
|
2019-06-25 18:07:47 +02:00
|
|
|
impl WindowExtWebSys for Window {
|
|
|
|
|
fn canvas(&self) -> HtmlCanvasElement {
|
|
|
|
|
self.window.canvas().raw().clone()
|
|
|
|
|
}
|
2020-02-17 20:25:27 +01:00
|
|
|
|
|
|
|
|
fn is_dark_mode(&self) -> bool {
|
|
|
|
|
let window = web_sys::window().expect("Failed to obtain window");
|
|
|
|
|
|
|
|
|
|
window
|
|
|
|
|
.match_media("(prefers-color-scheme: dark)")
|
|
|
|
|
.ok()
|
|
|
|
|
.flatten()
|
|
|
|
|
.map(|media| media.matches())
|
|
|
|
|
.unwrap_or(false)
|
|
|
|
|
}
|
2019-06-25 18:07:47 +02:00
|
|
|
}
|
2019-10-11 11:45:07 -04:00
|
|
|
|
2020-01-04 01:33:07 -05:00
|
|
|
pub fn window_size() -> LogicalSize<f64> {
|
2019-10-11 11:45:07 -04:00
|
|
|
let window = web_sys::window().expect("Failed to obtain window");
|
|
|
|
|
let width = window
|
|
|
|
|
.inner_width()
|
|
|
|
|
.expect("Failed to get width")
|
|
|
|
|
.as_f64()
|
|
|
|
|
.expect("Failed to get width as f64");
|
|
|
|
|
let height = window
|
|
|
|
|
.inner_height()
|
|
|
|
|
.expect("Failed to get height")
|
|
|
|
|
.as_f64()
|
|
|
|
|
.expect("Failed to get height as f64");
|
|
|
|
|
|
|
|
|
|
LogicalSize { width, height }
|
|
|
|
|
}
|
|
|
|
|
|
2020-01-03 14:52:27 -05:00
|
|
|
pub fn scale_factor() -> f64 {
|
2019-12-31 14:39:33 -08:00
|
|
|
let window = web_sys::window().expect("Failed to obtain window");
|
|
|
|
|
window.device_pixel_ratio()
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
pub fn set_canvas_size(raw: &HtmlCanvasElement, size: Size) {
|
2020-01-03 14:52:27 -05:00
|
|
|
let scale_factor = scale_factor();
|
2019-12-31 14:39:33 -08:00
|
|
|
|
2020-01-03 14:52:27 -05:00
|
|
|
let physical_size = size.to_physical::<u32>(scale_factor);
|
|
|
|
|
let logical_size = size.to_logical::<f64>(scale_factor);
|
2019-12-31 14:39:33 -08:00
|
|
|
|
|
|
|
|
raw.set_width(physical_size.width);
|
|
|
|
|
raw.set_height(physical_size.height);
|
|
|
|
|
|
2020-08-17 16:48:29 -07:00
|
|
|
set_canvas_style_property(raw, "width", &format!("{}px", logical_size.width));
|
|
|
|
|
set_canvas_style_property(raw, "height", &format!("{}px", logical_size.height));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
pub fn set_canvas_style_property(raw: &HtmlCanvasElement, property: &str, value: &str) {
|
2019-12-31 14:39:33 -08:00
|
|
|
let style = raw.style();
|
|
|
|
|
style
|
2020-08-17 16:48:29 -07:00
|
|
|
.set_property(property, value)
|
|
|
|
|
.expect(&format!("Failed to set {}", property));
|
2019-12-31 14:39:33 -08:00
|
|
|
}
|
|
|
|
|
|
2019-10-11 11:45:07 -04:00
|
|
|
pub fn is_fullscreen(canvas: &HtmlCanvasElement) -> bool {
|
|
|
|
|
let window = window().expect("Failed to obtain window");
|
|
|
|
|
let document = window.document().expect("Failed to obtain document");
|
|
|
|
|
|
|
|
|
|
match document.fullscreen_element() {
|
|
|
|
|
Some(elem) => {
|
|
|
|
|
let raw: Element = canvas.clone().into();
|
|
|
|
|
raw == elem
|
|
|
|
|
}
|
|
|
|
|
None => false,
|
|
|
|
|
}
|
|
|
|
|
}
|
2020-01-15 21:20:14 -05:00
|
|
|
|
|
|
|
|
pub type RawCanvasType = HtmlCanvasElement;
|