From 1be301497eee18b92ef2f793b7c308b7d5e4b5d7 Mon Sep 17 00:00:00 2001 From: Xiaoji Chen Date: Mon, 9 Dec 2024 08:42:34 -0800 Subject: [PATCH] fix(webgl): Prevent auto resizing when using external gl context (#2296) --- modules/core/src/adapter/canvas-context.ts | 3 ++- modules/webgl/src/adapter/webgl-device.ts | 7 +++++-- 2 files changed, 7 insertions(+), 3 deletions(-) diff --git a/modules/core/src/adapter/canvas-context.ts b/modules/core/src/adapter/canvas-context.ts index 7a1fc9cb4d..c38fcbdcef 100644 --- a/modules/core/src/adapter/canvas-context.ts +++ b/modules/core/src/adapter/canvas-context.ts @@ -198,7 +198,8 @@ export abstract class CanvasContext { // For headless gl we might have used custom width and height // hence use cached clientWidth const [drawingBufferWidth] = this.getDrawingBufferSize(); - const {clientWidth} = this._canvasSizeInfo; + // _canvasSizeInfo may not be populated if `setDevicePixelRatio` is never called + const clientWidth = this._canvasSizeInfo.clientWidth || this.htmlCanvas?.clientWidth; return clientWidth ? drawingBufferWidth / clientWidth : 1; } catch { return 1; diff --git a/modules/webgl/src/adapter/webgl-device.ts b/modules/webgl/src/adapter/webgl-device.ts index fd4aa7ddd8..05d3101722 100644 --- a/modules/webgl/src/adapter/webgl-device.ts +++ b/modules/webgl/src/adapter/webgl-device.ts @@ -203,7 +203,8 @@ ${device.info.vendor}, ${device.info.renderer} for canvas: ${device.canvasContex // Create and instrument context const canvas = props.gl?.canvas || props.canvas; - this.canvasContext = new WebGLCanvasContext(this, {...props, canvas}); + const autoResize = !props.gl; + this.canvasContext = new WebGLCanvasContext(this, {...props, autoResize, canvas}); this.lost = new Promise<{reason: 'destroyed'; message: string}>(resolve => { this._resolveContextLost = resolve; @@ -241,7 +242,9 @@ ${device.info.vendor}, ${device.info.renderer} for canvas: ${device.canvasContex this.features.initializeFeatures(); } - this.canvasContext.resize(); + if (autoResize) { + this.canvasContext.resize(); + } // Install context state tracking // @ts-expect-error - hidden parameters