From 8e719c3bd985812fb9e4039255f669bcf389924a Mon Sep 17 00:00:00 2001 From: ienaga Date: Wed, 15 Feb 2023 00:29:54 +0900 Subject: [PATCH] =?UTF-8?q?#21=20OffscreenCanvas=E3=81=AE=E5=AE=9F?= =?UTF-8?q?=E8=A3=85(WIP)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/renderer/RenderBase.js | 25 +++++++++++++++---------- 1 file changed, 15 insertions(+), 10 deletions(-) diff --git a/src/renderer/RenderBase.js b/src/renderer/RenderBase.js index a6833d52..d341409b 100644 --- a/src/renderer/RenderBase.js +++ b/src/renderer/RenderBase.js @@ -46,6 +46,10 @@ class CommandController // update $devicePixelRatio = devicePixelRatio; + const player = Util.$renderPlayer; + player._$samples = samples; + player._$canvas = canvas; + const gl = canvas.getContext("webgl2", { "stencil": true, "premultipliedAlpha": true, @@ -54,13 +58,11 @@ class CommandController "preserveDrawingBuffer": true }); - const player = Util.$renderPlayer; - player._$samples = samples; - player._$canvas = canvas; - - const context = new CanvasToWebGLContext(gl, samples); - player._$context = context; - player._$cacheStore._$context = context; + if (gl) { + const context = new CanvasToWebGLContext(gl, samples); + player._$context = context; + player._$cacheStore._$context = context; + } } /** @@ -74,13 +76,16 @@ class CommandController */ setBackgroundColor (background_color = null) { - const player = Util.$renderPlayer; + const context = Util.$renderPlayer._$context; + if (!context) { + return ; + } if (!background_color || background_color === "transparent" ) { - player._$context._$setColor(0, 0, 0, 0); + context._$setColor(0, 0, 0, 0); } else { @@ -88,7 +93,7 @@ class CommandController Util.$toColorInt(background_color) ); - player._$context._$setColor( + context._$setColor( color.R / 255, color.G / 255, color.B / 255,