On Web, add WindowBuilderExtWebSys::with_append() (#2953)

This commit is contained in:
daxpedda 2023-07-12 17:11:52 +02:00 committed by GitHub
parent 5b5ebc25d8
commit b63164645b
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
6 changed files with 31 additions and 6 deletions

View file

@ -20,6 +20,7 @@ And please only add new entries to the top of this list, right below the `# Unre
- On Web, fix some `WindowBuilder` methods doing nothing. - On Web, fix some `WindowBuilder` methods doing nothing.
- On Web, implement `Window::focus_window()`. - On Web, implement `Window::focus_window()`.
- On Web, remove unnecessary `Window::is_dark_mode()`, which was replaced with `Window::theme()`. - On Web, remove unnecessary `Window::is_dark_mode()`, which was replaced with `Window::theme()`.
- On Web, add `WindowBuilderExtWebSys::with_append()` to append the canvas element to the web page on creation.
# 0.29.0-beta.0 # 0.29.0-beta.0

View file

@ -10,10 +10,13 @@ use winit::{
pub fn main() { pub fn main() {
let event_loop = EventLoop::new(); let event_loop = EventLoop::new();
let window = WindowBuilder::new() let builder = WindowBuilder::new().with_title("A fantastic window!");
.with_title("A fantastic window!") #[cfg(wasm_platform)]
.build(&event_loop) let builder = {
.unwrap(); use winit::platform::web::WindowBuilderExtWebSys;
builder.with_append(true)
};
let window = builder.build(&event_loop).unwrap();
#[cfg(wasm_platform)] #[cfg(wasm_platform)]
let log_list = wasm::insert_canvas_and_create_log_list(&window); let log_list = wasm::insert_canvas_and_create_log_list(&window);
@ -96,7 +99,6 @@ mod wasm {
// Use to test interactions with border and padding. // Use to test interactions with border and padding.
//style.set_property("border", "50px solid black").unwrap(); //style.set_property("border", "50px solid black").unwrap();
//style.set_property("padding", "50px").unwrap(); //style.set_property("padding", "50px").unwrap();
body.append_child(&canvas).unwrap();
let log_header = document.create_element("h2").unwrap(); let log_header = document.create_element("h2").unwrap();
log_header.set_text_content(Some("Event Log")); log_header.set_text_content(Some("Event Log"));

View file

@ -13,6 +13,7 @@ mod wasm {
dpi::PhysicalSize, dpi::PhysicalSize,
event::{Event, WindowEvent}, event::{Event, WindowEvent},
event_loop::{ControlFlow, EventLoop}, event_loop::{ControlFlow, EventLoop},
platform::web::WindowBuilderExtWebSys,
window::{Window, WindowBuilder}, window::{Window, WindowBuilder},
}; };
@ -37,6 +38,7 @@ This example demonstrates the desired future functionality which will possibly b
// When running in a non-wasm environment this would set the window size to 100x100. // When running in a non-wasm environment this would set the window size to 100x100.
// However in this example it just sets a default initial size of 100x100 that is immediately overwritten due to the layout + styling of the page. // However in this example it just sets a default initial size of 100x100 that is immediately overwritten due to the layout + styling of the page.
.with_inner_size(PhysicalSize::new(100, 100)) .with_inner_size(PhysicalSize::new(100, 100))
.with_append(true)
.build(&event_loop) .build(&event_loop)
.unwrap(); .unwrap();
@ -72,7 +74,6 @@ This example demonstrates the desired future functionality which will possibly b
canvas canvas
.style() .style()
.set_css_text("display: block; background-color: crimson; margin: auto; width: 50%; aspect-ratio: 4 / 1;"); .set_css_text("display: block; background-color: crimson; margin: auto; width: 50%; aspect-ratio: 4 / 1;");
body.append_child(&canvas).unwrap();
let explanation = document.create_element("pre").unwrap(); let explanation = document.create_element("pre").unwrap();
explanation.set_text_content(Some(EXPLANATION)); explanation.set_text_content(Some(EXPLANATION));

View file

@ -66,6 +66,11 @@ pub trait WindowBuilderExtWebSys {
/// ///
/// Enabled by default. /// Enabled by default.
fn with_focusable(self, focusable: bool) -> Self; fn with_focusable(self, focusable: bool) -> Self;
/// On window creation, append the canvas element to the web page if it isn't already.
///
/// Disabled by default.
fn with_append(self, append: bool) -> Self;
} }
impl WindowBuilderExtWebSys for WindowBuilder { impl WindowBuilderExtWebSys for WindowBuilder {
@ -86,6 +91,12 @@ impl WindowBuilderExtWebSys for WindowBuilder {
self self
} }
fn with_append(mut self, append: bool) -> Self {
self.platform_specific.append = append;
self
}
} }
/// Additional methods on `EventLoop` that are specific to the web. /// Additional methods on `EventLoop` that are specific to the web.

View file

@ -70,6 +70,14 @@ impl Canvas {
.unchecked_into(), .unchecked_into(),
}; };
if platform_attr.append && !document.contains(Some(&canvas)) {
document
.body()
.expect("Failed to get body from document")
.append_child(&canvas)
.expect("Failed to append canvas to body");
}
// A tabindex is needed in order to capture local keyboard events. // A tabindex is needed in order to capture local keyboard events.
// A "0" value means that the element should be focusable in // A "0" value means that the element should be focusable in
// sequential keyboard navigation, but its order is defined by the // sequential keyboard navigation, but its order is defined by the

View file

@ -483,6 +483,7 @@ pub struct PlatformSpecificWindowBuilderAttributes {
pub(crate) canvas: Option<backend::RawCanvasType>, pub(crate) canvas: Option<backend::RawCanvasType>,
pub(crate) prevent_default: bool, pub(crate) prevent_default: bool,
pub(crate) focusable: bool, pub(crate) focusable: bool,
pub(crate) append: bool,
} }
impl Default for PlatformSpecificWindowBuilderAttributes { impl Default for PlatformSpecificWindowBuilderAttributes {
@ -491,6 +492,7 @@ impl Default for PlatformSpecificWindowBuilderAttributes {
canvas: None, canvas: None,
prevent_default: true, prevent_default: true,
focusable: true, focusable: true,
append: false,
} }
} }
} }