@lightningjs/renderer 3.0.0-beta9 → 3.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +202 -202
- package/NOTICE +3 -3
- package/README.md +230 -147
- package/dist/exports/canvas.d.ts +1 -1
- package/dist/exports/canvas.js +1 -1
- package/dist/exports/canvas.js.map +1 -1
- package/dist/exports/index.d.ts +5 -6
- package/dist/exports/index.js +3 -5
- package/dist/exports/index.js.map +1 -1
- package/dist/exports/platform.d.ts +7 -0
- package/dist/exports/platform.js +27 -0
- package/dist/exports/platform.js.map +1 -0
- package/dist/exports/webgl.d.ts +2 -1
- package/dist/exports/webgl.js +2 -1
- package/dist/exports/webgl.js.map +1 -1
- package/dist/src/common/CommonTypes.d.ts +15 -3
- package/dist/src/core/AutosizeManager.d.ts +29 -0
- package/dist/src/core/AutosizeManager.js +169 -0
- package/dist/src/core/AutosizeManager.js.map +1 -0
- package/dist/src/core/Autosizer.d.ts +35 -0
- package/dist/src/core/Autosizer.js +196 -0
- package/dist/src/core/Autosizer.js.map +1 -0
- package/dist/src/core/CoreNode.d.ts +106 -58
- package/dist/src/core/CoreNode.js +524 -282
- package/dist/src/core/CoreNode.js.map +1 -1
- package/dist/src/core/CoreTextNode.d.ts +73 -88
- package/dist/src/core/CoreTextNode.js +375 -236
- package/dist/src/core/CoreTextNode.js.map +1 -1
- package/dist/src/core/CoreTextureManager.d.ts +19 -17
- package/dist/src/core/CoreTextureManager.js +52 -120
- package/dist/src/core/CoreTextureManager.js.map +1 -1
- package/dist/src/core/Stage.d.ts +63 -9
- package/dist/src/core/Stage.js +233 -133
- package/dist/src/core/Stage.js.map +1 -1
- package/dist/src/core/TextureError.d.ts +11 -0
- package/dist/src/core/TextureError.js +37 -0
- package/dist/src/core/TextureError.js.map +1 -0
- package/dist/src/core/TextureMemoryManager.d.ts +2 -4
- package/dist/src/core/TextureMemoryManager.js +80 -113
- package/dist/src/core/TextureMemoryManager.js.map +1 -1
- package/dist/src/core/animations/Animation.d.ts +21 -0
- package/dist/src/core/animations/Animation.js +194 -0
- package/dist/src/core/animations/Animation.js.map +1 -0
- package/dist/src/core/animations/CoreAnimation.d.ts +3 -3
- package/dist/src/core/animations/CoreAnimation.js +3 -3
- package/dist/src/core/animations/CoreAnimation.js.map +1 -1
- package/dist/src/core/animations/CoreAnimationController.d.ts +1 -1
- package/dist/src/core/animations/CoreAnimationController.js +4 -2
- package/dist/src/core/animations/CoreAnimationController.js.map +1 -1
- package/dist/src/core/animations/Playback.d.ts +64 -0
- package/dist/src/core/animations/Playback.js +169 -0
- package/dist/src/core/animations/Playback.js.map +1 -0
- package/dist/src/core/animations/Transition.d.ts +27 -0
- package/dist/src/core/animations/Transition.js +52 -0
- package/dist/src/core/animations/Transition.js.map +1 -0
- package/dist/src/core/animations/utils.d.ts +2 -0
- package/dist/src/core/animations/utils.js +136 -0
- package/dist/src/core/animations/utils.js.map +1 -0
- package/dist/src/core/lib/ImageWorker.d.ts +2 -2
- package/dist/src/core/lib/ImageWorker.js +30 -11
- package/dist/src/core/lib/ImageWorker.js.map +1 -1
- package/dist/src/core/lib/WebGlContextWrapper.d.ts +22 -1
- package/dist/src/core/lib/WebGlContextWrapper.js +49 -3
- package/dist/src/core/lib/WebGlContextWrapper.js.map +1 -1
- package/dist/src/core/lib/collectionUtils.d.ts +4 -0
- package/dist/src/core/lib/collectionUtils.js +72 -0
- package/dist/src/core/lib/collectionUtils.js.map +1 -0
- package/dist/src/core/lib/colorCache.d.ts +1 -0
- package/dist/src/core/lib/colorCache.js +19 -0
- package/dist/src/core/lib/colorCache.js.map +1 -0
- package/dist/src/core/lib/colorParser.d.ts +21 -0
- package/dist/src/core/lib/colorParser.js +72 -0
- package/dist/src/core/lib/colorParser.js.map +1 -0
- package/dist/src/core/lib/textureCompression.d.ts +14 -2
- package/dist/src/core/lib/textureCompression.js +320 -67
- package/dist/src/core/lib/textureCompression.js.map +1 -1
- package/dist/src/core/lib/utils.d.ts +6 -6
- package/dist/src/core/lib/utils.js +21 -65
- package/dist/src/core/lib/utils.js.map +1 -1
- package/dist/src/core/platform.d.ts +10 -0
- package/dist/src/core/platform.js +81 -0
- package/dist/src/core/platform.js.map +1 -0
- package/dist/src/core/platforms/GlContextWrapper.d.ts +136 -0
- package/{src/core/text-rendering/TextRenderingUtils.ts → dist/src/core/platforms/GlContextWrapper.js} +32 -36
- package/dist/src/core/platforms/GlContextWrapper.js.map +1 -0
- package/dist/src/core/platforms/Platform.d.ts +78 -12
- package/dist/src/core/platforms/Platform.js +18 -0
- package/dist/src/core/platforms/Platform.js.map +1 -1
- package/dist/src/core/platforms/web/WebGlContextWrapper.d.ts +776 -0
- package/dist/src/core/platforms/web/WebGlContextWrapper.js +1208 -0
- package/dist/src/core/platforms/web/WebGlContextWrapper.js.map +1 -0
- package/dist/src/core/platforms/web/WebPlatform.d.ts +17 -2
- package/dist/src/core/platforms/web/WebPlatform.js +158 -13
- package/dist/src/core/platforms/web/WebPlatform.js.map +1 -1
- package/dist/src/core/platforms/web/WebPlatformChrome50.d.ts +19 -0
- package/dist/src/core/platforms/web/WebPlatformChrome50.js +54 -0
- package/dist/src/core/platforms/web/WebPlatformChrome50.js.map +1 -0
- package/dist/src/core/platforms/web/WebPlatformLegacy.d.ts +20 -0
- package/dist/src/core/platforms/web/WebPlatformLegacy.js +105 -0
- package/dist/src/core/platforms/web/WebPlatformLegacy.js.map +1 -0
- package/dist/src/core/platforms/web/WebPlatformNext.d.ts +21 -0
- package/dist/src/core/platforms/web/WebPlatformNext.js +52 -0
- package/dist/src/core/platforms/web/WebPlatformNext.js.map +1 -0
- package/dist/src/core/platforms/web/lib/ImageWorker.d.ts +21 -0
- package/dist/src/core/platforms/web/lib/ImageWorker.js +136 -0
- package/dist/src/core/platforms/web/lib/ImageWorker.js.map +1 -0
- package/dist/src/core/platforms/web/lib/ImageWorkerDefault.d.ts +6 -0
- package/dist/src/core/platforms/web/lib/ImageWorkerDefault.js +92 -0
- package/dist/src/core/platforms/web/lib/ImageWorkerDefault.js.map +1 -0
- package/dist/src/core/platforms/web/lib/ImageWorkerLegacy.d.ts +1 -0
- package/dist/src/core/platforms/web/lib/ImageWorkerLegacy.js +63 -0
- package/dist/src/core/platforms/web/lib/ImageWorkerLegacy.js.map +1 -0
- package/dist/src/core/platforms/web/lib/ImageWorkerNoOptions.d.ts +7 -0
- package/dist/src/core/platforms/web/lib/ImageWorkerNoOptions.js +75 -0
- package/dist/src/core/platforms/web/lib/ImageWorkerNoOptions.js.map +1 -0
- package/dist/src/core/platforms/web/lib/createImageBitmap.d.ts +1 -0
- package/dist/src/core/platforms/web/lib/createImageBitmap.js +27 -0
- package/dist/src/core/platforms/web/lib/createImageBitmap.js.map +1 -0
- package/dist/src/core/platforms/web/lib/textureCompression.d.ts +26 -0
- package/dist/src/core/platforms/web/lib/textureCompression.js +301 -0
- package/dist/src/core/platforms/web/lib/textureCompression.js.map +1 -0
- package/dist/src/core/platforms/web/lib/textureSvg.d.ts +7 -0
- package/dist/src/core/platforms/web/lib/textureSvg.js +51 -0
- package/dist/src/core/platforms/web/lib/textureSvg.js.map +1 -0
- package/dist/src/core/platforms/web/lib/utils.d.ts +5 -0
- package/dist/src/core/platforms/web/lib/utils.js +86 -0
- package/dist/src/core/platforms/web/lib/utils.js.map +1 -0
- package/dist/src/core/renderers/CoreContextTexture.d.ts +2 -1
- package/dist/src/core/renderers/CoreContextTexture.js.map +1 -1
- package/dist/src/core/renderers/CoreRenderer.d.ts +4 -40
- package/dist/src/core/renderers/CoreRenderer.js +3 -4
- package/dist/src/core/renderers/CoreRenderer.js.map +1 -1
- package/dist/src/core/renderers/CoreShader.d.ts +9 -0
- package/{src/core/text-rendering/renderers/SdfTextRenderer/internal/constants.ts → dist/src/core/renderers/CoreShader.js} +28 -32
- package/dist/src/core/renderers/CoreShader.js.map +1 -0
- package/dist/src/core/renderers/CoreShaderNode.d.ts +10 -0
- package/dist/src/core/renderers/CoreShaderNode.js +19 -2
- package/dist/src/core/renderers/CoreShaderNode.js.map +1 -1
- package/dist/src/core/renderers/canvas/CanvasCoreRenderer.d.ts +33 -0
- package/dist/src/core/renderers/canvas/CanvasCoreRenderer.js +250 -0
- package/dist/src/core/renderers/canvas/CanvasCoreRenderer.js.map +1 -0
- package/dist/src/core/renderers/canvas/CanvasCoreTexture.d.ts +17 -0
- package/dist/src/core/renderers/canvas/CanvasCoreTexture.js +125 -0
- package/dist/src/core/renderers/canvas/CanvasCoreTexture.js.map +1 -0
- package/dist/src/core/renderers/canvas/CanvasRenderer.d.ts +5 -6
- package/dist/src/core/renderers/canvas/CanvasRenderer.js +67 -91
- package/dist/src/core/renderers/canvas/CanvasRenderer.js.map +1 -1
- package/dist/src/core/renderers/canvas/CanvasShaderNode.d.ts +1 -2
- package/dist/src/core/renderers/canvas/CanvasShaderNode.js +5 -4
- package/dist/src/core/renderers/canvas/CanvasShaderNode.js.map +1 -1
- package/dist/src/core/renderers/canvas/CanvasTexture.d.ts +3 -2
- package/dist/src/core/renderers/canvas/CanvasTexture.js +17 -13
- package/dist/src/core/renderers/canvas/CanvasTexture.js.map +1 -1
- package/dist/src/core/renderers/canvas/internal/C2DShaderUtils.d.ts +13 -0
- package/dist/src/core/renderers/canvas/internal/C2DShaderUtils.js +113 -192
- package/dist/src/core/renderers/canvas/internal/C2DShaderUtils.js.map +1 -1
- package/dist/src/core/renderers/canvas/internal/ColorUtils.d.ts +0 -2
- package/dist/src/core/renderers/canvas/internal/ColorUtils.js +0 -14
- package/dist/src/core/renderers/canvas/internal/ColorUtils.js.map +1 -1
- package/dist/src/core/renderers/canvas/shaders/UnsupportedShader.d.ts +10 -0
- package/{src/core/text-rendering/renderers/SdfTextRenderer/internal/util.ts → dist/src/core/renderers/canvas/shaders/UnsupportedShader.js} +43 -40
- package/dist/src/core/renderers/canvas/shaders/UnsupportedShader.js.map +1 -0
- package/dist/src/core/renderers/webgl/SdfRenderOp.d.ts +33 -0
- package/dist/src/core/renderers/webgl/SdfRenderOp.js +98 -0
- package/dist/src/core/renderers/webgl/SdfRenderOp.js.map +1 -0
- package/dist/src/core/renderers/webgl/WebGlCoreCtxRenderTexture.d.ts +12 -0
- package/dist/src/core/renderers/webgl/WebGlCoreCtxRenderTexture.js +58 -0
- package/dist/src/core/renderers/webgl/WebGlCoreCtxRenderTexture.js.map +1 -0
- package/dist/src/core/renderers/webgl/WebGlCoreCtxSubTexture.d.ts +9 -0
- package/dist/src/core/renderers/webgl/WebGlCoreCtxSubTexture.js +38 -0
- package/dist/src/core/renderers/webgl/WebGlCoreCtxSubTexture.js.map +1 -0
- package/dist/src/core/renderers/webgl/WebGlCoreCtxTexture.d.ts +69 -0
- package/dist/src/core/renderers/webgl/WebGlCoreCtxTexture.js +272 -0
- package/dist/src/core/renderers/webgl/WebGlCoreCtxTexture.js.map +1 -0
- package/dist/src/core/renderers/webgl/WebGlCoreRenderOp.d.ts +34 -0
- package/dist/src/core/renderers/webgl/WebGlCoreRenderOp.js +114 -0
- package/dist/src/core/renderers/webgl/WebGlCoreRenderOp.js.map +1 -0
- package/dist/src/core/renderers/webgl/WebGlCoreRenderer.d.ts +133 -0
- package/dist/src/core/renderers/webgl/WebGlCoreRenderer.js +649 -0
- package/dist/src/core/renderers/webgl/WebGlCoreRenderer.js.map +1 -0
- package/dist/src/core/renderers/webgl/WebGlCoreShader.d.ts +78 -0
- package/dist/src/core/renderers/webgl/WebGlCoreShader.js +202 -0
- package/dist/src/core/renderers/webgl/WebGlCoreShader.js.map +1 -0
- package/dist/src/core/renderers/webgl/WebGlCtxRenderTexture.d.ts +4 -2
- package/dist/src/core/renderers/webgl/WebGlCtxRenderTexture.js +14 -6
- package/dist/src/core/renderers/webgl/WebGlCtxRenderTexture.js.map +1 -1
- package/dist/src/core/renderers/webgl/WebGlCtxSubTexture.d.ts +15 -2
- package/dist/src/core/renderers/webgl/WebGlCtxSubTexture.js +34 -5
- package/dist/src/core/renderers/webgl/WebGlCtxSubTexture.js.map +1 -1
- package/dist/src/core/renderers/webgl/WebGlCtxTexture.d.ts +19 -9
- package/dist/src/core/renderers/webgl/WebGlCtxTexture.js +101 -49
- package/dist/src/core/renderers/webgl/WebGlCtxTexture.js.map +1 -1
- package/dist/src/core/renderers/webgl/WebGlRenderOp.d.ts +3 -2
- package/dist/src/core/renderers/webgl/WebGlRenderOp.js +14 -5
- package/dist/src/core/renderers/webgl/WebGlRenderOp.js.map +1 -1
- package/dist/src/core/renderers/webgl/WebGlRenderer.d.ts +11 -23
- package/dist/src/core/renderers/webgl/WebGlRenderer.js +122 -133
- package/dist/src/core/renderers/webgl/WebGlRenderer.js.map +1 -1
- package/dist/src/core/renderers/webgl/WebGlShaderNode.d.ts +4 -6
- package/dist/src/core/renderers/webgl/WebGlShaderNode.js +3 -3
- package/dist/src/core/renderers/webgl/WebGlShaderNode.js.map +1 -1
- package/dist/src/core/renderers/webgl/WebGlShaderProgram.d.ts +7 -7
- package/dist/src/core/renderers/webgl/WebGlShaderProgram.js +56 -37
- package/dist/src/core/renderers/webgl/WebGlShaderProgram.js.map +1 -1
- package/dist/src/core/renderers/webgl/internal/RendererUtils.d.ts +4 -4
- package/dist/src/core/renderers/webgl/internal/RendererUtils.js.map +1 -1
- package/dist/src/core/renderers/webgl/internal/ShaderUtils.d.ts +3 -3
- package/dist/src/core/renderers/webgl/internal/ShaderUtils.js +38 -37
- package/dist/src/core/renderers/webgl/internal/ShaderUtils.js.map +1 -1
- package/dist/src/core/renderers/webgl/shaders/DefaultShader.d.ts +9 -0
- package/dist/src/core/renderers/webgl/shaders/DefaultShader.js +84 -0
- package/dist/src/core/renderers/webgl/shaders/DefaultShader.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/DefaultShaderBatched.d.ts +10 -0
- package/dist/src/core/renderers/webgl/shaders/DefaultShaderBatched.js +108 -0
- package/dist/src/core/renderers/webgl/shaders/DefaultShaderBatched.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/DynamicShader.d.ts +29 -0
- package/dist/src/core/renderers/webgl/shaders/DynamicShader.js +408 -0
- package/dist/src/core/renderers/webgl/shaders/DynamicShader.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/RoundedRectangle.d.ts +28 -0
- package/dist/src/core/renderers/webgl/shaders/RoundedRectangle.js +126 -0
- package/dist/src/core/renderers/webgl/shaders/RoundedRectangle.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/SdfShader.d.ts +47 -0
- package/dist/src/core/renderers/webgl/shaders/SdfShader.js +148 -0
- package/dist/src/core/renderers/webgl/shaders/SdfShader.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/effects/BorderBottomEffect.d.ts +31 -0
- package/dist/src/core/renderers/webgl/shaders/effects/BorderBottomEffect.js +71 -0
- package/dist/src/core/renderers/webgl/shaders/effects/BorderBottomEffect.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/effects/BorderEffect.d.ts +30 -0
- package/dist/src/core/renderers/webgl/shaders/effects/BorderEffect.js +58 -0
- package/dist/src/core/renderers/webgl/shaders/effects/BorderEffect.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/effects/BorderLeftEffect.d.ts +31 -0
- package/dist/src/core/renderers/webgl/shaders/effects/BorderLeftEffect.js +71 -0
- package/dist/src/core/renderers/webgl/shaders/effects/BorderLeftEffect.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/effects/BorderRightEffect.d.ts +31 -0
- package/dist/src/core/renderers/webgl/shaders/effects/BorderRightEffect.js +71 -0
- package/dist/src/core/renderers/webgl/shaders/effects/BorderRightEffect.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/effects/BorderTopEffect.d.ts +31 -0
- package/dist/src/core/renderers/webgl/shaders/effects/BorderTopEffect.js +71 -0
- package/dist/src/core/renderers/webgl/shaders/effects/BorderTopEffect.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/effects/EffectUtils.d.ts +9 -0
- package/dist/src/core/renderers/webgl/shaders/effects/EffectUtils.js +136 -0
- package/dist/src/core/renderers/webgl/shaders/effects/EffectUtils.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/effects/FadeOutEffect.d.ts +36 -0
- package/dist/src/core/renderers/webgl/shaders/effects/FadeOutEffect.js +85 -0
- package/dist/src/core/renderers/webgl/shaders/effects/FadeOutEffect.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/effects/GlitchEffect.d.ts +45 -0
- package/dist/src/core/renderers/webgl/shaders/effects/GlitchEffect.js +104 -0
- package/dist/src/core/renderers/webgl/shaders/effects/GlitchEffect.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/effects/GrayscaleEffect.d.ts +22 -0
- package/dist/src/core/renderers/webgl/shaders/effects/GrayscaleEffect.js +45 -0
- package/dist/src/core/renderers/webgl/shaders/effects/GrayscaleEffect.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/effects/HolePunchEffect.d.ts +58 -0
- package/dist/src/core/renderers/webgl/shaders/effects/HolePunchEffect.js +80 -0
- package/dist/src/core/renderers/webgl/shaders/effects/HolePunchEffect.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/effects/LinearGradientEffect.d.ts +35 -0
- package/dist/src/core/renderers/webgl/shaders/effects/LinearGradientEffect.js +134 -0
- package/dist/src/core/renderers/webgl/shaders/effects/LinearGradientEffect.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/effects/RadialGradientEffect.d.ts +40 -0
- package/dist/src/core/renderers/webgl/shaders/effects/RadialGradientEffect.js +143 -0
- package/dist/src/core/renderers/webgl/shaders/effects/RadialGradientEffect.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/effects/RadialProgressEffect.d.ts +61 -0
- package/dist/src/core/renderers/webgl/shaders/effects/RadialProgressEffect.js +127 -0
- package/dist/src/core/renderers/webgl/shaders/effects/RadialProgressEffect.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/effects/RadiusEffect.d.ts +40 -0
- package/dist/src/core/renderers/webgl/shaders/effects/RadiusEffect.js +71 -0
- package/dist/src/core/renderers/webgl/shaders/effects/RadiusEffect.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/effects/ShaderEffect.d.ts +115 -0
- package/dist/src/core/renderers/webgl/shaders/effects/ShaderEffect.js +61 -0
- package/dist/src/core/renderers/webgl/shaders/effects/ShaderEffect.js.map +1 -0
- package/dist/src/core/shaders/canvas/Border.d.ts +8 -2
- package/dist/src/core/shaders/canvas/Border.js +64 -25
- package/dist/src/core/shaders/canvas/Border.js.map +1 -1
- package/dist/src/core/shaders/canvas/HolePunch.js +4 -3
- package/dist/src/core/shaders/canvas/HolePunch.js.map +1 -1
- package/dist/src/core/shaders/canvas/LinearGradient.js +7 -5
- package/dist/src/core/shaders/canvas/LinearGradient.js.map +1 -1
- package/dist/src/core/shaders/canvas/RadialGradient.js +12 -10
- package/dist/src/core/shaders/canvas/RadialGradient.js.map +1 -1
- package/dist/src/core/shaders/canvas/Rounded.js +3 -3
- package/dist/src/core/shaders/canvas/Rounded.js.map +1 -1
- package/dist/src/core/shaders/canvas/RoundedWithBorder.d.ts +6 -3
- package/dist/src/core/shaders/canvas/RoundedWithBorder.js +41 -11
- package/dist/src/core/shaders/canvas/RoundedWithBorder.js.map +1 -1
- package/dist/src/core/shaders/canvas/RoundedWithBorderAndShadow.d.ts +2 -3
- package/dist/src/core/shaders/canvas/RoundedWithBorderAndShadow.js +46 -9
- package/dist/src/core/shaders/canvas/RoundedWithBorderAndShadow.js.map +1 -1
- package/dist/src/core/shaders/canvas/RoundedWithShadow.js +6 -5
- package/dist/src/core/shaders/canvas/RoundedWithShadow.js.map +1 -1
- package/dist/src/core/shaders/canvas/Shadow.js +4 -2
- package/dist/src/core/shaders/canvas/Shadow.js.map +1 -1
- package/dist/src/core/shaders/canvas/utils/render.d.ts +1 -1
- package/dist/src/core/shaders/canvas/utils/render.js +31 -18
- package/dist/src/core/shaders/canvas/utils/render.js.map +1 -1
- package/dist/src/core/shaders/templates/BorderTemplate.d.ts +11 -1
- package/dist/src/core/shaders/templates/BorderTemplate.js +30 -10
- package/dist/src/core/shaders/templates/BorderTemplate.js.map +1 -1
- package/dist/src/core/shaders/templates/HolePunchTemplate.d.ts +2 -2
- package/dist/src/core/shaders/templates/HolePunchTemplate.js +2 -2
- package/dist/src/core/shaders/templates/HolePunchTemplate.js.map +1 -1
- package/dist/src/core/shaders/templates/RadialGradientTemplate.d.ts +8 -6
- package/dist/src/core/shaders/templates/RadialGradientTemplate.js +2 -2
- package/dist/src/core/shaders/templates/RadialGradientTemplate.js.map +1 -1
- package/dist/src/core/shaders/webgl/Border.js +138 -84
- package/dist/src/core/shaders/webgl/Border.js.map +1 -1
- package/dist/src/core/shaders/webgl/Default.js +46 -47
- package/dist/src/core/shaders/webgl/Default.js.map +1 -1
- package/dist/src/core/shaders/webgl/DefaultBatched.js +61 -61
- package/dist/src/core/shaders/webgl/HolePunch.js +34 -34
- package/dist/src/core/shaders/webgl/HolePunch.js.map +1 -1
- package/dist/src/core/shaders/webgl/LinearGradient.js +60 -36
- package/dist/src/core/shaders/webgl/LinearGradient.js.map +1 -1
- package/dist/src/core/shaders/webgl/RadialGradient.js +60 -37
- package/dist/src/core/shaders/webgl/RadialGradient.js.map +1 -1
- package/dist/src/core/shaders/webgl/Rounded.js +74 -72
- package/dist/src/core/shaders/webgl/Rounded.js.map +1 -1
- package/dist/src/core/shaders/webgl/RoundedWithBorder.js +172 -113
- package/dist/src/core/shaders/webgl/RoundedWithBorder.js.map +1 -1
- package/dist/src/core/shaders/webgl/RoundedWithBorderAndShadow.js +191 -132
- package/dist/src/core/shaders/webgl/RoundedWithBorderAndShadow.js.map +1 -1
- package/dist/src/core/shaders/webgl/RoundedWithShadow.js +57 -55
- package/dist/src/core/shaders/webgl/RoundedWithShadow.js.map +1 -1
- package/dist/src/core/shaders/webgl/SdfShader.d.ts +0 -2
- package/dist/src/core/shaders/webgl/SdfShader.js +56 -66
- package/dist/src/core/shaders/webgl/SdfShader.js.map +1 -1
- package/dist/src/core/shaders/webgl/SdfShadowShader.d.ts +9 -0
- package/dist/src/core/shaders/webgl/SdfShadowShader.js +100 -0
- package/dist/src/core/shaders/webgl/SdfShadowShader.js.map +1 -0
- package/dist/src/core/shaders/webgl/Shadow.js +89 -83
- package/dist/src/core/shaders/webgl/Shadow.js.map +1 -1
- package/dist/src/core/text-rendering/CanvasFont.d.ts +14 -0
- package/dist/src/core/text-rendering/CanvasFont.js +111 -0
- package/dist/src/core/text-rendering/CanvasFont.js.map +1 -0
- package/dist/src/core/text-rendering/CanvasFontHandler.d.ts +59 -0
- package/dist/src/core/text-rendering/CanvasFontHandler.js +224 -0
- package/dist/src/core/text-rendering/CanvasFontHandler.js.map +1 -0
- package/dist/src/core/text-rendering/CanvasTextRenderer.d.ts +17 -0
- package/dist/src/core/text-rendering/CanvasTextRenderer.js +157 -0
- package/dist/src/core/text-rendering/CanvasTextRenderer.js.map +1 -0
- package/dist/src/core/text-rendering/CoreFont.d.ts +33 -0
- package/dist/src/core/text-rendering/CoreFont.js +48 -0
- package/dist/src/core/text-rendering/CoreFont.js.map +1 -0
- package/dist/src/core/text-rendering/FontManager.d.ts +11 -0
- package/dist/src/core/text-rendering/FontManager.js +42 -0
- package/dist/src/core/text-rendering/FontManager.js.map +1 -0
- package/dist/src/core/text-rendering/SdfFont.d.ts +29 -0
- package/dist/src/core/text-rendering/SdfFont.js +142 -0
- package/dist/src/core/text-rendering/SdfFont.js.map +1 -0
- package/dist/src/core/text-rendering/SdfFontHandler.d.ts +182 -0
- package/dist/src/core/text-rendering/SdfFontHandler.js +381 -0
- package/dist/src/core/text-rendering/SdfFontHandler.js.map +1 -0
- package/dist/src/core/text-rendering/SdfTextRenderer.d.ts +17 -0
- package/dist/src/core/text-rendering/SdfTextRenderer.js +301 -0
- package/dist/src/core/text-rendering/SdfTextRenderer.js.map +1 -0
- package/dist/src/core/text-rendering/TextLayoutEngine.d.ts +18 -0
- package/dist/src/core/text-rendering/TextLayoutEngine.js +380 -0
- package/dist/src/core/text-rendering/TextLayoutEngine.js.map +1 -0
- package/dist/src/core/text-rendering/TextRenderer.d.ts +383 -0
- package/{src/core/text-rendering/renderers/SdfTextRenderer/internal/getUnicodeCodepoints.ts → dist/src/core/text-rendering/TextRenderer.js} +20 -38
- package/dist/src/core/text-rendering/TextRenderer.js.map +1 -0
- package/dist/src/core/text-rendering/TextTextureRendererUtils.js.map +1 -1
- package/dist/src/core/text-rendering/Utils.d.ts +30 -0
- package/dist/src/core/text-rendering/Utils.js +84 -0
- package/dist/src/core/text-rendering/Utils.js.map +1 -0
- package/dist/src/core/text-rendering/font-face-types/SdfTrFontFace/SdfTrFontFace.js +2 -2
- package/dist/src/core/text-rendering/font-face-types/SdfTrFontFace/SdfTrFontFace.js.map +1 -1
- package/dist/src/core/text-rendering/renderers/CanvasTextRenderer.js +0 -5
- package/dist/src/core/text-rendering/renderers/CanvasTextRenderer.js.map +1 -1
- package/dist/src/core/text-rendering/renderers/LightningTextTextureRenderer.d.ts +1 -7
- package/dist/src/core/text-rendering/renderers/LightningTextTextureRenderer.js +2 -50
- package/dist/src/core/text-rendering/renderers/LightningTextTextureRenderer.js.map +1 -1
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.d.ts +3 -2
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.js +87 -46
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.js.map +1 -1
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText.d.ts +1 -1
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText.js +8 -66
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText.js.map +1 -1
- package/dist/src/core/text-rendering/renderers/TextRenderer.d.ts +4 -14
- package/dist/src/core/text-rendering/renderers/TextRenderer.js +0 -3
- package/dist/src/core/text-rendering/renderers/TextRenderer.js.map +1 -1
- package/dist/src/core/textures/ColorTexture.d.ts +1 -1
- package/dist/src/core/textures/ColorTexture.js +3 -4
- package/dist/src/core/textures/ColorTexture.js.map +1 -1
- package/dist/src/core/textures/ImageTexture.d.ts +33 -14
- package/dist/src/core/textures/ImageTexture.js +46 -125
- package/dist/src/core/textures/ImageTexture.js.map +1 -1
- package/dist/src/core/textures/NoiseTexture.d.ts +3 -3
- package/dist/src/core/textures/NoiseTexture.js +8 -8
- package/dist/src/core/textures/NoiseTexture.js.map +1 -1
- package/dist/src/core/textures/RenderTexture.d.ts +7 -7
- package/dist/src/core/textures/RenderTexture.js +12 -12
- package/dist/src/core/textures/RenderTexture.js.map +1 -1
- package/dist/src/core/textures/SubTexture.d.ts +6 -8
- package/dist/src/core/textures/SubTexture.js +22 -40
- package/dist/src/core/textures/SubTexture.js.map +1 -1
- package/dist/src/core/textures/Texture.d.ts +74 -15
- package/dist/src/core/textures/Texture.js +131 -19
- package/dist/src/core/textures/Texture.js.map +1 -1
- package/dist/src/core/utils.d.ts +2 -1
- package/dist/src/core/utils.js +1 -1
- package/dist/src/core/utils.js.map +1 -1
- package/dist/src/main-api/DynamicShaderController.d.ts +29 -0
- package/dist/src/main-api/DynamicShaderController.js +58 -0
- package/dist/src/main-api/DynamicShaderController.js.map +1 -0
- package/dist/src/main-api/Inspector.d.ts +129 -1
- package/dist/src/main-api/Inspector.js +462 -23
- package/dist/src/main-api/Inspector.js.map +1 -1
- package/dist/src/main-api/Renderer.d.ts +223 -41
- package/dist/src/main-api/Renderer.js +107 -62
- package/dist/src/main-api/Renderer.js.map +1 -1
- package/dist/src/main-api/ShaderController.d.ts +31 -0
- package/dist/src/main-api/ShaderController.js +37 -0
- package/dist/src/main-api/ShaderController.js.map +1 -0
- package/dist/src/utils.d.ts +0 -2
- package/dist/src/utils.js +0 -36
- package/dist/src/utils.js.map +1 -1
- package/dist/tsconfig.dist.tsbuildinfo +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/exports/canvas-shaders.ts +28 -28
- package/exports/canvas.ts +45 -45
- package/exports/index.ts +90 -90
- package/exports/inspector.ts +24 -24
- package/exports/platform.ts +31 -0
- package/exports/utils.ts +50 -50
- package/exports/webgl-shaders.ts +28 -28
- package/exports/webgl.ts +52 -50
- package/package.json +16 -15
- package/src/common/CommonTypes.ts +163 -146
- package/src/common/EventEmitter.ts +77 -77
- package/src/common/IAnimationController.ts +92 -92
- package/src/common/IEventEmitter.ts +28 -28
- package/src/core/Autosizer.ts +224 -0
- package/src/core/CoreNode.test.ts +365 -202
- package/src/core/CoreNode.ts +2785 -2489
- package/src/core/CoreShaderManager.ts +188 -188
- package/src/core/CoreTextNode.test.ts +311 -0
- package/src/core/CoreTextNode.ts +598 -451
- package/src/core/CoreTextureManager.ts +484 -548
- package/src/core/Stage.ts +927 -800
- package/src/core/TextureError.ts +46 -0
- package/src/core/TextureMemoryManager.ts +418 -462
- package/src/core/animations/AnimationManager.ts +38 -38
- package/src/core/animations/CoreAnimation.ts +290 -291
- package/src/core/animations/CoreAnimationController.ts +169 -166
- package/src/core/lib/ContextSpy.ts +41 -41
- package/src/core/lib/Matrix3d.ts +244 -244
- package/src/core/lib/RenderCoords.ts +71 -71
- package/src/core/lib/collectionUtils.ts +83 -0
- package/src/core/lib/colorCache.ts +20 -0
- package/src/core/{renderers/canvas/internal/ColorUtils.ts → lib/colorParser.ts} +85 -85
- package/src/core/lib/utils.ts +337 -390
- package/src/core/platforms/GlContextWrapper.ts +291 -0
- package/src/core/platforms/Platform.ts +176 -77
- package/src/core/{lib → platforms/web}/WebGlContextWrapper.ts +1547 -1368
- package/src/core/platforms/web/WebPlatform.ts +306 -84
- package/src/core/platforms/web/WebPlatformChrome50.ts +63 -0
- package/src/core/platforms/web/WebPlatformLegacy.ts +150 -0
- package/src/core/platforms/web/WebPlatformNext.ts +57 -0
- package/src/core/platforms/web/lib/ImageWorker.ts +192 -0
- package/src/core/platforms/web/lib/ImageWorkerDefault.ts +117 -0
- package/src/core/platforms/web/lib/ImageWorkerLegacy.ts +87 -0
- package/src/core/platforms/web/lib/ImageWorkerNoOptions.ts +99 -0
- package/src/core/platforms/web/lib/createImageBitmap.ts +40 -0
- package/src/core/platforms/web/lib/textureCompression.ts +391 -0
- package/src/core/{lib → platforms/web/lib}/textureSvg.ts +66 -78
- package/src/core/platforms/web/lib/utils.ts +105 -0
- package/src/core/renderers/CoreContextTexture.ts +44 -43
- package/src/core/renderers/CoreRenderOp.ts +22 -22
- package/src/core/renderers/CoreRenderer.ts +71 -110
- package/src/core/renderers/CoreShaderNode.ts +202 -175
- package/src/core/renderers/CoreShaderProgram.ts +23 -23
- package/src/core/renderers/canvas/CanvasRenderer.ts +258 -302
- package/src/core/renderers/canvas/CanvasShaderNode.ts +95 -96
- package/src/core/renderers/canvas/CanvasTexture.ts +160 -156
- package/src/core/renderers/webgl/SdfRenderOp.ts +106 -0
- package/src/core/renderers/webgl/WebGlCtxRenderTexture.ts +89 -86
- package/src/core/renderers/webgl/WebGlCtxSubTexture.ts +95 -50
- package/src/core/renderers/webgl/WebGlCtxTexture.ts +350 -298
- package/src/core/renderers/webgl/WebGlRenderer.ts +726 -747
- package/src/core/renderers/webgl/WebGlShaderNode.ts +430 -435
- package/src/core/renderers/webgl/WebGlShaderProgram.ts +362 -341
- package/src/core/renderers/webgl/internal/BufferCollection.ts +54 -54
- package/src/core/renderers/webgl/internal/RendererUtils.ts +151 -155
- package/src/core/renderers/webgl/internal/ShaderUtils.ts +283 -281
- package/src/core/renderers/webgl/internal/WebGlUtils.ts +35 -35
- package/src/core/shaders/canvas/Border.ts +132 -78
- package/src/core/shaders/canvas/HolePunch.ts +56 -62
- package/src/core/shaders/canvas/LinearGradient.ts +73 -71
- package/src/core/shaders/canvas/RadialGradient.ts +96 -99
- package/src/core/shaders/canvas/Rounded.ts +55 -55
- package/src/core/shaders/canvas/RoundedWithBorder.ts +122 -74
- package/src/core/shaders/canvas/RoundedWithBorderAndShadow.ts +136 -90
- package/src/core/shaders/canvas/RoundedWithShadow.ts +71 -70
- package/src/core/shaders/canvas/Shadow.ts +54 -52
- package/src/core/shaders/canvas/utils/render.ts +160 -151
- package/src/core/shaders/templates/BorderTemplate.ts +145 -115
- package/src/core/shaders/templates/HolePunchTemplate.ts +82 -82
- package/src/core/shaders/templates/LinearGradientTemplate.ts +71 -71
- package/src/core/shaders/templates/RadialGradientTemplate.ts +83 -81
- package/src/core/shaders/templates/RoundedTemplate.ts +98 -98
- package/src/core/shaders/templates/RoundedWithBorderAndShadowTemplate.ts +38 -38
- package/src/core/shaders/templates/RoundedWithBorderTemplate.ts +35 -35
- package/src/core/shaders/templates/RoundedWithShadowTemplate.ts +35 -35
- package/src/core/shaders/templates/ShadowTemplate.ts +106 -106
- package/src/core/shaders/utils.ts +46 -46
- package/src/core/shaders/webgl/Border.ts +169 -116
- package/src/core/shaders/webgl/Default.ts +88 -89
- package/src/core/shaders/webgl/DefaultBatched.ts +129 -129
- package/src/core/shaders/webgl/HolePunch.ts +75 -75
- package/src/core/shaders/webgl/LinearGradient.ts +106 -82
- package/src/core/shaders/webgl/RadialGradient.ts +108 -85
- package/src/core/shaders/webgl/Rounded.ts +115 -117
- package/src/core/shaders/webgl/RoundedWithBorder.ts +210 -155
- package/src/core/shaders/webgl/RoundedWithBorderAndShadow.ts +234 -175
- package/src/core/shaders/webgl/RoundedWithShadow.ts +96 -98
- package/src/core/shaders/webgl/SdfShader.ts +122 -134
- package/src/core/shaders/webgl/Shadow.ts +121 -115
- package/src/core/text-rendering/CanvasFontHandler.ts +304 -0
- package/src/core/text-rendering/CanvasTextRenderer.ts +255 -0
- package/src/core/text-rendering/SdfFontHandler.ts +584 -0
- package/src/core/text-rendering/SdfTextRenderer.ts +403 -0
- package/src/core/text-rendering/TextLayoutEngine.ts +672 -0
- package/src/core/text-rendering/TextRenderer.ts +444 -0
- package/src/core/text-rendering/Utils.ts +99 -0
- package/src/core/text-rendering/tests/TextLayoutEngine.test.ts +453 -0
- package/src/core/textures/ColorTexture.ts +104 -102
- package/src/core/textures/ImageTexture.ts +292 -418
- package/src/core/textures/NoiseTexture.ts +106 -104
- package/src/core/textures/RenderTexture.ts +87 -85
- package/src/core/textures/SubTexture.ts +184 -205
- package/src/core/textures/Texture.ts +524 -381
- package/src/core/utils.ts +229 -227
- package/src/env.d.ts +7 -7
- package/src/main-api/INode.ts +100 -100
- package/src/main-api/Inspector.ts +1278 -569
- package/src/main-api/Renderer.ts +1030 -818
- package/src/main-api/utils.ts +45 -45
- package/src/utils.ts +220 -267
- package/COPYING +0 -1
- package/src/core/lib/ImageWorker.ts +0 -286
- package/src/core/lib/textureCompression.ts +0 -152
- package/src/core/lib/validateImageBitmap.ts +0 -87
- package/src/core/renderers/canvas/internal/C2DShaderUtils.ts +0 -220
- package/src/core/renderers/webgl/WebGlRenderOp.ts +0 -161
- package/src/core/text-rendering/TextTextureRendererUtils.ts +0 -263
- package/src/core/text-rendering/TrFontManager.ts +0 -183
- package/src/core/text-rendering/font-face-types/SdfTrFontFace/SdfTrFontFace.ts +0 -176
- package/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/FontShaper.ts +0 -139
- package/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/SdfFontShaper.test.ts +0 -173
- package/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/SdfFontShaper.ts +0 -171
- package/src/core/text-rendering/font-face-types/TrFontFace.ts +0 -187
- package/src/core/text-rendering/font-face-types/WebTrFontFace.ts +0 -94
- package/src/core/text-rendering/font-face-types/utils.ts +0 -39
- package/src/core/text-rendering/renderers/CanvasTextRenderer.ts +0 -514
- package/src/core/text-rendering/renderers/LightningTextTextureRenderer.ts +0 -863
- package/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.ts +0 -793
- package/src/core/text-rendering/renderers/SdfTextRenderer/internal/PeekableGenerator.test.ts +0 -48
- package/src/core/text-rendering/renderers/SdfTextRenderer/internal/PeekableGenerator.ts +0 -66
- package/src/core/text-rendering/renderers/SdfTextRenderer/internal/SpecialCodepoints.ts +0 -52
- package/src/core/text-rendering/renderers/SdfTextRenderer/internal/getStartConditions.ts +0 -117
- package/src/core/text-rendering/renderers/SdfTextRenderer/internal/getUnicodeCodepoints.test.ts +0 -133
- package/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText.ts +0 -497
- package/src/core/text-rendering/renderers/SdfTextRenderer/internal/measureText.test.ts +0 -49
- package/src/core/text-rendering/renderers/SdfTextRenderer/internal/measureText.ts +0 -52
- package/src/core/text-rendering/renderers/SdfTextRenderer/internal/setRenderWindow.test.ts +0 -205
- package/src/core/text-rendering/renderers/SdfTextRenderer/internal/setRenderWindow.ts +0 -93
- package/src/core/text-rendering/renderers/TextRenderer.ts +0 -567
|
@@ -1,747 +1,726 @@
|
|
|
1
|
-
/*
|
|
2
|
-
* If not stated otherwise in this file or this component's LICENSE file the
|
|
3
|
-
* following copyright and licenses apply:
|
|
4
|
-
*
|
|
5
|
-
* Copyright 2023 Comcast Cable Communications Management, LLC.
|
|
6
|
-
*
|
|
7
|
-
* Licensed under the Apache License, Version 2.0 (the License);
|
|
8
|
-
* you may not use this file except in compliance with the License.
|
|
9
|
-
* You may obtain a copy of the License at
|
|
10
|
-
*
|
|
11
|
-
* http://www.apache.org/licenses/LICENSE-2.0
|
|
12
|
-
*
|
|
13
|
-
* Unless required by applicable law or agreed to in writing, software
|
|
14
|
-
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
15
|
-
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
16
|
-
* See the License for the specific language governing permissions and
|
|
17
|
-
* limitations under the License.
|
|
18
|
-
*/
|
|
19
|
-
|
|
20
|
-
import {
|
|
21
|
-
import {
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
type
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
type
|
|
36
|
-
} from '
|
|
37
|
-
import {
|
|
38
|
-
import {
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
} from '../../textures/
|
|
43
|
-
import {
|
|
44
|
-
import {
|
|
45
|
-
import {
|
|
46
|
-
import {
|
|
47
|
-
import {
|
|
48
|
-
import {
|
|
49
|
-
import {
|
|
50
|
-
import {
|
|
51
|
-
import {
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
override
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
this.
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
const
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
glw.
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
shaderType
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
*
|
|
245
|
-
*
|
|
246
|
-
*
|
|
247
|
-
* The function
|
|
248
|
-
*
|
|
249
|
-
*
|
|
250
|
-
* The function
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
const
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
}
|
|
266
|
-
|
|
267
|
-
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
const
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
const
|
|
279
|
-
const
|
|
280
|
-
const
|
|
281
|
-
|
|
282
|
-
|
|
283
|
-
|
|
284
|
-
f[i
|
|
285
|
-
f[i +
|
|
286
|
-
f[i +
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
f[i +
|
|
290
|
-
f[i +
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
f[i +
|
|
295
|
-
f[i +
|
|
296
|
-
f[i +
|
|
297
|
-
|
|
298
|
-
|
|
299
|
-
f[i +
|
|
300
|
-
f[i +
|
|
301
|
-
|
|
302
|
-
|
|
303
|
-
|
|
304
|
-
f[i +
|
|
305
|
-
f[i +
|
|
306
|
-
f[i +
|
|
307
|
-
|
|
308
|
-
|
|
309
|
-
f[i +
|
|
310
|
-
f[i +
|
|
311
|
-
|
|
312
|
-
|
|
313
|
-
|
|
314
|
-
f[i +
|
|
315
|
-
f[i +
|
|
316
|
-
f[i +
|
|
317
|
-
|
|
318
|
-
|
|
319
|
-
f[i +
|
|
320
|
-
f[i +
|
|
321
|
-
|
|
322
|
-
|
|
323
|
-
this.
|
|
324
|
-
|
|
325
|
-
|
|
326
|
-
|
|
327
|
-
|
|
328
|
-
*
|
|
329
|
-
*
|
|
330
|
-
*
|
|
331
|
-
* @param
|
|
332
|
-
|
|
333
|
-
|
|
334
|
-
|
|
335
|
-
|
|
336
|
-
|
|
337
|
-
|
|
338
|
-
|
|
339
|
-
|
|
340
|
-
|
|
341
|
-
|
|
342
|
-
|
|
343
|
-
|
|
344
|
-
|
|
345
|
-
*
|
|
346
|
-
* @param
|
|
347
|
-
* @
|
|
348
|
-
|
|
349
|
-
|
|
350
|
-
|
|
351
|
-
|
|
352
|
-
|
|
353
|
-
|
|
354
|
-
|
|
355
|
-
|
|
356
|
-
const
|
|
357
|
-
|
|
358
|
-
if (
|
|
359
|
-
|
|
360
|
-
|
|
361
|
-
|
|
362
|
-
|
|
363
|
-
|
|
364
|
-
|
|
365
|
-
|
|
366
|
-
|
|
367
|
-
|
|
368
|
-
|
|
369
|
-
|
|
370
|
-
|
|
371
|
-
|
|
372
|
-
|
|
373
|
-
|
|
374
|
-
|
|
375
|
-
|
|
376
|
-
|
|
377
|
-
|
|
378
|
-
|
|
379
|
-
|
|
380
|
-
|
|
381
|
-
|
|
382
|
-
|
|
383
|
-
|
|
384
|
-
|
|
385
|
-
|
|
386
|
-
|
|
387
|
-
|
|
388
|
-
|
|
389
|
-
|
|
390
|
-
|
|
391
|
-
|
|
392
|
-
if (
|
|
393
|
-
|
|
394
|
-
|
|
395
|
-
|
|
396
|
-
|
|
397
|
-
|
|
398
|
-
|
|
399
|
-
|
|
400
|
-
|
|
401
|
-
|
|
402
|
-
|
|
403
|
-
|
|
404
|
-
|
|
405
|
-
|
|
406
|
-
|
|
407
|
-
|
|
408
|
-
|
|
409
|
-
|
|
410
|
-
|
|
411
|
-
|
|
412
|
-
|
|
413
|
-
|
|
414
|
-
|
|
415
|
-
|
|
416
|
-
|
|
417
|
-
|
|
418
|
-
|
|
419
|
-
|
|
420
|
-
|
|
421
|
-
|
|
422
|
-
|
|
423
|
-
|
|
424
|
-
this.
|
|
425
|
-
|
|
426
|
-
|
|
427
|
-
|
|
428
|
-
|
|
429
|
-
|
|
430
|
-
|
|
431
|
-
|
|
432
|
-
|
|
433
|
-
|
|
434
|
-
|
|
435
|
-
|
|
436
|
-
|
|
437
|
-
|
|
438
|
-
|
|
439
|
-
|
|
440
|
-
|
|
441
|
-
|
|
442
|
-
|
|
443
|
-
for (let i = 0
|
|
444
|
-
|
|
445
|
-
|
|
446
|
-
|
|
447
|
-
|
|
448
|
-
|
|
449
|
-
|
|
450
|
-
|
|
451
|
-
|
|
452
|
-
|
|
453
|
-
|
|
454
|
-
|
|
455
|
-
|
|
456
|
-
|
|
457
|
-
|
|
458
|
-
|
|
459
|
-
|
|
460
|
-
|
|
461
|
-
|
|
462
|
-
|
|
463
|
-
|
|
464
|
-
|
|
465
|
-
|
|
466
|
-
|
|
467
|
-
|
|
468
|
-
|
|
469
|
-
*
|
|
470
|
-
*
|
|
471
|
-
*
|
|
472
|
-
|
|
473
|
-
|
|
474
|
-
|
|
475
|
-
|
|
476
|
-
|
|
477
|
-
|
|
478
|
-
|
|
479
|
-
|
|
480
|
-
|
|
481
|
-
|
|
482
|
-
|
|
483
|
-
|
|
484
|
-
|
|
485
|
-
|
|
486
|
-
|
|
487
|
-
|
|
488
|
-
|
|
489
|
-
|
|
490
|
-
|
|
491
|
-
|
|
492
|
-
|
|
493
|
-
|
|
494
|
-
|
|
495
|
-
|
|
496
|
-
|
|
497
|
-
|
|
498
|
-
|
|
499
|
-
|
|
500
|
-
|
|
501
|
-
|
|
502
|
-
|
|
503
|
-
|
|
504
|
-
|
|
505
|
-
|
|
506
|
-
|
|
507
|
-
|
|
508
|
-
|
|
509
|
-
|
|
510
|
-
|
|
511
|
-
|
|
512
|
-
|
|
513
|
-
|
|
514
|
-
|
|
515
|
-
|
|
516
|
-
|
|
517
|
-
|
|
518
|
-
|
|
519
|
-
|
|
520
|
-
|
|
521
|
-
|
|
522
|
-
|
|
523
|
-
|
|
524
|
-
|
|
525
|
-
|
|
526
|
-
|
|
527
|
-
|
|
528
|
-
|
|
529
|
-
|
|
530
|
-
|
|
531
|
-
|
|
532
|
-
|
|
533
|
-
|
|
534
|
-
|
|
535
|
-
|
|
536
|
-
|
|
537
|
-
|
|
538
|
-
|
|
539
|
-
|
|
540
|
-
|
|
541
|
-
|
|
542
|
-
|
|
543
|
-
|
|
544
|
-
|
|
545
|
-
|
|
546
|
-
|
|
547
|
-
|
|
548
|
-
|
|
549
|
-
|
|
550
|
-
|
|
551
|
-
|
|
552
|
-
|
|
553
|
-
|
|
554
|
-
|
|
555
|
-
|
|
556
|
-
|
|
557
|
-
|
|
558
|
-
|
|
559
|
-
|
|
560
|
-
|
|
561
|
-
|
|
562
|
-
|
|
563
|
-
|
|
564
|
-
|
|
565
|
-
|
|
566
|
-
|
|
567
|
-
|
|
568
|
-
|
|
569
|
-
|
|
570
|
-
|
|
571
|
-
|
|
572
|
-
|
|
573
|
-
|
|
574
|
-
|
|
575
|
-
|
|
576
|
-
|
|
577
|
-
|
|
578
|
-
|
|
579
|
-
|
|
580
|
-
|
|
581
|
-
|
|
582
|
-
|
|
583
|
-
|
|
584
|
-
|
|
585
|
-
|
|
586
|
-
|
|
587
|
-
|
|
588
|
-
|
|
589
|
-
|
|
590
|
-
|
|
591
|
-
|
|
592
|
-
|
|
593
|
-
|
|
594
|
-
|
|
595
|
-
|
|
596
|
-
|
|
597
|
-
|
|
598
|
-
|
|
599
|
-
|
|
600
|
-
|
|
601
|
-
|
|
602
|
-
|
|
603
|
-
|
|
604
|
-
|
|
605
|
-
|
|
606
|
-
|
|
607
|
-
|
|
608
|
-
|
|
609
|
-
|
|
610
|
-
|
|
611
|
-
|
|
612
|
-
|
|
613
|
-
|
|
614
|
-
|
|
615
|
-
|
|
616
|
-
|
|
617
|
-
|
|
618
|
-
|
|
619
|
-
|
|
620
|
-
|
|
621
|
-
|
|
622
|
-
|
|
623
|
-
|
|
624
|
-
|
|
625
|
-
|
|
626
|
-
|
|
627
|
-
|
|
628
|
-
|
|
629
|
-
|
|
630
|
-
|
|
631
|
-
|
|
632
|
-
|
|
633
|
-
|
|
634
|
-
|
|
635
|
-
|
|
636
|
-
|
|
637
|
-
|
|
638
|
-
|
|
639
|
-
|
|
640
|
-
|
|
641
|
-
|
|
642
|
-
|
|
643
|
-
|
|
644
|
-
|
|
645
|
-
|
|
646
|
-
|
|
647
|
-
|
|
648
|
-
|
|
649
|
-
|
|
650
|
-
|
|
651
|
-
|
|
652
|
-
|
|
653
|
-
|
|
654
|
-
texture
|
|
655
|
-
|
|
656
|
-
|
|
657
|
-
|
|
658
|
-
|
|
659
|
-
|
|
660
|
-
|
|
661
|
-
|
|
662
|
-
|
|
663
|
-
|
|
664
|
-
|
|
665
|
-
|
|
666
|
-
|
|
667
|
-
|
|
668
|
-
|
|
669
|
-
|
|
670
|
-
|
|
671
|
-
|
|
672
|
-
|
|
673
|
-
|
|
674
|
-
|
|
675
|
-
|
|
676
|
-
|
|
677
|
-
|
|
678
|
-
|
|
679
|
-
|
|
680
|
-
|
|
681
|
-
|
|
682
|
-
|
|
683
|
-
|
|
684
|
-
|
|
685
|
-
|
|
686
|
-
|
|
687
|
-
|
|
688
|
-
|
|
689
|
-
|
|
690
|
-
|
|
691
|
-
|
|
692
|
-
|
|
693
|
-
|
|
694
|
-
|
|
695
|
-
|
|
696
|
-
|
|
697
|
-
|
|
698
|
-
|
|
699
|
-
|
|
700
|
-
|
|
701
|
-
|
|
702
|
-
|
|
703
|
-
|
|
704
|
-
|
|
705
|
-
|
|
706
|
-
|
|
707
|
-
|
|
708
|
-
|
|
709
|
-
|
|
710
|
-
|
|
711
|
-
|
|
712
|
-
|
|
713
|
-
|
|
714
|
-
|
|
715
|
-
|
|
716
|
-
|
|
717
|
-
|
|
718
|
-
|
|
719
|
-
|
|
720
|
-
|
|
721
|
-
|
|
722
|
-
|
|
723
|
-
|
|
724
|
-
|
|
725
|
-
|
|
726
|
-
|
|
727
|
-
* Sets the glClearColor to the specified color. *
|
|
728
|
-
* @param color - The color to set as the clear color, represented as a 32-bit integer.
|
|
729
|
-
*/
|
|
730
|
-
updateClearColor(color: number) {
|
|
731
|
-
if (this.clearColor.raw === color) {
|
|
732
|
-
return;
|
|
733
|
-
}
|
|
734
|
-
const glw = this.glw;
|
|
735
|
-
const normalizedColor = getNormalizedRgbaComponents(color);
|
|
736
|
-
glw.clearColor(
|
|
737
|
-
normalizedColor[0],
|
|
738
|
-
normalizedColor[1],
|
|
739
|
-
normalizedColor[2],
|
|
740
|
-
normalizedColor[3],
|
|
741
|
-
);
|
|
742
|
-
this.clearColor = {
|
|
743
|
-
raw: color,
|
|
744
|
-
normalized: normalizedColor,
|
|
745
|
-
};
|
|
746
|
-
}
|
|
747
|
-
}
|
|
1
|
+
/*
|
|
2
|
+
* If not stated otherwise in this file or this component's LICENSE file the
|
|
3
|
+
* following copyright and licenses apply:
|
|
4
|
+
*
|
|
5
|
+
* Copyright 2023 Comcast Cable Communications Management, LLC.
|
|
6
|
+
*
|
|
7
|
+
* Licensed under the Apache License, Version 2.0 (the License);
|
|
8
|
+
* you may not use this file except in compliance with the License.
|
|
9
|
+
* You may obtain a copy of the License at
|
|
10
|
+
*
|
|
11
|
+
* http://www.apache.org/licenses/LICENSE-2.0
|
|
12
|
+
*
|
|
13
|
+
* Unless required by applicable law or agreed to in writing, software
|
|
14
|
+
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
15
|
+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
16
|
+
* See the License for the specific language governing permissions and
|
|
17
|
+
* limitations under the License.
|
|
18
|
+
*/
|
|
19
|
+
|
|
20
|
+
import { CoreRenderer, type BufferInfo } from '../CoreRenderer.js';
|
|
21
|
+
import type { SdfRenderOp } from './SdfRenderOp.js';
|
|
22
|
+
import type { CoreContextTexture } from '../CoreContextTexture.js';
|
|
23
|
+
import {
|
|
24
|
+
createIndexBuffer,
|
|
25
|
+
type CoreWebGlParameters,
|
|
26
|
+
type CoreWebGlExtensions,
|
|
27
|
+
getWebGlParameters,
|
|
28
|
+
getWebGlExtensions,
|
|
29
|
+
type WebGlColor,
|
|
30
|
+
} from './internal/RendererUtils.js';
|
|
31
|
+
import { WebGlCtxTexture } from './WebGlCtxTexture.js';
|
|
32
|
+
import {
|
|
33
|
+
Texture,
|
|
34
|
+
TextureType,
|
|
35
|
+
type TextureCoords,
|
|
36
|
+
} from '../../textures/Texture.js';
|
|
37
|
+
import { SubTexture } from '../../textures/SubTexture.js';
|
|
38
|
+
import { WebGlCtxSubTexture } from './WebGlCtxSubTexture.js';
|
|
39
|
+
import { BufferCollection } from './internal/BufferCollection.js';
|
|
40
|
+
import { compareRect, getNormalizedRgbaComponents } from '../../lib/utils.js';
|
|
41
|
+
import { WebGlShaderProgram } from './WebGlShaderProgram.js';
|
|
42
|
+
import { RenderTexture } from '../../textures/RenderTexture.js';
|
|
43
|
+
import { CoreNodeRenderState, CoreNode } from '../../CoreNode.js';
|
|
44
|
+
import { WebGlCtxRenderTexture } from './WebGlCtxRenderTexture.js';
|
|
45
|
+
import { Default } from '../../shaders/webgl/Default.js';
|
|
46
|
+
import type { WebGlShaderType } from './WebGlShaderNode.js';
|
|
47
|
+
import { WebGlShaderNode } from './WebGlShaderNode.js';
|
|
48
|
+
import type { Dimensions } from '../../../common/CommonTypes.js';
|
|
49
|
+
import type { GlContextWrapper } from '../../platforms/GlContextWrapper.js';
|
|
50
|
+
import type { Platform } from '../../platforms/Platform.js';
|
|
51
|
+
import type { Stage } from '../../Stage.js';
|
|
52
|
+
|
|
53
|
+
interface CoreWebGlSystem {
|
|
54
|
+
parameters: CoreWebGlParameters;
|
|
55
|
+
extensions: CoreWebGlExtensions;
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
export type WebGlRenderOp = CoreNode | SdfRenderOp;
|
|
59
|
+
|
|
60
|
+
export class WebGlRenderer extends CoreRenderer {
|
|
61
|
+
//// WebGL Native Context and Data
|
|
62
|
+
glw: GlContextWrapper;
|
|
63
|
+
system: CoreWebGlSystem;
|
|
64
|
+
|
|
65
|
+
//// Persistent data
|
|
66
|
+
quadBuffer: ArrayBuffer;
|
|
67
|
+
fQuadBuffer: Float32Array;
|
|
68
|
+
uiQuadBuffer: Uint32Array;
|
|
69
|
+
renderOps: WebGlRenderOp[] = [];
|
|
70
|
+
|
|
71
|
+
//// Render Op / Buffer Filling State
|
|
72
|
+
curBufferIdx = 0;
|
|
73
|
+
curRenderOp: WebGlRenderOp | null = null;
|
|
74
|
+
override rttNodes: CoreNode[] = [];
|
|
75
|
+
activeRttNode: CoreNode | null = null;
|
|
76
|
+
|
|
77
|
+
override defaultTextureCoords: TextureCoords = {
|
|
78
|
+
x1: 0,
|
|
79
|
+
y1: 0,
|
|
80
|
+
x2: 1,
|
|
81
|
+
y2: 1,
|
|
82
|
+
};
|
|
83
|
+
|
|
84
|
+
//// Default Shader
|
|
85
|
+
defaultShaderNode: WebGlShaderNode | null = null;
|
|
86
|
+
quadBufferCollection: BufferCollection;
|
|
87
|
+
|
|
88
|
+
clearColor: WebGlColor = {
|
|
89
|
+
raw: 0x00000000,
|
|
90
|
+
normalized: [0, 0, 0, 0],
|
|
91
|
+
};
|
|
92
|
+
|
|
93
|
+
/**
|
|
94
|
+
* White pixel texture used by default when no texture is specified.
|
|
95
|
+
*/
|
|
96
|
+
|
|
97
|
+
quadBufferUsage = 0;
|
|
98
|
+
numQuadsRendered = 0;
|
|
99
|
+
/**
|
|
100
|
+
* Whether the renderer is currently rendering to a texture.
|
|
101
|
+
*/
|
|
102
|
+
public renderToTextureActive = false;
|
|
103
|
+
|
|
104
|
+
constructor(stage: Stage) {
|
|
105
|
+
super(stage);
|
|
106
|
+
|
|
107
|
+
this.quadBuffer = new ArrayBuffer(stage.options.quadBufferSize);
|
|
108
|
+
this.fQuadBuffer = new Float32Array(this.quadBuffer);
|
|
109
|
+
this.uiQuadBuffer = new Uint32Array(this.quadBuffer);
|
|
110
|
+
|
|
111
|
+
this.mode = 'webgl';
|
|
112
|
+
|
|
113
|
+
const platform = stage.platform;
|
|
114
|
+
const canvas = platform.canvas!;
|
|
115
|
+
|
|
116
|
+
const glw = (this.glw = platform.createContext() as GlContextWrapper);
|
|
117
|
+
glw.viewport(0, 0, canvas.width, canvas.height);
|
|
118
|
+
|
|
119
|
+
this.updateClearColor(stage.clearColor);
|
|
120
|
+
|
|
121
|
+
glw.setBlend(true);
|
|
122
|
+
glw.blendFunc(glw.ONE, glw.ONE_MINUS_SRC_ALPHA);
|
|
123
|
+
|
|
124
|
+
createIndexBuffer(glw, stage.bufferMemory);
|
|
125
|
+
|
|
126
|
+
this.system = {
|
|
127
|
+
parameters: getWebGlParameters(this.glw),
|
|
128
|
+
extensions: getWebGlExtensions(this.glw),
|
|
129
|
+
};
|
|
130
|
+
const quadBuffer = glw.createBuffer();
|
|
131
|
+
const stride = 8 * Float32Array.BYTES_PER_ELEMENT;
|
|
132
|
+
this.quadBufferCollection = new BufferCollection([
|
|
133
|
+
{
|
|
134
|
+
buffer: quadBuffer!,
|
|
135
|
+
attributes: {
|
|
136
|
+
a_position: {
|
|
137
|
+
name: 'a_position',
|
|
138
|
+
size: 2, // 2 components per iteration
|
|
139
|
+
type: glw.FLOAT, // the data is 32bit floats
|
|
140
|
+
normalized: false, // don't normalize the data
|
|
141
|
+
stride, // 0 = move forward size * sizeof(type) each iteration to get the next position
|
|
142
|
+
offset: 0, // start at the beginning of the buffer
|
|
143
|
+
},
|
|
144
|
+
a_textureCoords: {
|
|
145
|
+
name: 'a_textureCoords',
|
|
146
|
+
size: 2,
|
|
147
|
+
type: glw.FLOAT,
|
|
148
|
+
normalized: false,
|
|
149
|
+
stride,
|
|
150
|
+
offset: 2 * Float32Array.BYTES_PER_ELEMENT,
|
|
151
|
+
},
|
|
152
|
+
a_color: {
|
|
153
|
+
name: 'a_color',
|
|
154
|
+
size: 4,
|
|
155
|
+
type: glw.UNSIGNED_BYTE,
|
|
156
|
+
normalized: true,
|
|
157
|
+
stride,
|
|
158
|
+
offset: 4 * Float32Array.BYTES_PER_ELEMENT,
|
|
159
|
+
},
|
|
160
|
+
a_textureIndex: {
|
|
161
|
+
name: 'a_textureIndex',
|
|
162
|
+
size: 1,
|
|
163
|
+
type: glw.FLOAT,
|
|
164
|
+
normalized: false,
|
|
165
|
+
stride,
|
|
166
|
+
offset: 5 * Float32Array.BYTES_PER_ELEMENT,
|
|
167
|
+
},
|
|
168
|
+
a_nodeCoords: {
|
|
169
|
+
name: 'a_nodeCoords',
|
|
170
|
+
size: 2,
|
|
171
|
+
type: glw.FLOAT,
|
|
172
|
+
normalized: false,
|
|
173
|
+
stride,
|
|
174
|
+
offset: 6 * Float32Array.BYTES_PER_ELEMENT,
|
|
175
|
+
},
|
|
176
|
+
},
|
|
177
|
+
},
|
|
178
|
+
]);
|
|
179
|
+
}
|
|
180
|
+
|
|
181
|
+
reset() {
|
|
182
|
+
const { glw } = this;
|
|
183
|
+
this.curBufferIdx = 0;
|
|
184
|
+
this.curRenderOp = null;
|
|
185
|
+
this.renderOps.length = 0;
|
|
186
|
+
glw.setScissorTest(false);
|
|
187
|
+
if (this.stage.options.enableClear !== false) {
|
|
188
|
+
glw.clear();
|
|
189
|
+
}
|
|
190
|
+
}
|
|
191
|
+
|
|
192
|
+
createShaderProgram(
|
|
193
|
+
shaderType: WebGlShaderType,
|
|
194
|
+
props: Record<string, unknown>,
|
|
195
|
+
): WebGlShaderProgram {
|
|
196
|
+
return new WebGlShaderProgram(this, shaderType, props);
|
|
197
|
+
}
|
|
198
|
+
|
|
199
|
+
createShaderNode(
|
|
200
|
+
shaderKey: string,
|
|
201
|
+
shaderType: WebGlShaderType,
|
|
202
|
+
props?: Record<string, unknown>,
|
|
203
|
+
program?: WebGlShaderProgram,
|
|
204
|
+
) {
|
|
205
|
+
return new WebGlShaderNode(
|
|
206
|
+
shaderKey,
|
|
207
|
+
shaderType,
|
|
208
|
+
program!,
|
|
209
|
+
this.stage,
|
|
210
|
+
props,
|
|
211
|
+
);
|
|
212
|
+
}
|
|
213
|
+
|
|
214
|
+
override supportsShaderType(shaderType: Readonly<WebGlShaderType>): boolean {
|
|
215
|
+
//if shadertype doesnt have a fragment source we cant use it
|
|
216
|
+
return shaderType.fragment !== undefined;
|
|
217
|
+
}
|
|
218
|
+
|
|
219
|
+
createCtxTexture(textureSource: Texture): CoreContextTexture {
|
|
220
|
+
if (textureSource instanceof SubTexture) {
|
|
221
|
+
return new WebGlCtxSubTexture(
|
|
222
|
+
this.glw,
|
|
223
|
+
this.stage.txMemManager,
|
|
224
|
+
textureSource,
|
|
225
|
+
);
|
|
226
|
+
} else if (textureSource instanceof RenderTexture) {
|
|
227
|
+
return new WebGlCtxRenderTexture(
|
|
228
|
+
this.glw,
|
|
229
|
+
this.stage.txMemManager,
|
|
230
|
+
textureSource,
|
|
231
|
+
);
|
|
232
|
+
}
|
|
233
|
+
return new WebGlCtxTexture(
|
|
234
|
+
this.glw,
|
|
235
|
+
this.stage.txMemManager,
|
|
236
|
+
textureSource,
|
|
237
|
+
);
|
|
238
|
+
}
|
|
239
|
+
|
|
240
|
+
/**
|
|
241
|
+
* This function adds a quad (a rectangle composed of two triangles) to the WebGL rendering pipeline.
|
|
242
|
+
*
|
|
243
|
+
* It takes a set of options that define the quad's properties, such as its dimensions, colors, texture, shader, and transformation matrix.
|
|
244
|
+
* The function first updates the shader properties with the current dimensions if necessary, then sets the default texture if none is provided.
|
|
245
|
+
* It then checks if a new render operation is needed, based on the current shader and clipping rectangle.
|
|
246
|
+
* If a new render operation is needed, it creates one and updates the current render operation.
|
|
247
|
+
* The function then adjusts the texture coordinates based on the texture options and adds the texture to the texture manager.
|
|
248
|
+
*
|
|
249
|
+
* Finally, it calculates the vertices for the quad, taking into account any transformations, and adds them to the quad buffer.
|
|
250
|
+
* The function updates the length and number of quads in the current render operation, and updates the current buffer index.
|
|
251
|
+
*/
|
|
252
|
+
addQuad(node: CoreNode) {
|
|
253
|
+
const f = this.fQuadBuffer;
|
|
254
|
+
const u = this.uiQuadBuffer;
|
|
255
|
+
let i = this.curBufferIdx;
|
|
256
|
+
|
|
257
|
+
const reuse = this.reuseRenderOp(node);
|
|
258
|
+
if (reuse === false) {
|
|
259
|
+
this.newRenderOp(node, i);
|
|
260
|
+
}
|
|
261
|
+
|
|
262
|
+
let tx = (node.props.texture || this.stage.defaultTexture) as Texture;
|
|
263
|
+
if (tx.type === TextureType.subTexture) {
|
|
264
|
+
tx = (tx as SubTexture).parentTexture;
|
|
265
|
+
}
|
|
266
|
+
|
|
267
|
+
const texture = tx.ctxTexture as WebGlCtxTexture;
|
|
268
|
+
let tidx = this.curRenderOp!.addTexture(texture);
|
|
269
|
+
|
|
270
|
+
if (tidx === 0xffffffff) {
|
|
271
|
+
this.newRenderOp(node, i);
|
|
272
|
+
tidx = this.curRenderOp!.addTexture(texture);
|
|
273
|
+
}
|
|
274
|
+
|
|
275
|
+
const rc = node.renderCoords!;
|
|
276
|
+
const tc = node.textureCoords || this.defaultTextureCoords;
|
|
277
|
+
|
|
278
|
+
const cTl = node.premultipliedColorTl;
|
|
279
|
+
const cTr = node.premultipliedColorTr;
|
|
280
|
+
const cBl = node.premultipliedColorBl;
|
|
281
|
+
const cBr = node.premultipliedColorBr;
|
|
282
|
+
|
|
283
|
+
// Upper-Left
|
|
284
|
+
f[i] = rc.x1;
|
|
285
|
+
f[i + 1] = rc.y1;
|
|
286
|
+
f[i + 2] = tc.x1;
|
|
287
|
+
f[i + 3] = tc.y1;
|
|
288
|
+
u[i + 4] = cTl;
|
|
289
|
+
f[i + 5] = tidx;
|
|
290
|
+
f[i + 6] = 0;
|
|
291
|
+
f[i + 7] = 0;
|
|
292
|
+
|
|
293
|
+
// Upper-Right
|
|
294
|
+
f[i + 8] = rc.x2;
|
|
295
|
+
f[i + 9] = rc.y2;
|
|
296
|
+
f[i + 10] = tc.x2;
|
|
297
|
+
f[i + 11] = tc.y1;
|
|
298
|
+
u[i + 12] = cTr;
|
|
299
|
+
f[i + 13] = tidx;
|
|
300
|
+
f[i + 14] = 1;
|
|
301
|
+
f[i + 15] = 0;
|
|
302
|
+
|
|
303
|
+
// Lower-Left
|
|
304
|
+
f[i + 16] = rc.x4;
|
|
305
|
+
f[i + 17] = rc.y4;
|
|
306
|
+
f[i + 18] = tc.x1;
|
|
307
|
+
f[i + 19] = tc.y2;
|
|
308
|
+
u[i + 20] = cBl;
|
|
309
|
+
f[i + 21] = tidx;
|
|
310
|
+
f[i + 22] = 0;
|
|
311
|
+
f[i + 23] = 1;
|
|
312
|
+
|
|
313
|
+
// Lower-Right
|
|
314
|
+
f[i + 24] = rc.x3;
|
|
315
|
+
f[i + 25] = rc.y3;
|
|
316
|
+
f[i + 26] = tc.x2;
|
|
317
|
+
f[i + 27] = tc.y2;
|
|
318
|
+
u[i + 28] = cBr;
|
|
319
|
+
f[i + 29] = tidx;
|
|
320
|
+
f[i + 30] = 1;
|
|
321
|
+
f[i + 31] = 1;
|
|
322
|
+
|
|
323
|
+
this.curRenderOp!.numQuads++;
|
|
324
|
+
this.curBufferIdx = i + 32;
|
|
325
|
+
}
|
|
326
|
+
|
|
327
|
+
/**
|
|
328
|
+
* Replace the existing RenderOp with a new one that uses the specified Shader
|
|
329
|
+
* and starts at the specified buffer index.
|
|
330
|
+
*
|
|
331
|
+
* @param shader
|
|
332
|
+
* @param bufferIdx
|
|
333
|
+
*/
|
|
334
|
+
private newRenderOp(node: CoreNode, bufferIdx: number) {
|
|
335
|
+
const curRenderOp = node;
|
|
336
|
+
curRenderOp.renderOpBufferIdx = bufferIdx;
|
|
337
|
+
curRenderOp.numQuads = 0;
|
|
338
|
+
curRenderOp.renderOpTextures.length = 0;
|
|
339
|
+
|
|
340
|
+
this.curRenderOp = curRenderOp;
|
|
341
|
+
this.renderOps.push(curRenderOp);
|
|
342
|
+
}
|
|
343
|
+
|
|
344
|
+
/**
|
|
345
|
+
* Test if the current Render operation can be reused for the specified parameters.
|
|
346
|
+
* @param params
|
|
347
|
+
* @returns
|
|
348
|
+
*/
|
|
349
|
+
reuseRenderOp(node: CoreNode): boolean {
|
|
350
|
+
const curRenderOp = this.curRenderOp;
|
|
351
|
+
if (curRenderOp === null) {
|
|
352
|
+
return false;
|
|
353
|
+
}
|
|
354
|
+
|
|
355
|
+
const shader = node.props.shader as WebGlShaderNode;
|
|
356
|
+
const curShader = curRenderOp.shader as WebGlShaderNode;
|
|
357
|
+
|
|
358
|
+
if (curShader?.shaderKey !== shader?.shaderKey) {
|
|
359
|
+
return false;
|
|
360
|
+
}
|
|
361
|
+
|
|
362
|
+
// Switching clipping rect will require a new render operation
|
|
363
|
+
if (compareRect(curRenderOp.clippingRect, node.clippingRect) === false) {
|
|
364
|
+
return false;
|
|
365
|
+
}
|
|
366
|
+
|
|
367
|
+
// Force new render operation if rendering to texture is different
|
|
368
|
+
const curRtt = curRenderOp.rtt;
|
|
369
|
+
if (
|
|
370
|
+
curRenderOp.parentHasRenderTexture !== node.parentHasRenderTexture ||
|
|
371
|
+
curRtt !== (node.props.rtt === true)
|
|
372
|
+
) {
|
|
373
|
+
return false;
|
|
374
|
+
}
|
|
375
|
+
|
|
376
|
+
if (
|
|
377
|
+
node.parentHasRenderTexture === true &&
|
|
378
|
+
node.parentFramebufferDimensions !== null
|
|
379
|
+
) {
|
|
380
|
+
const curFbDims = curRenderOp.isCoreNode
|
|
381
|
+
? curRenderOp.parentFramebufferDimensions
|
|
382
|
+
: curRenderOp.framebufferDimensions;
|
|
383
|
+
if (
|
|
384
|
+
curFbDims === null ||
|
|
385
|
+
curFbDims.w !== node.parentFramebufferDimensions.w ||
|
|
386
|
+
curFbDims.h !== node.parentFramebufferDimensions.h
|
|
387
|
+
) {
|
|
388
|
+
return false;
|
|
389
|
+
}
|
|
390
|
+
}
|
|
391
|
+
|
|
392
|
+
if (curShader?.shaderKey === 'default' && shader?.shaderKey === 'default') {
|
|
393
|
+
return true;
|
|
394
|
+
}
|
|
395
|
+
|
|
396
|
+
// Check if the shader can batch the shader properties
|
|
397
|
+
if (curShader?.program.reuseRenderOp(node, curRenderOp) === false) {
|
|
398
|
+
return false;
|
|
399
|
+
}
|
|
400
|
+
|
|
401
|
+
return true;
|
|
402
|
+
}
|
|
403
|
+
|
|
404
|
+
/**
|
|
405
|
+
* add RenderOp to the render pipeline
|
|
406
|
+
*/
|
|
407
|
+
addRenderOp(renderable: WebGlRenderOp) {
|
|
408
|
+
this.renderOps.push(renderable);
|
|
409
|
+
this.curRenderOp = null;
|
|
410
|
+
}
|
|
411
|
+
|
|
412
|
+
/**
|
|
413
|
+
* Render the current set of RenderOps to render to the specified surface.
|
|
414
|
+
*
|
|
415
|
+
* TODO: 'screen' is the only supported surface at the moment.
|
|
416
|
+
*
|
|
417
|
+
* @param surface
|
|
418
|
+
*/
|
|
419
|
+
render(surface: 'screen' | CoreContextTexture = 'screen'): void {
|
|
420
|
+
const { glw, quadBuffer } = this;
|
|
421
|
+
|
|
422
|
+
const arr = new Float32Array(quadBuffer, 0, this.curBufferIdx);
|
|
423
|
+
|
|
424
|
+
const buffer = this.quadBufferCollection.getBuffer('a_position') || null;
|
|
425
|
+
glw.arrayBufferData(buffer, arr, glw.STATIC_DRAW);
|
|
426
|
+
|
|
427
|
+
for (let i = 0, length = this.renderOps.length; i < length; i++) {
|
|
428
|
+
this.renderOps[i]!.draw(this);
|
|
429
|
+
}
|
|
430
|
+
|
|
431
|
+
this.quadBufferUsage = this.curBufferIdx * arr.BYTES_PER_ELEMENT;
|
|
432
|
+
|
|
433
|
+
// Calculate the size of each quad in bytes (4 vertices per quad) times the size of each vertex in bytes
|
|
434
|
+
const QUAD_SIZE_IN_BYTES = 4 * (8 * arr.BYTES_PER_ELEMENT); // 8 attributes per vertex
|
|
435
|
+
this.numQuadsRendered = this.quadBufferUsage / QUAD_SIZE_IN_BYTES;
|
|
436
|
+
}
|
|
437
|
+
|
|
438
|
+
getQuadCount(): number {
|
|
439
|
+
return this.numQuadsRendered;
|
|
440
|
+
}
|
|
441
|
+
|
|
442
|
+
renderToTexture(node: CoreNode) {
|
|
443
|
+
for (let i = 0; i < this.rttNodes.length; i++) {
|
|
444
|
+
if (this.rttNodes[i] === node) {
|
|
445
|
+
return;
|
|
446
|
+
}
|
|
447
|
+
}
|
|
448
|
+
|
|
449
|
+
this.insertRTTNodeInOrder(node);
|
|
450
|
+
}
|
|
451
|
+
|
|
452
|
+
/**
|
|
453
|
+
* Inserts an RTT node into `this.rttNodes` while maintaining the correct rendering order based on hierarchy.
|
|
454
|
+
*
|
|
455
|
+
* Rendering order for RTT nodes is critical when nested RTT nodes exist in a parent-child relationship.
|
|
456
|
+
* Specifically:
|
|
457
|
+
* - Child RTT nodes must be rendered before their RTT-enabled parents to ensure proper texture composition.
|
|
458
|
+
* - If an RTT node is added and it has existing RTT children, it should be rendered after those children.
|
|
459
|
+
*
|
|
460
|
+
* This function addresses both cases by:
|
|
461
|
+
* 1. **Checking Upwards**: It traverses the node's hierarchy upwards to identify any RTT parent
|
|
462
|
+
* already in `rttNodes`. If an RTT parent is found, the new node is placed before this parent.
|
|
463
|
+
* 2. **Checking Downwards**: It traverses the node’s children recursively to find any RTT-enabled
|
|
464
|
+
* children that are already in `rttNodes`. If such children are found, the new node is inserted
|
|
465
|
+
* after the last (highest index) RTT child node.
|
|
466
|
+
*
|
|
467
|
+
* The final calculated insertion index ensures the new node is positioned in `rttNodes` to respect
|
|
468
|
+
* both parent-before-child and child-before-parent rendering rules, preserving the correct order
|
|
469
|
+
* for the WebGL renderer.
|
|
470
|
+
*
|
|
471
|
+
* @param node - The RTT-enabled CoreNode to be added to `rttNodes` in the appropriate hierarchical position.
|
|
472
|
+
*/
|
|
473
|
+
private insertRTTNodeInOrder(node: CoreNode) {
|
|
474
|
+
let insertIndex = this.rttNodes.length; // Default to the end of the array
|
|
475
|
+
|
|
476
|
+
// 1. Traverse upwards to ensure the node is placed before its RTT parent (if any).
|
|
477
|
+
let currentNode: CoreNode = node;
|
|
478
|
+
while (currentNode) {
|
|
479
|
+
if (!currentNode.parent) {
|
|
480
|
+
break;
|
|
481
|
+
}
|
|
482
|
+
|
|
483
|
+
const parentIndex = this.rttNodes.indexOf(currentNode.parent);
|
|
484
|
+
if (parentIndex !== -1) {
|
|
485
|
+
// Found an RTT parent in the list; set insertIndex to place node before the parent
|
|
486
|
+
insertIndex = parentIndex;
|
|
487
|
+
break;
|
|
488
|
+
}
|
|
489
|
+
|
|
490
|
+
currentNode = currentNode.parent;
|
|
491
|
+
}
|
|
492
|
+
|
|
493
|
+
// 2. Traverse downwards to ensure the node is placed after any RTT children.
|
|
494
|
+
// Look through each child recursively to see if any are already in rttNodes.
|
|
495
|
+
const maxChildIndex = this.findMaxChildRTTIndex(node);
|
|
496
|
+
if (maxChildIndex !== -1) {
|
|
497
|
+
// Adjust insertIndex to be after the last child RTT node
|
|
498
|
+
insertIndex = Math.max(insertIndex, maxChildIndex + 1);
|
|
499
|
+
}
|
|
500
|
+
|
|
501
|
+
// 3. Insert the node at the calculated position
|
|
502
|
+
this.rttNodes.splice(insertIndex, 0, node);
|
|
503
|
+
}
|
|
504
|
+
|
|
505
|
+
// Helper function to find the highest index of any RTT children of a node within rttNodes
|
|
506
|
+
private findMaxChildRTTIndex(node: CoreNode): number {
|
|
507
|
+
let maxIndex = -1;
|
|
508
|
+
|
|
509
|
+
const traverseChildren = (currentNode: CoreNode) => {
|
|
510
|
+
const currentIndex = this.rttNodes.indexOf(currentNode);
|
|
511
|
+
if (currentIndex !== -1) {
|
|
512
|
+
maxIndex = Math.max(maxIndex, currentIndex);
|
|
513
|
+
}
|
|
514
|
+
|
|
515
|
+
// Recursively check all children of the current node
|
|
516
|
+
for (const child of currentNode.children) {
|
|
517
|
+
traverseChildren(child);
|
|
518
|
+
}
|
|
519
|
+
};
|
|
520
|
+
|
|
521
|
+
// Start traversal directly with the provided node
|
|
522
|
+
traverseChildren(node);
|
|
523
|
+
|
|
524
|
+
return maxIndex;
|
|
525
|
+
}
|
|
526
|
+
|
|
527
|
+
renderRTTNodes() {
|
|
528
|
+
const { glw } = this;
|
|
529
|
+
// Render all associated RTT nodes to their textures
|
|
530
|
+
for (let i = 0; i < this.rttNodes.length; i++) {
|
|
531
|
+
const node = this.rttNodes[i];
|
|
532
|
+
|
|
533
|
+
// Skip nodes that don't have RTT updates
|
|
534
|
+
if (node === undefined || node.hasRTTupdates === false) {
|
|
535
|
+
continue;
|
|
536
|
+
}
|
|
537
|
+
|
|
538
|
+
// Skip nodes that are not visible
|
|
539
|
+
if (
|
|
540
|
+
node.worldAlpha === 0 ||
|
|
541
|
+
node.renderState === CoreNodeRenderState.OutOfBounds
|
|
542
|
+
) {
|
|
543
|
+
continue;
|
|
544
|
+
}
|
|
545
|
+
|
|
546
|
+
// Skip nodes that do not have a loaded texture
|
|
547
|
+
if (node.texture === null || node.texture.state !== 'loaded') {
|
|
548
|
+
continue;
|
|
549
|
+
}
|
|
550
|
+
|
|
551
|
+
// Set the active RTT node to the current node
|
|
552
|
+
// So we can prevent rendering children of nested RTT nodes
|
|
553
|
+
this.activeRttNode = node;
|
|
554
|
+
const ctxTexture = node.texture.ctxTexture as WebGlCtxRenderTexture;
|
|
555
|
+
this.renderToTextureActive = true;
|
|
556
|
+
|
|
557
|
+
// Bind the the texture's framebuffer
|
|
558
|
+
glw.bindFramebuffer(ctxTexture.framebuffer);
|
|
559
|
+
|
|
560
|
+
glw.viewport(0, 0, ctxTexture.w, ctxTexture.h);
|
|
561
|
+
// Set the clear color to transparent
|
|
562
|
+
glw.clearColor(0, 0, 0, 0);
|
|
563
|
+
glw.clear();
|
|
564
|
+
|
|
565
|
+
// Render all associated quads to the texture
|
|
566
|
+
for (let i = 0; i < node.children.length; i++) {
|
|
567
|
+
const child = node.children[i];
|
|
568
|
+
|
|
569
|
+
if (child === undefined) {
|
|
570
|
+
continue;
|
|
571
|
+
}
|
|
572
|
+
|
|
573
|
+
this.stage.addQuads(child);
|
|
574
|
+
child.hasRTTupdates = false;
|
|
575
|
+
}
|
|
576
|
+
|
|
577
|
+
// Render all associated quads to the texture
|
|
578
|
+
this.render();
|
|
579
|
+
|
|
580
|
+
// Reset render operations
|
|
581
|
+
this.renderOps.length = 0;
|
|
582
|
+
node.hasRTTupdates = false;
|
|
583
|
+
}
|
|
584
|
+
|
|
585
|
+
const clearColor = this.clearColor.normalized;
|
|
586
|
+
// Restore the default clear color
|
|
587
|
+
glw.clearColor(clearColor[0], clearColor[1], clearColor[2], clearColor[3]);
|
|
588
|
+
|
|
589
|
+
// Bind the default framebuffer
|
|
590
|
+
glw.bindFramebuffer(null);
|
|
591
|
+
|
|
592
|
+
glw.viewport(0, 0, this.glw.canvas.width, this.glw.canvas.height);
|
|
593
|
+
this.renderToTextureActive = false;
|
|
594
|
+
}
|
|
595
|
+
|
|
596
|
+
updateViewport(): void {
|
|
597
|
+
this.glw.viewport(0, 0, this.glw.canvas.width, this.glw.canvas.height);
|
|
598
|
+
}
|
|
599
|
+
|
|
600
|
+
removeRTTNode(node: CoreNode) {
|
|
601
|
+
const index = this.rttNodes.indexOf(node);
|
|
602
|
+
if (index === -1) {
|
|
603
|
+
return;
|
|
604
|
+
}
|
|
605
|
+
this.rttNodes.splice(index, 1);
|
|
606
|
+
}
|
|
607
|
+
|
|
608
|
+
getBufferInfo(): BufferInfo | null {
|
|
609
|
+
const bufferInfo: BufferInfo = {
|
|
610
|
+
totalAvailable: this.stage.options.quadBufferSize,
|
|
611
|
+
totalUsed: this.quadBufferUsage,
|
|
612
|
+
};
|
|
613
|
+
return bufferInfo;
|
|
614
|
+
}
|
|
615
|
+
|
|
616
|
+
getDefaultShaderNode(): WebGlShaderNode {
|
|
617
|
+
if (this.defaultShaderNode !== null) {
|
|
618
|
+
return this.defaultShaderNode as WebGlShaderNode;
|
|
619
|
+
}
|
|
620
|
+
this.stage.shManager.registerShaderType('default', Default);
|
|
621
|
+
this.defaultShaderNode = this.stage.shManager.createShader(
|
|
622
|
+
'default',
|
|
623
|
+
) as WebGlShaderNode;
|
|
624
|
+
return this.defaultShaderNode;
|
|
625
|
+
}
|
|
626
|
+
|
|
627
|
+
override getTextureCoords(node: CoreNode): TextureCoords | undefined {
|
|
628
|
+
const texture = node.texture;
|
|
629
|
+
if (texture === null) {
|
|
630
|
+
return undefined;
|
|
631
|
+
}
|
|
632
|
+
|
|
633
|
+
//this stuff needs to be properly moved to CtxSubTexture at some point in the future.
|
|
634
|
+
const ctxTexture =
|
|
635
|
+
(texture as SubTexture).parentTexture !== undefined
|
|
636
|
+
? (texture as SubTexture).parentTexture.ctxTexture
|
|
637
|
+
: texture.ctxTexture;
|
|
638
|
+
if (ctxTexture === undefined) {
|
|
639
|
+
return undefined;
|
|
640
|
+
}
|
|
641
|
+
|
|
642
|
+
const textureOptions = node.props.textureOptions;
|
|
643
|
+
|
|
644
|
+
//early exit for textures with no options unless its a subtexture
|
|
645
|
+
if (
|
|
646
|
+
texture.type !== TextureType.subTexture &&
|
|
647
|
+
textureOptions === undefined
|
|
648
|
+
) {
|
|
649
|
+
return (ctxTexture as WebGlCtxTexture).txCoords;
|
|
650
|
+
}
|
|
651
|
+
|
|
652
|
+
let { x1, x2, y1, y2 } = (ctxTexture as WebGlCtxTexture).txCoords;
|
|
653
|
+
if (texture.type === TextureType.subTexture) {
|
|
654
|
+
const { w: parentW, h: parentH } = (texture as SubTexture).parentTexture
|
|
655
|
+
.dimensions!;
|
|
656
|
+
const { x, y, w, h } = (texture as SubTexture).props;
|
|
657
|
+
x1 = x / parentW;
|
|
658
|
+
y1 = y / parentH;
|
|
659
|
+
x2 = x1 + w / parentW;
|
|
660
|
+
y2 = y1 + h / parentH;
|
|
661
|
+
}
|
|
662
|
+
|
|
663
|
+
const resizeMode = textureOptions.resizeMode;
|
|
664
|
+
if (
|
|
665
|
+
resizeMode !== undefined &&
|
|
666
|
+
resizeMode.type === 'cover' &&
|
|
667
|
+
texture.dimensions !== null
|
|
668
|
+
) {
|
|
669
|
+
const dimensions = texture.dimensions as Dimensions;
|
|
670
|
+
const w = node.props.w;
|
|
671
|
+
const h = node.props.h;
|
|
672
|
+
const scaleX = w / dimensions.w;
|
|
673
|
+
const scaleY = h / dimensions.h;
|
|
674
|
+
const scale = Math.max(scaleX, scaleY);
|
|
675
|
+
const precision = 1 / scale;
|
|
676
|
+
|
|
677
|
+
// Determine based on width
|
|
678
|
+
if (scaleX < scale) {
|
|
679
|
+
const desiredSize = precision * node.props.w;
|
|
680
|
+
x1 = (1 - desiredSize / dimensions.w) * (resizeMode.clipX ?? 0.5);
|
|
681
|
+
x2 = x1 + desiredSize / dimensions.w;
|
|
682
|
+
}
|
|
683
|
+
// Determine based on height
|
|
684
|
+
if (scaleY < scale) {
|
|
685
|
+
const desiredSize = precision * node.props.h;
|
|
686
|
+
y1 = (1 - desiredSize / dimensions.h) * (resizeMode.clipY ?? 0.5);
|
|
687
|
+
y2 = y1 + desiredSize / dimensions.h;
|
|
688
|
+
}
|
|
689
|
+
}
|
|
690
|
+
|
|
691
|
+
if (textureOptions.flipX === true) {
|
|
692
|
+
[x1, x2] = [x2, x1];
|
|
693
|
+
}
|
|
694
|
+
if (textureOptions.flipY === true) {
|
|
695
|
+
[y1, y2] = [y2, y1];
|
|
696
|
+
}
|
|
697
|
+
return {
|
|
698
|
+
x1,
|
|
699
|
+
y1,
|
|
700
|
+
x2,
|
|
701
|
+
y2,
|
|
702
|
+
};
|
|
703
|
+
}
|
|
704
|
+
|
|
705
|
+
/**
|
|
706
|
+
* Sets the glClearColor to the specified color. *
|
|
707
|
+
* @param color - The color to set as the clear color, represented as a 32-bit integer.
|
|
708
|
+
*/
|
|
709
|
+
updateClearColor(color: number) {
|
|
710
|
+
if (this.clearColor.raw === color) {
|
|
711
|
+
return;
|
|
712
|
+
}
|
|
713
|
+
const glw = this.glw;
|
|
714
|
+
const normalizedColor = getNormalizedRgbaComponents(color);
|
|
715
|
+
glw.clearColor(
|
|
716
|
+
normalizedColor[0],
|
|
717
|
+
normalizedColor[1],
|
|
718
|
+
normalizedColor[2],
|
|
719
|
+
normalizedColor[3],
|
|
720
|
+
);
|
|
721
|
+
this.clearColor = {
|
|
722
|
+
raw: color,
|
|
723
|
+
normalized: normalizedColor,
|
|
724
|
+
};
|
|
725
|
+
}
|
|
726
|
+
}
|