Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

OffscreenCanvas Support for WebGL Backend #2603

Merged
Show file tree
Hide file tree
Changes from 7 commits
Commits
Show all changes
21 commits
Select commit Hold shift + click to select a range
416b38b
First attempt of exposing create_surface_from_canvas for webgl
haraldreingruber-dedalus Apr 15, 2022
7696677
Test Fix Compile For WebGL Offscreen Canvas
zicklag Apr 16, 2022
3ed5422
Only specify web-sys feature version in wgpu-core, so that patch vers…
haraldreingruber-dedalus Apr 17, 2022
9527f08
Reuse already existing fn create_surface_from_canvas
haraldreingruber-dedalus Apr 17, 2022
fa8c64a
Remove unnecessary unsafe
haraldreingruber-dedalus Apr 17, 2022
d273a67
Remove unsafe prefix also from top-level create_surface_from_canvas
haraldreingruber-dedalus Apr 17, 2022
807d45f
Add create_surface_from_offscreen_canvas() for webgl
haraldreingruber-dedalus Apr 17, 2022
7d70ed1
Cargo fmt
haraldreingruber-dedalus Apr 18, 2022
48a3c54
Store webgl2_context instead of canvas, which works also for Offscree…
haraldreingruber-dedalus Apr 18, 2022
f083cd1
Copy skybox example for OffscreenCanvas example
haraldreingruber-dedalus Apr 21, 2022
b089cd2
Use offscreen_canvas instead in newly created example
haraldreingruber-dedalus Apr 22, 2022
1846bec
Update skypbox_offscreen readme.md
haraldreingruber-dedalus Apr 23, 2022
d7083da
Allow enabling OffscreenCanvas in examples via http://localhost:8000/…
haraldreingruber-dedalus May 3, 2022
eb8bbf9
Merge branch 'master' into feature/webgl_offscreen_canvas
haraldreingruber-dedalus May 31, 2022
0426f86
Fix cargo fmt
haraldreingruber-dedalus Jun 4, 2022
2464909
[fix warning] Only import FromStr for wasm32
haraldreingruber-dedalus Jun 4, 2022
2553e1a
[fix warning] Exclude offscreen_canvas_setup from non-wasm32
haraldreingruber-dedalus Jun 4, 2022
fd2cbdc
[fix warning] Add ImageBitmap feature as well so that all related met…
haraldreingruber-dedalus Jun 4, 2022
c2cba40
Fix cargo fmt
haraldreingruber-dedalus Jun 4, 2022
158c416
Fix emscripten build
haraldreingruber-dedalus Jun 6, 2022
95ca719
Remove `webgl` feature from wgpu-core as webgl is the only wasm32 bac…
haraldreingruber-dedalus Jun 6, 2022
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
53 changes: 27 additions & 26 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 2 additions & 0 deletions wgpu-core/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,7 @@ replay = ["serde", "wgt/replay", "arrayvec/serde", "naga/deserialize"]
serial-pass = ["serde", "wgt/serde", "arrayvec/serde"]
id32 = []
vulkan-portability = ["hal/vulkan"]
webgl = ["web-sys"]
cwfitzgerald marked this conversation as resolved.
Show resolved Hide resolved

[dependencies]
arrayvec = "0.7"
Expand Down Expand Up @@ -56,6 +57,7 @@ version = "0.12"

[target.'cfg(target_arch = "wasm32")'.dependencies]
hal = { path = "../wgpu-hal", package = "wgpu-hal", version = "0.12", features = ["gles"] }
web-sys = { version = "0.3", features = ["HtmlCanvasElement"], optional = true }
cwfitzgerald marked this conversation as resolved.
Show resolved Hide resolved

[target.'cfg(all(not(target_arch = "wasm32"), any(target_os = "ios", target_os = "macos")))'.dependencies]
hal = { path = "../wgpu-hal", package = "wgpu-hal", version = "0.12", features = ["metal"] }
Expand Down
46 changes: 46 additions & 0 deletions wgpu-core/src/instance.rs
Original file line number Diff line number Diff line change
Expand Up @@ -493,6 +493,52 @@ impl<G: GlobalIdentityHandlerFactory> Global<G> {
id.0
}

#[cfg(all(target_arch = "wasm32", feature = "webgl"))]
pub fn create_surface_webgl_canvas(
&self,
canvas: &web_sys::HtmlCanvasElement,
id_in: Input<G, SurfaceId>,
) -> SurfaceId {
profiling::scope!("create_surface_webgl_canvas", "Instance");

let surface = Surface {
presentation: None,
gl: self.instance.gl.as_ref().map(|inst| HalSurface {
raw: {
inst.create_surface_from_canvas(canvas)
.expect("Create surface from canvas")
},
}),
};

let mut token = Token::root();
let id = self.surfaces.prepare(id_in).assign(surface, &mut token);
id.0
}

#[cfg(all(target_arch = "wasm32", feature = "webgl"))]
pub fn create_surface_webgl_offscreen_canvas(
&self,
canvas: &web_sys::OffscreenCanvas,
id_in: Input<G, SurfaceId>,
) -> SurfaceId {
profiling::scope!("create_surface_webgl_offscreen_canvas", "Instance");

let surface = Surface {
presentation: None,
gl: self.instance.gl.as_ref().map(|inst| HalSurface {
raw: {
inst.create_surface_from_offscreen_canvas(canvas)
.expect("Create surface from offscreen canvas")
},
}),
};

let mut token = Token::root();
let id = self.surfaces.prepare(id_in).assign(surface, &mut token);
id.0
}

#[cfg(dx12)]
pub unsafe fn instance_create_surface_from_visual(
&self,
Expand Down
42 changes: 33 additions & 9 deletions wgpu-hal/src/gles/web.rs
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,38 @@ pub struct Instance {
canvas: Mutex<Option<web_sys::HtmlCanvasElement>>,
}

impl Instance {
pub fn create_surface_from_canvas(
&self,
canvas: &web_sys::HtmlCanvasElement,
) -> Result<Surface, crate::InstanceError> {
*self.canvas.lock() = Some(canvas.clone());

Ok(Surface {
canvas: canvas.clone(),
present_program: None,
swapchain: None,
texture: None,
presentable: true,
})
}

pub fn create_surface_from_offscreen_canvas(
&self,
canvas: &web_sys::OffscreenCanvas,
) -> Result<Surface, crate::InstanceError> {
*self.canvas.lock() = Some(canvas.clone());
haraldreingruber-dedalus marked this conversation as resolved.
Show resolved Hide resolved

Ok(Surface {
canvas: canvas.clone(),
present_program: None,
swapchain: None,
texture: None,
presentable: true,
})
}
}

// SAFE: WASM doesn't have threads
unsafe impl Sync for Instance {}
unsafe impl Send for Instance {}
Expand Down Expand Up @@ -79,15 +111,7 @@ impl crate::Instance<super::Api> for Instance {
.dyn_into()
.expect("Failed to downcast to canvas type");

*self.canvas.lock() = Some(canvas.clone());

Ok(Surface {
canvas,
present_program: None,
swapchain: None,
texture: None,
presentable: true,
})
self.create_surface_from_canvas(&canvas)
} else {
unreachable!()
}
Expand Down
2 changes: 1 addition & 1 deletion wgpu/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -83,7 +83,7 @@ glsl = ["naga/glsl-in"]
trace = ["serde", "wgc/trace"]
replay = ["serde", "wgc/replay"]
angle = ["wgc/angle"]
webgl = ["wgc"]
webgl = ["wgc", "wgc/webgl"]
emscripten = ["webgl"]
vulkan-portability = ["wgc/vulkan-portability"]

Expand Down
24 changes: 24 additions & 0 deletions wgpu/src/backend/direct.rs
Original file line number Diff line number Diff line change
Expand Up @@ -163,6 +163,30 @@ impl Context {
}
}

#[cfg(all(target_arch = "wasm32", feature = "webgl"))]
pub fn instance_create_surface_from_canvas(
self: &Arc<Self>,
canvas: &web_sys::HtmlCanvasElement,
) -> Surface {
let id = self.0.create_surface_webgl_canvas(canvas, PhantomData);
haraldreingruber-dedalus marked this conversation as resolved.
Show resolved Hide resolved
Surface {
id,
configured_device: Mutex::default(),
}
}

#[cfg(all(target_arch = "wasm32", feature = "webgl"))]
pub fn instance_create_surface_from_offscreen_canvas(
self: &Arc<Self>,
canvas: &web_sys::OffscreenCanvas,
) -> Surface {
let id = self.0.create_surface_webgl_offscreen_canvas(canvas, PhantomData);
Surface {
id,
configured_device: Mutex::default(),
}
}

#[cfg(target_os = "windows")]
pub unsafe fn create_surface_from_visual(
self: &Arc<Self>,
Expand Down
8 changes: 4 additions & 4 deletions wgpu/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1531,8 +1531,8 @@ impl Instance {
/// # Safety
///
/// - canvas must be a valid <canvas> element to create a surface upon.
#[cfg(all(target_arch = "wasm32", not(feature = "webgl")))]
pub unsafe fn create_surface_from_canvas(
#[cfg(target_arch = "wasm32")]
pub fn create_surface_from_canvas(
&self,
canvas: &web_sys::HtmlCanvasElement,
) -> Surface {
Expand All @@ -1547,8 +1547,8 @@ impl Instance {
/// # Safety
///
/// - canvas must be a valid OffscreenCanvas to create a surface upon.
#[cfg(all(target_arch = "wasm32", not(feature = "webgl")))]
pub unsafe fn create_surface_from_offscreen_canvas(
#[cfg(target_arch = "wasm32")]
pub fn create_surface_from_offscreen_canvas(
&self,
canvas: &web_sys::OffscreenCanvas,
) -> Surface {
Expand Down