From 5730d86d136539d79f50b1e92ba9ec5049196488 Mon Sep 17 00:00:00 2001 From: Arthas <15215604969@163.com> Date: Thu, 16 Nov 2023 13:05:39 +0800 Subject: [PATCH] fix: jira CSD-60920 render issue after (#1110) --- ts/Renderer/RendererManager.ts | 50 +++++++++++++----------------- ts/Renderer/WebGLRenderer/index.ts | 3 +- 2 files changed, 23 insertions(+), 30 deletions(-) diff --git a/ts/Renderer/RendererManager.ts b/ts/Renderer/RendererManager.ts index e737db1d8..fabbedc52 100644 --- a/ts/Renderer/RendererManager.ts +++ b/ts/Renderer/RendererManager.ts @@ -48,7 +48,7 @@ export class RendererManager extends IRendererManager { /** * @ignore */ - renderMode: RENDER_MODE; + renderMode?: RENDER_MODE; /** * @ignore */ @@ -62,9 +62,7 @@ export class RendererManager extends IRendererManager { super(); this.renderFps = 15; this.renderers = new Map(); - this.renderMode = this.checkWebglEnv() - ? RENDER_MODE.WEBGL - : RENDER_MODE.SOFTWARE; + this.setRenderMode(); this.msgBridge = AgoraEnv.AgoraElectronBridge; this.defaultRenderConfig = { rendererOptions: { @@ -83,11 +81,20 @@ export class RendererManager extends IRendererManager { * @returns * 0: Success.< 0: Failure. */ - public setRenderMode(mode: RENDER_MODE) { - this.renderMode = mode; - logInfo( - 'setRenderMode: new render mode will take effect only if new view bind to render' - ); + public setRenderMode(mode?: RENDER_MODE) { + if (mode === undefined) { + this.renderMode = this.checkWebglEnv() + ? RENDER_MODE.WEBGL + : RENDER_MODE.SOFTWARE; + return; + } + + if (mode !== this.renderMode) { + this.renderMode = mode; + logInfo( + 'setRenderMode: new render mode will take effect only if new view bind to render' + ); + } } /** @@ -430,17 +437,6 @@ export class RendererManager extends IRendererManager { } } - /** - * @ignore - */ - private getRender({ - videoSourceType, - channelId, - uid, - }: VideoFrameCacheConfig) { - return this.renderers.get(videoSourceType)?.get(channelId)?.get(uid); - } - /** * @ignore */ @@ -475,18 +471,14 @@ export class RendererManager extends IRendererManager { return filterRenders[0]; } const renderer = this.createRenderer(() => { - const renderConfig = this.getRender(config); - if (!renderConfig) { - return; - } - renderConfig.renders = renders.filter((r) => r !== renderer); - const contentMode = renderer.contentMode; + const { contentMode, mirror } = renderer; renderer.unbind(); - this.setRenderMode(RENDER_MODE.SOFTWARE); + renders.splice(renders.indexOf(renderer), 1); + this.setRenderMode(); const newRender = this.createRenderer(); - newRender.contentMode = contentMode; newRender.bind(view); - renderConfig.renders.push(newRender); + newRender.setRenderOption({ contentMode, mirror }); + renders.push(newRender); }); renderer.bind(view); renders.push(renderer); diff --git a/ts/Renderer/WebGLRenderer/index.ts b/ts/Renderer/WebGLRenderer/index.ts index 91025a12f..3e0552d0d 100644 --- a/ts/Renderer/WebGLRenderer/index.ts +++ b/ts/Renderer/WebGLRenderer/index.ts @@ -453,7 +453,8 @@ export class GlRenderer extends IRenderer { } } - private handleContextLost = () => { + private handleContextLost = (event: Event) => { + console.warn('webglcontextlost', event); try { this.canvas && this.canvas.removeEventListener(