From bcd294adf6f7dd970ea87969cbea67fd19087bcd Mon Sep 17 00:00:00 2001 From: Dave Pagurek Date: Wed, 20 Sep 2023 16:02:34 -0400 Subject: [PATCH] Fix clear() on framebuffers on Intel macs --- src/webgl/p5.RendererGL.js | 17 ++++++++++++++++- 1 file changed, 16 insertions(+), 1 deletion(-) diff --git a/src/webgl/p5.RendererGL.js b/src/webgl/p5.RendererGL.js index e163d93c32..9a293f8079 100644 --- a/src/webgl/p5.RendererGL.js +++ b/src/webgl/p5.RendererGL.js @@ -1310,7 +1310,22 @@ p5.RendererGL = class RendererGL extends p5.Renderer { const _r = args[0] || 0; const _g = args[1] || 0; const _b = args[2] || 0; - const _a = args[3] || 0; + let _a = args[3] || 0; + + const activeFramebuffer = this.activeFramebuffer(); + if ( + activeFramebuffer && + activeFramebuffer.format === constants.UNSIGNED_BYTE && + !activeFramebuffer.antialias && + _a === 0 + ) { + // Drivers on Intel Macs check for 0,0,0,0 exactly when drawing to a + // framebuffer and ignore the command if it's the only drawing command to + // the framebuffer. To work around it, we can set the alpha to a value so + // low that it still rounds down to 0, but that circumvents the buggy + // check in the driver. + _a = 1e-10; + } this.GL.clearColor(_r * _a, _g * _a, _b * _a, _a); this.GL.clearDepth(1);