@lightningjs/renderer 3.0.0-beta2 → 3.0.0-beta21
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/README.md +16 -26
- 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 +2 -5
- package/dist/exports/index.js +1 -5
- package/dist/exports/index.js.map +1 -1
- package/dist/exports/utils.d.ts +2 -1
- package/dist/exports/utils.js +2 -1
- package/dist/exports/utils.js.map +1 -1
- 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 +13 -2
- 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 +124 -100
- package/dist/src/core/CoreNode.js +720 -472
- package/dist/src/core/CoreNode.js.map +1 -1
- package/dist/src/core/CoreShaderManager.d.ts +3 -5
- package/dist/src/core/CoreShaderManager.js.map +1 -1
- package/dist/src/core/CoreTextNode.d.ts +74 -87
- package/dist/src/core/CoreTextNode.js +355 -232
- package/dist/src/core/CoreTextNode.js.map +1 -1
- package/dist/src/core/CoreTextureManager.d.ts +25 -13
- package/dist/src/core/CoreTextureManager.js +80 -104
- package/dist/src/core/CoreTextureManager.js.map +1 -1
- package/dist/src/core/Stage.d.ts +93 -33
- package/dist/src/core/Stage.js +315 -151
- 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 +11 -4
- package/dist/src/core/TextureMemoryManager.js +128 -109
- 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 +8 -3
- package/dist/src/core/animations/CoreAnimation.js.map +1 -1
- package/dist/src/core/animations/CoreAnimationController.d.ts +1 -0
- package/dist/src/core/animations/CoreAnimationController.js +11 -4
- 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 +31 -12
- package/dist/src/core/lib/ImageWorker.js.map +1 -1
- package/dist/src/core/lib/WebGlContextWrapper.d.ts +41 -3
- package/dist/src/core/lib/WebGlContextWrapper.js +105 -28
- package/dist/src/core/lib/WebGlContextWrapper.js.map +1 -1
- package/dist/src/core/lib/collectionUtils.d.ts +5 -0
- package/dist/src/core/lib/collectionUtils.js +100 -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 +8 -2
- package/dist/src/core/lib/utils.js +43 -21
- package/dist/src/core/lib/utils.js.map +1 -1
- package/dist/src/core/lib/validateImageBitmap.d.ts +2 -1
- package/dist/src/core/lib/validateImageBitmap.js +4 -4
- package/dist/src/core/lib/validateImageBitmap.js.map +1 -1
- package/dist/src/core/platform.js +30 -5
- package/dist/src/core/platform.js.map +1 -1
- package/dist/src/core/platforms/Platform.d.ts +42 -0
- package/dist/src/{main-api/IRenderDriver.js → core/platforms/Platform.js} +4 -2
- package/dist/src/core/platforms/Platform.js.map +1 -0
- package/dist/src/core/platforms/web/WebPlatform.d.ts +10 -0
- package/dist/src/core/platforms/web/WebPlatform.js +87 -0
- package/dist/src/core/platforms/web/WebPlatform.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 +5 -30
- package/dist/src/core/renderers/CoreRenderer.js +1 -0
- package/dist/src/core/renderers/CoreRenderer.js.map +1 -1
- package/dist/src/core/renderers/CoreShaderNode.d.ts +12 -1
- package/dist/src/core/renderers/CoreShaderNode.js +26 -0
- package/dist/src/core/renderers/CoreShaderNode.js.map +1 -1
- package/dist/src/core/renderers/canvas/CanvasCoreTexture.d.ts +2 -1
- package/dist/src/core/renderers/canvas/CanvasCoreTexture.js +11 -9
- package/dist/src/core/renderers/canvas/CanvasCoreTexture.js.map +1 -1
- package/dist/src/core/renderers/canvas/CanvasRenderer.d.ts +4 -5
- package/dist/src/core/renderers/canvas/CanvasRenderer.js +65 -87
- 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 +3 -5
- 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/webgl/SdfRenderOp.d.ts +33 -0
- package/dist/src/core/renderers/webgl/SdfRenderOp.js +97 -0
- package/dist/src/core/renderers/webgl/SdfRenderOp.js.map +1 -0
- package/dist/src/core/renderers/webgl/WebGlCoreCtxRenderTexture.js +3 -0
- package/dist/src/core/renderers/webgl/WebGlCoreCtxRenderTexture.js.map +1 -1
- package/dist/src/core/renderers/webgl/WebGlCoreCtxTexture.d.ts +18 -6
- package/dist/src/core/renderers/webgl/WebGlCoreCtxTexture.js +87 -42
- package/dist/src/core/renderers/webgl/WebGlCoreCtxTexture.js.map +1 -1
- package/dist/src/core/renderers/webgl/WebGlCoreRenderOp.js +1 -1
- package/dist/src/core/renderers/webgl/WebGlCoreRenderer.js +53 -17
- package/dist/src/core/renderers/webgl/WebGlCoreRenderer.js.map +1 -1
- package/dist/src/core/renderers/webgl/WebGlCoreShader.d.ts +2 -7
- package/dist/src/core/renderers/webgl/WebGlCoreShader.js +21 -50
- package/dist/src/core/renderers/webgl/WebGlCoreShader.js.map +1 -1
- package/dist/src/core/renderers/webgl/WebGlCtxRenderTexture.d.ts +2 -0
- 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 +13 -0
- 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 +16 -6
- package/dist/src/core/renderers/webgl/WebGlCtxTexture.js +102 -52
- package/dist/src/core/renderers/webgl/WebGlCtxTexture.js.map +1 -1
- package/dist/src/core/renderers/webgl/WebGlRenderOp.d.ts +1 -1
- package/dist/src/core/renderers/webgl/WebGlRenderOp.js +11 -4
- package/dist/src/core/renderers/webgl/WebGlRenderOp.js.map +1 -1
- package/dist/src/core/renderers/webgl/WebGlRenderer.d.ts +11 -21
- package/dist/src/core/renderers/webgl/WebGlRenderer.js +168 -152
- package/dist/src/core/renderers/webgl/WebGlRenderer.js.map +1 -1
- package/dist/src/core/renderers/webgl/WebGlShaderNode.d.ts +2 -4
- package/dist/src/core/renderers/webgl/WebGlShaderNode.js +1 -4
- package/dist/src/core/renderers/webgl/WebGlShaderNode.js.map +1 -1
- package/dist/src/core/renderers/webgl/WebGlShaderProgram.d.ts +9 -7
- package/dist/src/core/renderers/webgl/WebGlShaderProgram.js +83 -43
- package/dist/src/core/renderers/webgl/WebGlShaderProgram.js.map +1 -1
- package/dist/src/core/renderers/webgl/shaders/DefaultShader.js +3 -6
- package/dist/src/core/renderers/webgl/shaders/DefaultShader.js.map +1 -1
- package/dist/src/core/renderers/webgl/shaders/DefaultShaderBatched.js +0 -11
- package/dist/src/core/renderers/webgl/shaders/DefaultShaderBatched.js.map +1 -1
- package/dist/src/core/renderers/webgl/shaders/DynamicShader.js +5 -10
- package/dist/src/core/renderers/webgl/shaders/DynamicShader.js.map +1 -1
- package/dist/src/core/renderers/webgl/shaders/RoundedRectangle.js +5 -10
- package/dist/src/core/renderers/webgl/shaders/RoundedRectangle.js.map +1 -1
- package/dist/src/core/renderers/webgl/shaders/SdfShader.js +0 -12
- package/dist/src/core/renderers/webgl/shaders/SdfShader.js.map +1 -1
- package/dist/src/core/renderers/webgl/shaders/effects/BorderBottomEffect.js +1 -1
- package/dist/src/core/renderers/webgl/shaders/effects/BorderLeftEffect.js +1 -1
- package/dist/src/core/renderers/webgl/shaders/effects/BorderRightEffect.js +1 -1
- package/dist/src/core/renderers/webgl/shaders/effects/BorderTopEffect.js +1 -1
- package/dist/src/core/renderers/webgl/shaders/effects/FadeOutEffect.js +5 -5
- package/dist/src/core/renderers/webgl/shaders/effects/HolePunchEffect.js +1 -1
- package/dist/src/core/renderers/webgl/shaders/effects/LinearGradientEffect.js +24 -19
- package/dist/src/core/renderers/webgl/shaders/effects/LinearGradientEffect.js.map +1 -1
- package/dist/src/core/renderers/webgl/shaders/effects/RadialGradientEffect.d.ts +1 -0
- package/dist/src/core/renderers/webgl/shaders/effects/RadialGradientEffect.js +32 -5
- package/dist/src/core/renderers/webgl/shaders/effects/RadialGradientEffect.js.map +1 -1
- package/dist/src/core/renderers/webgl/shaders/effects/RadialProgressEffect.js +1 -1
- package/dist/src/core/renderers/webgl/shaders/effects/RadiusEffect.js +5 -5
- 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 +11 -7
- package/dist/src/core/shaders/canvas/LinearGradient.js.map +1 -1
- package/dist/src/core/shaders/canvas/RadialGradient.js +21 -17
- 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 +45 -7
- 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 +50 -11
- package/dist/src/core/shaders/canvas/RoundedWithBorderAndShadow.js.map +1 -1
- package/dist/src/core/shaders/canvas/RoundedWithShadow.js +10 -7
- 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 +12 -2
- package/dist/src/core/shaders/templates/BorderTemplate.js +31 -11
- 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 +3 -3
- 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/templates/RoundedTemplate.js +1 -1
- package/dist/src/core/shaders/templates/RoundedTemplate.js.map +1 -1
- package/dist/src/core/shaders/templates/RoundedWithBorderAndShadowTemplate.d.ts +1 -1
- package/dist/src/core/shaders/templates/RoundedWithBorderTemplate.d.ts +1 -1
- package/dist/src/core/shaders/templates/RoundedWithShadowTemplate.d.ts +1 -1
- package/dist/src/core/shaders/templates/ShadowTemplate.d.ts +1 -1
- package/dist/src/core/shaders/{templates/shaderUtils.d.ts → utils.d.ts} +1 -1
- package/dist/src/core/shaders/{templates/shaderUtils.js → utils.js} +2 -2
- package/dist/src/core/shaders/utils.js.map +1 -0
- package/dist/src/core/shaders/webgl/Border.js +116 -35
- package/dist/src/core/shaders/webgl/Border.js.map +1 -1
- package/dist/src/core/shaders/webgl/Default.js +6 -7
- package/dist/src/core/shaders/webgl/Default.js.map +1 -1
- package/dist/src/core/shaders/webgl/HolePunch.js +4 -3
- package/dist/src/core/shaders/webgl/HolePunch.js.map +1 -1
- package/dist/src/core/shaders/webgl/LinearGradient.js +33 -8
- package/dist/src/core/shaders/webgl/LinearGradient.js.map +1 -1
- package/dist/src/core/shaders/webgl/RadialGradient.js +56 -32
- package/dist/src/core/shaders/webgl/RadialGradient.js.map +1 -1
- package/dist/src/core/shaders/webgl/Rounded.js +4 -2
- package/dist/src/core/shaders/webgl/Rounded.js.map +1 -1
- package/dist/src/core/shaders/webgl/RoundedWithBorder.js +153 -39
- package/dist/src/core/shaders/webgl/RoundedWithBorder.js.map +1 -1
- package/dist/src/core/shaders/webgl/RoundedWithBorderAndShadow.js +158 -43
- package/dist/src/core/shaders/webgl/RoundedWithBorderAndShadow.js.map +1 -1
- package/dist/src/core/shaders/webgl/RoundedWithShadow.js +6 -4
- 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 +7 -17
- 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 +12 -6
- package/dist/src/core/shaders/webgl/Shadow.js.map +1 -1
- 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/SdfFontHandler.d.ts +182 -0
- package/dist/src/core/text-rendering/SdfFontHandler.js +391 -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 +303 -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/dist/src/{main-api/ICoreDriver.js → core/text-rendering/TextRenderer.js} +1 -1
- 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/LightningTextTextureRenderer.d.ts +0 -6
- 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 +35 -38
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.js.map +1 -1
- package/dist/src/core/text-rendering/renderers/TextRenderer.d.ts +4 -1
- 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 +11 -4
- package/dist/src/core/textures/ImageTexture.js +31 -40
- 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 +19 -37
- package/dist/src/core/textures/SubTexture.js.map +1 -1
- package/dist/src/core/textures/Texture.d.ts +87 -10
- package/dist/src/core/textures/Texture.js +160 -17
- 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/INode.d.ts +2 -2
- package/dist/src/main-api/Inspector.d.ts +131 -2
- package/dist/src/main-api/Inspector.js +345 -28
- package/dist/src/main-api/Inspector.js.map +1 -1
- package/dist/src/main-api/Renderer.d.ts +295 -82
- package/dist/src/main-api/Renderer.js +223 -76
- package/dist/src/main-api/Renderer.js.map +1 -1
- package/dist/src/utils.d.ts +1 -6
- package/dist/src/utils.js +2 -9
- package/dist/src/utils.js.map +1 -1
- package/dist/tsconfig.dist.tsbuildinfo +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/exports/canvas.ts +1 -1
- package/exports/index.ts +2 -8
- package/exports/utils.ts +7 -1
- package/exports/webgl.ts +3 -1
- package/package.json +15 -17
- package/src/common/CommonTypes.ts +18 -2
- package/src/core/Autosizer.ts +224 -0
- package/src/core/CoreNode.test.ts +179 -17
- package/src/core/CoreNode.ts +895 -599
- package/src/core/CoreShaderManager.ts +5 -10
- package/src/core/CoreTextNode.ts +422 -286
- package/src/core/CoreTextureManager.ts +110 -130
- package/src/core/Stage.ts +397 -195
- package/src/core/TextureError.ts +46 -0
- package/src/core/TextureMemoryManager.ts +164 -141
- package/src/core/animations/CoreAnimation.ts +15 -9
- package/src/core/animations/CoreAnimationController.ts +13 -4
- package/src/core/lib/ImageWorker.ts +43 -12
- package/src/core/lib/WebGlContextWrapper.ts +127 -79
- package/src/core/lib/collectionUtils.ts +118 -0
- package/src/core/lib/colorCache.ts +20 -0
- package/src/core/{renderers/canvas/internal/ColorUtils.ts → lib/colorParser.ts} +2 -2
- package/src/core/lib/textureCompression.ts +433 -75
- package/src/core/lib/utils.ts +54 -25
- package/src/core/lib/validateImageBitmap.ts +17 -6
- package/src/core/platforms/Platform.ts +83 -0
- package/src/core/platforms/web/WebPlatform.ts +132 -0
- package/src/core/renderers/CoreContextTexture.ts +2 -1
- package/src/core/renderers/CoreRenderer.ts +5 -32
- package/src/core/renderers/CoreShaderNode.ts +38 -3
- package/src/core/renderers/canvas/CanvasRenderer.ts +84 -126
- package/src/core/renderers/canvas/CanvasShaderNode.ts +4 -8
- package/src/core/renderers/canvas/CanvasTexture.ts +22 -18
- package/src/core/renderers/webgl/SdfRenderOp.ts +105 -0
- package/src/core/renderers/webgl/WebGlCtxRenderTexture.ts +18 -15
- package/src/core/renderers/webgl/WebGlCtxSubTexture.ts +50 -5
- package/src/core/renderers/webgl/WebGlCtxTexture.ts +134 -84
- package/src/core/renderers/webgl/WebGlRenderer.ts +203 -190
- package/src/core/renderers/webgl/WebGlShaderNode.ts +4 -11
- package/src/core/renderers/webgl/WebGlShaderProgram.ts +101 -53
- package/src/core/shaders/canvas/Border.ts +88 -34
- package/src/core/shaders/canvas/HolePunch.ts +5 -11
- package/src/core/shaders/canvas/LinearGradient.ts +14 -10
- package/src/core/shaders/canvas/RadialGradient.ts +24 -41
- package/src/core/shaders/canvas/Rounded.ts +7 -7
- package/src/core/shaders/canvas/RoundedWithBorder.ts +77 -23
- package/src/core/shaders/canvas/RoundedWithBorderAndShadow.ts +84 -36
- package/src/core/shaders/canvas/RoundedWithShadow.ts +15 -13
- package/src/core/shaders/canvas/Shadow.ts +7 -5
- package/src/core/shaders/canvas/utils/render.ts +45 -36
- package/src/core/shaders/templates/BorderTemplate.ts +42 -12
- package/src/core/shaders/templates/HolePunchTemplate.ts +5 -5
- package/src/core/shaders/templates/RadialGradientTemplate.ts +10 -8
- package/src/core/shaders/templates/RoundedTemplate.ts +1 -1
- package/src/core/shaders/templates/RoundedWithBorderAndShadowTemplate.ts +1 -1
- package/src/core/shaders/templates/RoundedWithBorderTemplate.ts +1 -1
- package/src/core/shaders/templates/RoundedWithShadowTemplate.ts +1 -1
- package/src/core/shaders/templates/ShadowTemplate.ts +1 -1
- package/src/core/shaders/{templates/shaderUtils.ts → utils.ts} +2 -3
- package/src/core/shaders/webgl/Border.ts +116 -39
- package/src/core/shaders/webgl/Default.ts +6 -7
- package/src/core/shaders/webgl/HolePunch.ts +4 -7
- package/src/core/shaders/webgl/LinearGradient.ts +33 -8
- package/src/core/shaders/webgl/RadialGradient.ts +58 -34
- package/src/core/shaders/webgl/Rounded.ts +4 -6
- package/src/core/shaders/webgl/RoundedWithBorder.ts +154 -46
- package/src/core/shaders/webgl/RoundedWithBorderAndShadow.ts +159 -52
- package/src/core/shaders/webgl/RoundedWithShadow.ts +6 -8
- package/src/core/shaders/webgl/SdfShader.ts +7 -19
- package/src/core/shaders/webgl/Shadow.ts +12 -6
- 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 +591 -0
- package/src/core/text-rendering/SdfTextRenderer.ts +408 -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 +7 -5
- package/src/core/textures/ImageTexture.ts +78 -66
- package/src/core/textures/NoiseTexture.ts +14 -12
- package/src/core/textures/RenderTexture.ts +18 -16
- package/src/core/textures/SubTexture.ts +25 -46
- package/src/core/textures/Texture.ts +207 -24
- package/src/core/utils.ts +9 -7
- package/src/main-api/INode.ts +4 -3
- package/src/main-api/Inspector.ts +577 -36
- package/src/main-api/Renderer.ts +518 -139
- package/src/utils.ts +10 -10
- package/dist/exports/core-api.d.ts +0 -74
- package/dist/exports/core-api.js +0 -96
- package/dist/exports/core-api.js.map +0 -1
- package/dist/exports/main-api.d.ts +0 -30
- package/dist/exports/main-api.js +0 -45
- package/dist/exports/main-api.js.map +0 -1
- package/dist/src/core/CoreExtension.d.ts +0 -12
- package/dist/src/core/CoreExtension.js +0 -29
- package/dist/src/core/CoreExtension.js.map +0 -1
- package/dist/src/core/CoreStuff.d.ts +0 -1
- package/dist/src/core/CoreStuff.js +0 -138
- package/dist/src/core/CoreStuff.js.map +0 -1
- package/dist/src/core/CoreTexturizer.d.ts +0 -14
- package/dist/src/core/CoreTexturizer.js +0 -47
- package/dist/src/core/CoreTexturizer.js.map +0 -1
- package/dist/src/core/LngNode.d.ts +0 -736
- package/dist/src/core/LngNode.js +0 -1174
- package/dist/src/core/LngNode.js.map +0 -1
- package/dist/src/core/Matrix2DContext.d.ts +0 -15
- package/dist/src/core/Matrix2DContext.js +0 -45
- package/dist/src/core/Matrix2DContext.js.map +0 -1
- package/dist/src/core/ShaderNode.d.ts +0 -10
- package/dist/src/core/ShaderNode.js +0 -30
- package/dist/src/core/ShaderNode.js.map +0 -1
- package/dist/src/core/TextNode.d.ts +0 -103
- package/dist/src/core/TextNode.js +0 -331
- package/dist/src/core/TextNode.js.map +0 -1
- package/dist/src/core/lib/Coords.d.ts +0 -14
- package/dist/src/core/lib/Coords.js +0 -55
- package/dist/src/core/lib/Coords.js.map +0 -1
- package/dist/src/core/lib/glm/common.d.ts +0 -162
- package/dist/src/core/lib/glm/common.js +0 -81
- package/dist/src/core/lib/glm/common.js.map +0 -1
- package/dist/src/core/lib/glm/index.d.ts +0 -11
- package/dist/src/core/lib/glm/index.js +0 -30
- package/dist/src/core/lib/glm/index.js.map +0 -1
- package/dist/src/core/lib/glm/mat2.d.ts +0 -219
- package/dist/src/core/lib/glm/mat2.js +0 -396
- package/dist/src/core/lib/glm/mat2.js.map +0 -1
- package/dist/src/core/lib/glm/mat2d.d.ts +0 -237
- package/dist/src/core/lib/glm/mat2d.js +0 -442
- package/dist/src/core/lib/glm/mat2d.js.map +0 -1
- package/dist/src/core/lib/glm/mat3.d.ts +0 -283
- package/dist/src/core/lib/glm/mat3.js +0 -680
- package/dist/src/core/lib/glm/mat3.js.map +0 -1
- package/dist/src/core/lib/glm/mat4.d.ts +0 -550
- package/dist/src/core/lib/glm/mat4.js +0 -1802
- package/dist/src/core/lib/glm/mat4.js.map +0 -1
- package/dist/src/core/lib/glm/quat.d.ts +0 -363
- package/dist/src/core/lib/glm/quat.js +0 -693
- package/dist/src/core/lib/glm/quat.js.map +0 -1
- package/dist/src/core/lib/glm/quat2.d.ts +0 -356
- package/dist/src/core/lib/glm/quat2.js +0 -754
- package/dist/src/core/lib/glm/quat2.js.map +0 -1
- package/dist/src/core/lib/glm/vec2.d.ts +0 -365
- package/dist/src/core/lib/glm/vec2.js +0 -569
- package/dist/src/core/lib/glm/vec2.js.map +0 -1
- package/dist/src/core/lib/glm/vec3.d.ts +0 -406
- package/dist/src/core/lib/glm/vec3.js +0 -720
- package/dist/src/core/lib/glm/vec3.js.map +0 -1
- package/dist/src/core/lib/glm/vec4.d.ts +0 -330
- package/dist/src/core/lib/glm/vec4.js +0 -608
- package/dist/src/core/lib/glm/vec4.js.map +0 -1
- package/dist/src/core/renderers/CoreShaderManager.d.ts +0 -19
- package/dist/src/core/renderers/CoreShaderManager.js +0 -33
- package/dist/src/core/renderers/CoreShaderManager.js.map +0 -1
- package/dist/src/core/renderers/webgl/WebGlCoreShaderManager.d.ts +0 -27
- package/dist/src/core/renderers/webgl/WebGlCoreShaderManager.js +0 -82
- package/dist/src/core/renderers/webgl/WebGlCoreShaderManager.js.map +0 -1
- package/dist/src/core/renderers/webgl/WebGlCoreShaderProgram.d.ts +0 -11
- package/dist/src/core/renderers/webgl/WebGlCoreShaderProgram.js +0 -34
- package/dist/src/core/renderers/webgl/WebGlCoreShaderProgram.js.map +0 -1
- package/dist/src/core/scene/Scene.d.ts +0 -59
- package/dist/src/core/scene/Scene.js +0 -106
- package/dist/src/core/scene/Scene.js.map +0 -1
- package/dist/src/core/shaders/templates/shaderUtils.js.map +0 -1
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/makeRenderWindow.d.ts +0 -20
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/makeRenderWindow.js +0 -55
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/makeRenderWindow.js.map +0 -1
- package/dist/src/main-api/ICoreDriver.d.ts +0 -27
- package/dist/src/main-api/ICoreDriver.js.map +0 -1
- package/dist/src/main-api/IRenderDriver.d.ts +0 -20
- package/dist/src/main-api/IRenderDriver.js.map +0 -1
- package/dist/src/main-api/IShaderController.d.ts +0 -14
- package/dist/src/main-api/IShaderController.js +0 -30
- package/dist/src/main-api/IShaderController.js.map +0 -1
- package/dist/src/main-api/IShaderNode.d.ts +0 -17
- package/dist/src/main-api/IShaderNode.js +0 -19
- package/dist/src/main-api/IShaderNode.js.map +0 -1
- package/dist/src/main-api/RendererMain.d.ts +0 -375
- package/dist/src/main-api/RendererMain.js +0 -365
- package/dist/src/main-api/RendererMain.js.map +0 -1
- package/dist/src/main-api/texture-usage-trackers/FinalizationRegistryTextureUsageTracker.d.ts +0 -9
- package/dist/src/main-api/texture-usage-trackers/FinalizationRegistryTextureUsageTracker.js +0 -38
- package/dist/src/main-api/texture-usage-trackers/FinalizationRegistryTextureUsageTracker.js.map +0 -1
- package/dist/src/main-api/texture-usage-trackers/ManualCountTextureUsageTracker.d.ts +0 -56
- package/dist/src/main-api/texture-usage-trackers/ManualCountTextureUsageTracker.js +0 -101
- package/dist/src/main-api/texture-usage-trackers/ManualCountTextureUsageTracker.js.map +0 -1
- package/dist/src/main-api/texture-usage-trackers/TextureUsageTracker.d.ts +0 -32
- package/dist/src/main-api/texture-usage-trackers/TextureUsageTracker.js +0 -28
- package/dist/src/main-api/texture-usage-trackers/TextureUsageTracker.js.map +0 -1
- package/dist/src/render-drivers/main/MainCoreDriver.d.ts +0 -24
- package/dist/src/render-drivers/main/MainCoreDriver.js +0 -118
- package/dist/src/render-drivers/main/MainCoreDriver.js.map +0 -1
- package/dist/src/render-drivers/main/MainOnlyNode.d.ts +0 -99
- package/dist/src/render-drivers/main/MainOnlyNode.js +0 -396
- package/dist/src/render-drivers/main/MainOnlyNode.js.map +0 -1
- package/dist/src/render-drivers/main/MainOnlyShaderController.d.ts +0 -6
- package/dist/src/render-drivers/main/MainOnlyShaderController.js +0 -15
- package/dist/src/render-drivers/main/MainOnlyShaderController.js.map +0 -1
- package/dist/src/render-drivers/main/MainOnlyShaderNode.d.ts +0 -7
- package/dist/src/render-drivers/main/MainOnlyShaderNode.js +0 -34
- package/dist/src/render-drivers/main/MainOnlyShaderNode.js.map +0 -1
- package/dist/src/render-drivers/main/MainOnlyTextNode.d.ts +0 -47
- package/dist/src/render-drivers/main/MainOnlyTextNode.js +0 -205
- package/dist/src/render-drivers/main/MainOnlyTextNode.js.map +0 -1
- package/dist/src/render-drivers/main/MainRenderDriver.d.ts +0 -17
- package/dist/src/render-drivers/main/MainRenderDriver.js +0 -88
- package/dist/src/render-drivers/main/MainRenderDriver.js.map +0 -1
- package/dist/src/render-drivers/threadx/NodeStruct.d.ts +0 -90
- package/dist/src/render-drivers/threadx/NodeStruct.js +0 -281
- package/dist/src/render-drivers/threadx/NodeStruct.js.map +0 -1
- package/dist/src/render-drivers/threadx/SharedNode.d.ts +0 -39
- package/dist/src/render-drivers/threadx/SharedNode.js +0 -60
- package/dist/src/render-drivers/threadx/SharedNode.js.map +0 -1
- package/dist/src/render-drivers/threadx/TextNodeStruct.d.ts +0 -44
- package/dist/src/render-drivers/threadx/TextNodeStruct.js +0 -201
- package/dist/src/render-drivers/threadx/TextNodeStruct.js.map +0 -1
- package/dist/src/render-drivers/threadx/ThreadXCoreDriver.d.ts +0 -28
- package/dist/src/render-drivers/threadx/ThreadXCoreDriver.js +0 -234
- package/dist/src/render-drivers/threadx/ThreadXCoreDriver.js.map +0 -1
- package/dist/src/render-drivers/threadx/ThreadXMainAnimationController.d.ts +0 -20
- package/dist/src/render-drivers/threadx/ThreadXMainAnimationController.js +0 -84
- package/dist/src/render-drivers/threadx/ThreadXMainAnimationController.js.map +0 -1
- package/dist/src/render-drivers/threadx/ThreadXMainNode.d.ts +0 -44
- package/dist/src/render-drivers/threadx/ThreadXMainNode.js +0 -154
- package/dist/src/render-drivers/threadx/ThreadXMainNode.js.map +0 -1
- package/dist/src/render-drivers/threadx/ThreadXMainShaderController.d.ts +0 -6
- package/dist/src/render-drivers/threadx/ThreadXMainShaderController.js +0 -16
- package/dist/src/render-drivers/threadx/ThreadXMainShaderController.js.map +0 -1
- package/dist/src/render-drivers/threadx/ThreadXMainShaderNode.d.ts +0 -7
- package/dist/src/render-drivers/threadx/ThreadXMainShaderNode.js +0 -15
- package/dist/src/render-drivers/threadx/ThreadXMainShaderNode.js.map +0 -1
- package/dist/src/render-drivers/threadx/ThreadXMainTextNode.d.ts +0 -28
- package/dist/src/render-drivers/threadx/ThreadXMainTextNode.js +0 -55
- package/dist/src/render-drivers/threadx/ThreadXMainTextNode.js.map +0 -1
- package/dist/src/render-drivers/threadx/ThreadXRenderDriver.d.ts +0 -21
- package/dist/src/render-drivers/threadx/ThreadXRenderDriver.js +0 -198
- package/dist/src/render-drivers/threadx/ThreadXRenderDriver.js.map +0 -1
- package/dist/src/render-drivers/threadx/ThreadXRendererMessage.d.ts +0 -70
- package/dist/src/render-drivers/threadx/ThreadXRendererMessage.js +0 -32
- package/dist/src/render-drivers/threadx/ThreadXRendererMessage.js.map +0 -1
- package/dist/src/render-drivers/threadx/worker/ThreadXRendererNode.d.ts +0 -19
- package/dist/src/render-drivers/threadx/worker/ThreadXRendererNode.js +0 -177
- package/dist/src/render-drivers/threadx/worker/ThreadXRendererNode.js.map +0 -1
- package/dist/src/render-drivers/threadx/worker/ThreadXRendererTextNode.d.ts +0 -27
- package/dist/src/render-drivers/threadx/worker/ThreadXRendererTextNode.js +0 -108
- package/dist/src/render-drivers/threadx/worker/ThreadXRendererTextNode.js.map +0 -1
- package/dist/src/render-drivers/threadx/worker/renderer.d.ts +0 -1
- package/dist/src/render-drivers/threadx/worker/renderer.js +0 -145
- package/dist/src/render-drivers/threadx/worker/renderer.js.map +0 -1
- package/dist/src/render-drivers/utils.d.ts +0 -12
- package/dist/src/render-drivers/utils.js +0 -69
- package/dist/src/render-drivers/utils.js.map +0 -1
- package/scripts/please-use-pnpm.js +0 -13
- package/src/core/platform.ts +0 -64
- package/src/core/renderers/canvas/internal/C2DShaderUtils.ts +0 -220
- package/src/core/renderers/webgl/WebGlRenderOp.ts +0 -161
- package/src/core/text-rendering/TextRenderingUtils.ts +0 -36
- 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 -509
- package/src/core/text-rendering/renderers/LightningTextTextureRenderer.ts +0 -815
- package/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.ts +0 -840
- 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/constants.ts +0 -32
- 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/getUnicodeCodepoints.ts +0 -38
- package/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText.ts +0 -408
- 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/SdfTextRenderer/internal/util.ts +0 -40
- package/src/core/text-rendering/renderers/TextRenderer.ts +0 -550
package/src/core/lib/utils.ts
CHANGED
|
@@ -82,8 +82,8 @@ export function getRgbaString(color: RGBA) {
|
|
|
82
82
|
export interface Rect {
|
|
83
83
|
x: number;
|
|
84
84
|
y: number;
|
|
85
|
-
|
|
86
|
-
|
|
85
|
+
w: number;
|
|
86
|
+
h: number;
|
|
87
87
|
}
|
|
88
88
|
|
|
89
89
|
export interface RectWithValid extends Rect {
|
|
@@ -97,6 +97,11 @@ export interface Bound {
|
|
|
97
97
|
y2: number;
|
|
98
98
|
}
|
|
99
99
|
|
|
100
|
+
export interface Coord {
|
|
101
|
+
x: number;
|
|
102
|
+
y: number;
|
|
103
|
+
}
|
|
104
|
+
|
|
100
105
|
export interface BoundWithValid extends Bound {
|
|
101
106
|
valid: boolean;
|
|
102
107
|
}
|
|
@@ -154,15 +159,15 @@ export function convertBoundToRect(bound: Bound, out?: Rect): Rect {
|
|
|
154
159
|
if (out) {
|
|
155
160
|
out.x = bound.x1;
|
|
156
161
|
out.y = bound.y1;
|
|
157
|
-
out.
|
|
158
|
-
out.
|
|
162
|
+
out.w = bound.x2 - bound.x1;
|
|
163
|
+
out.h = bound.y2 - bound.y1;
|
|
159
164
|
return out;
|
|
160
165
|
}
|
|
161
166
|
return {
|
|
162
167
|
x: bound.x1,
|
|
163
168
|
y: bound.y1,
|
|
164
|
-
|
|
165
|
-
|
|
169
|
+
w: bound.x2 - bound.x1,
|
|
170
|
+
h: bound.y2 - bound.y1,
|
|
166
171
|
};
|
|
167
172
|
}
|
|
168
173
|
|
|
@@ -175,35 +180,35 @@ export function intersectRect<T extends Rect = Rect>(
|
|
|
175
180
|
export function intersectRect(a: Rect, b: Rect, out?: Rect): Rect {
|
|
176
181
|
const x = Math.max(a.x, b.x);
|
|
177
182
|
const y = Math.max(a.y, b.y);
|
|
178
|
-
const
|
|
179
|
-
const
|
|
180
|
-
if (
|
|
183
|
+
const w = Math.min(a.x + a.w, b.x + b.w) - x;
|
|
184
|
+
const h = Math.min(a.y + a.h, b.y + b.h) - y;
|
|
185
|
+
if (w > 0 && h > 0) {
|
|
181
186
|
if (out) {
|
|
182
187
|
out.x = x;
|
|
183
188
|
out.y = y;
|
|
184
|
-
out.
|
|
185
|
-
out.
|
|
189
|
+
out.w = w;
|
|
190
|
+
out.h = h;
|
|
186
191
|
return out;
|
|
187
192
|
}
|
|
188
193
|
return {
|
|
189
194
|
x,
|
|
190
195
|
y,
|
|
191
|
-
|
|
192
|
-
|
|
196
|
+
w,
|
|
197
|
+
h,
|
|
193
198
|
};
|
|
194
199
|
}
|
|
195
200
|
if (out) {
|
|
196
201
|
out.x = 0;
|
|
197
202
|
out.y = 0;
|
|
198
|
-
out.
|
|
199
|
-
out.
|
|
203
|
+
out.w = 0;
|
|
204
|
+
out.h = 0;
|
|
200
205
|
return out;
|
|
201
206
|
}
|
|
202
207
|
return {
|
|
203
208
|
x: 0,
|
|
204
209
|
y: 0,
|
|
205
|
-
|
|
206
|
-
|
|
210
|
+
w: 0,
|
|
211
|
+
h: 0,
|
|
207
212
|
};
|
|
208
213
|
}
|
|
209
214
|
|
|
@@ -213,15 +218,15 @@ export function copyRect(a: Rect, out?: Rect): Rect {
|
|
|
213
218
|
if (out) {
|
|
214
219
|
out.x = a.x;
|
|
215
220
|
out.y = a.y;
|
|
216
|
-
out.
|
|
217
|
-
out.
|
|
221
|
+
out.w = a.w;
|
|
222
|
+
out.h = a.h;
|
|
218
223
|
return out;
|
|
219
224
|
}
|
|
220
225
|
return {
|
|
221
226
|
x: a.x,
|
|
222
227
|
y: a.y,
|
|
223
|
-
|
|
224
|
-
|
|
228
|
+
w: a.w,
|
|
229
|
+
h: a.h,
|
|
225
230
|
};
|
|
226
231
|
}
|
|
227
232
|
|
|
@@ -232,9 +237,7 @@ export function compareRect(a: Rect | null, b: Rect | null): boolean {
|
|
|
232
237
|
if (a === null || b === null) {
|
|
233
238
|
return false;
|
|
234
239
|
}
|
|
235
|
-
return
|
|
236
|
-
a.x === b.x && a.y === b.y && a.width === b.width && a.height === b.height
|
|
237
|
-
);
|
|
240
|
+
return a.x === b.x && a.y === b.y && a.w === b.w && a.h === b.h;
|
|
238
241
|
}
|
|
239
242
|
|
|
240
243
|
export function boundInsideBound(bound1: Bound, bound2: Bound) {
|
|
@@ -255,12 +258,16 @@ export function boundLargeThanBound(bound1: Bound, bound2: Bound) {
|
|
|
255
258
|
);
|
|
256
259
|
}
|
|
257
260
|
|
|
261
|
+
export function pointInBound(x: number, y: number, bound: Bound) {
|
|
262
|
+
return !(x < bound.x1 || x > bound.x2 || y < bound.y1 || y > bound.y2);
|
|
263
|
+
}
|
|
264
|
+
|
|
258
265
|
export function isBoundPositive(bound: Bound): boolean {
|
|
259
266
|
return bound.x1 < bound.x2 && bound.y1 < bound.y2;
|
|
260
267
|
}
|
|
261
268
|
|
|
262
269
|
export function isRectPositive(rect: Rect): boolean {
|
|
263
|
-
return rect.
|
|
270
|
+
return rect.w > 0 && rect.h > 0;
|
|
264
271
|
}
|
|
265
272
|
|
|
266
273
|
/**
|
|
@@ -384,3 +391,25 @@ export function dataURIToBlob(dataURI: string): Blob {
|
|
|
384
391
|
}
|
|
385
392
|
return new Blob(byteArrays, { type });
|
|
386
393
|
}
|
|
394
|
+
|
|
395
|
+
export function fetchJson(
|
|
396
|
+
url: string,
|
|
397
|
+
responseType: XMLHttpRequestResponseType = '',
|
|
398
|
+
): Promise<unknown> {
|
|
399
|
+
return new Promise((resolve, reject) => {
|
|
400
|
+
const xhr = new XMLHttpRequest();
|
|
401
|
+
xhr.responseType = responseType;
|
|
402
|
+
xhr.onreadystatechange = function () {
|
|
403
|
+
if (xhr.readyState == XMLHttpRequest.DONE) {
|
|
404
|
+
// On most devices like WebOS and Tizen, the file protocol returns 0 while http(s) protocol returns 200
|
|
405
|
+
if (xhr.status === 0 || xhr.status === 200) {
|
|
406
|
+
resolve(xhr.response);
|
|
407
|
+
} else {
|
|
408
|
+
reject(xhr.statusText);
|
|
409
|
+
}
|
|
410
|
+
}
|
|
411
|
+
};
|
|
412
|
+
xhr.open('GET', url, true);
|
|
413
|
+
xhr.send(null);
|
|
414
|
+
});
|
|
415
|
+
}
|
|
@@ -1,10 +1,14 @@
|
|
|
1
|
+
import type { Platform } from '../platforms/Platform.js';
|
|
2
|
+
|
|
1
3
|
export interface CreateImageBitmapSupport {
|
|
2
4
|
basic: boolean; // Supports createImageBitmap(image)
|
|
3
5
|
options: boolean; // Supports createImageBitmap(image, options)
|
|
4
6
|
full: boolean; // Supports createImageBitmap(image, sx, sy, sw, sh, options)
|
|
5
7
|
}
|
|
6
8
|
|
|
7
|
-
export async function validateCreateImageBitmap(
|
|
9
|
+
export async function validateCreateImageBitmap(
|
|
10
|
+
platform: Platform,
|
|
11
|
+
): Promise<CreateImageBitmapSupport> {
|
|
8
12
|
// Test if createImageBitmap is supported using a simple 1x1 PNG image
|
|
9
13
|
// prettier-ignore
|
|
10
14
|
const pngBinaryData = new Uint8Array([
|
|
@@ -47,14 +51,14 @@ export async function validateCreateImageBitmap(): Promise<CreateImageBitmapSupp
|
|
|
47
51
|
|
|
48
52
|
// Test basic createImageBitmap support
|
|
49
53
|
const blob = new Blob([pngBinaryData], { type: 'image/png' });
|
|
50
|
-
const bitmap = await createImageBitmap(blob);
|
|
54
|
+
const bitmap = await platform.createImageBitmap(blob);
|
|
51
55
|
bitmap.close?.();
|
|
52
56
|
support.basic = true;
|
|
53
57
|
|
|
54
58
|
// Test createImageBitmap with options support
|
|
55
59
|
try {
|
|
56
60
|
const options = { premultiplyAlpha: 'none' as const };
|
|
57
|
-
const bitmapWithOptions = await createImageBitmap(blob, options);
|
|
61
|
+
const bitmapWithOptions = await platform.createImageBitmap(blob, options);
|
|
58
62
|
bitmapWithOptions.close?.();
|
|
59
63
|
support.options = true;
|
|
60
64
|
} catch (e) {
|
|
@@ -63,9 +67,16 @@ export async function validateCreateImageBitmap(): Promise<CreateImageBitmapSupp
|
|
|
63
67
|
|
|
64
68
|
// Test createImageBitmap with full options support
|
|
65
69
|
try {
|
|
66
|
-
const bitmapWithFullOptions = await createImageBitmap(
|
|
67
|
-
|
|
68
|
-
|
|
70
|
+
const bitmapWithFullOptions = await platform.createImageBitmap(
|
|
71
|
+
blob,
|
|
72
|
+
0,
|
|
73
|
+
0,
|
|
74
|
+
1,
|
|
75
|
+
1,
|
|
76
|
+
{
|
|
77
|
+
premultiplyAlpha: 'none',
|
|
78
|
+
},
|
|
79
|
+
);
|
|
69
80
|
bitmapWithFullOptions.close?.();
|
|
70
81
|
support.full = true;
|
|
71
82
|
} catch (e) {
|
|
@@ -0,0 +1,83 @@
|
|
|
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 { type Stage } from '../Stage.js';
|
|
21
|
+
|
|
22
|
+
export abstract class Platform {
|
|
23
|
+
/**
|
|
24
|
+
* Creates a new canvas element.
|
|
25
|
+
* @returns The created HTMLCanvasElement.
|
|
26
|
+
*/
|
|
27
|
+
abstract createCanvas(): HTMLCanvasElement;
|
|
28
|
+
|
|
29
|
+
/**
|
|
30
|
+
* Get a DOM element by ID
|
|
31
|
+
* @returns The DOM element (or null)
|
|
32
|
+
*/
|
|
33
|
+
abstract getElementById(id: string): HTMLElement | null;
|
|
34
|
+
|
|
35
|
+
/**
|
|
36
|
+
* Starts the main rendering loop, calling the provided update function every frame.
|
|
37
|
+
* @param Stage - The stage for rendering
|
|
38
|
+
*/
|
|
39
|
+
abstract startLoop(stage: Stage): void;
|
|
40
|
+
|
|
41
|
+
/**
|
|
42
|
+
* Abstracted createImageBitmap method.
|
|
43
|
+
* @param blob - The image source to create the ImageBitmap from.
|
|
44
|
+
* @param sxOrOptions - The source rectangle x coordinate or ImageBitmapOptions.
|
|
45
|
+
* @param sy - The source rectangle y coordinate.
|
|
46
|
+
* @param sw - The source rectangle width.
|
|
47
|
+
* @param sh - The source rectangle height.
|
|
48
|
+
* @param options - The ImageBitmapOptions.
|
|
49
|
+
* @returns A promise that resolves with the created ImageBitmap.
|
|
50
|
+
*/
|
|
51
|
+
abstract createImageBitmap(blob: ImageBitmapSource): Promise<ImageBitmap>;
|
|
52
|
+
abstract createImageBitmap(
|
|
53
|
+
blob: ImageBitmapSource,
|
|
54
|
+
options: ImageBitmapOptions,
|
|
55
|
+
): Promise<ImageBitmap>;
|
|
56
|
+
abstract createImageBitmap(
|
|
57
|
+
blob: ImageBitmapSource,
|
|
58
|
+
sx: number,
|
|
59
|
+
sy: number,
|
|
60
|
+
sw: number,
|
|
61
|
+
sh: number,
|
|
62
|
+
): Promise<ImageBitmap>;
|
|
63
|
+
abstract createImageBitmap(
|
|
64
|
+
blob: ImageBitmapSource,
|
|
65
|
+
sx: number,
|
|
66
|
+
sy: number,
|
|
67
|
+
sw: number,
|
|
68
|
+
sh: number,
|
|
69
|
+
options: ImageBitmapOptions,
|
|
70
|
+
): Promise<ImageBitmap>;
|
|
71
|
+
|
|
72
|
+
/**
|
|
73
|
+
* Retrieves the current timestamp.
|
|
74
|
+
* @returns The current timestamp.
|
|
75
|
+
*/
|
|
76
|
+
abstract getTimeStamp(): number;
|
|
77
|
+
|
|
78
|
+
/**
|
|
79
|
+
* Adds a FontFace to the platforms FontFaceSet
|
|
80
|
+
* @param font - The FontFace to add
|
|
81
|
+
*/
|
|
82
|
+
abstract addFont(font: FontFace): void;
|
|
83
|
+
}
|
|
@@ -0,0 +1,132 @@
|
|
|
1
|
+
import { Platform } from '../Platform.js';
|
|
2
|
+
import type { Stage } from '../../Stage.js';
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* make fontface add not show errors
|
|
6
|
+
*/
|
|
7
|
+
interface FontFaceSetWithAdd extends FontFaceSet {
|
|
8
|
+
add(font: FontFace): void;
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
export class WebPlatform extends Platform {
|
|
12
|
+
////////////////////////
|
|
13
|
+
// Platform-specific methods
|
|
14
|
+
////////////////////////
|
|
15
|
+
|
|
16
|
+
override createCanvas(): HTMLCanvasElement {
|
|
17
|
+
const canvas = document.createElement('canvas');
|
|
18
|
+
return canvas;
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
override getElementById(id: string): HTMLElement | null {
|
|
22
|
+
return document.getElementById(id);
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
////////////////////////
|
|
26
|
+
// Update loop
|
|
27
|
+
////////////////////////
|
|
28
|
+
|
|
29
|
+
override startLoop(stage: Stage): void {
|
|
30
|
+
let isIdle = false;
|
|
31
|
+
let lastFrameTime = 0;
|
|
32
|
+
|
|
33
|
+
const runLoop = (currentTime: number = 0) => {
|
|
34
|
+
const targetFrameTime = stage.targetFrameTime;
|
|
35
|
+
|
|
36
|
+
// Check if we should throttle this frame
|
|
37
|
+
if (
|
|
38
|
+
targetFrameTime > 0 &&
|
|
39
|
+
currentTime - lastFrameTime < targetFrameTime
|
|
40
|
+
) {
|
|
41
|
+
// Too early for next frame, schedule with setTimeout for precise timing
|
|
42
|
+
const delay = targetFrameTime - (currentTime - lastFrameTime);
|
|
43
|
+
setTimeout(() => requestAnimationFrame(runLoop), delay);
|
|
44
|
+
return;
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
stage.updateFrameTime();
|
|
48
|
+
stage.updateAnimations();
|
|
49
|
+
|
|
50
|
+
if (!stage.hasSceneUpdates()) {
|
|
51
|
+
// We still need to calculate the fps else it looks like the app is frozen
|
|
52
|
+
stage.calculateFps();
|
|
53
|
+
|
|
54
|
+
if (targetFrameTime > 0) {
|
|
55
|
+
// Use setTimeout for throttled idle frames
|
|
56
|
+
setTimeout(
|
|
57
|
+
() => requestAnimationFrame(runLoop),
|
|
58
|
+
Math.max(targetFrameTime, 16.666666666666668),
|
|
59
|
+
);
|
|
60
|
+
} else {
|
|
61
|
+
// Use standard idle timeout when not throttling
|
|
62
|
+
setTimeout(() => requestAnimationFrame(runLoop), 16.666666666666668);
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
if (isIdle === false) {
|
|
66
|
+
stage.shManager.cleanup();
|
|
67
|
+
stage.eventBus.emit('idle');
|
|
68
|
+
isIdle = true;
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
if (stage.txMemManager.checkCleanup() === true) {
|
|
72
|
+
stage.txMemManager.cleanup();
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
stage.flushFrameEvents();
|
|
76
|
+
return;
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
isIdle = false;
|
|
80
|
+
stage.drawFrame();
|
|
81
|
+
stage.flushFrameEvents();
|
|
82
|
+
|
|
83
|
+
// Schedule next frame
|
|
84
|
+
if (targetFrameTime > 0) {
|
|
85
|
+
// Use setTimeout + rAF combination for precise FPS control
|
|
86
|
+
const nextFrameDelay = Math.max(
|
|
87
|
+
0,
|
|
88
|
+
targetFrameTime - (performance.now() - currentTime),
|
|
89
|
+
);
|
|
90
|
+
setTimeout(() => requestAnimationFrame(runLoop), nextFrameDelay);
|
|
91
|
+
} else {
|
|
92
|
+
// Use standard rAF when not throttling
|
|
93
|
+
requestAnimationFrame(runLoop);
|
|
94
|
+
}
|
|
95
|
+
};
|
|
96
|
+
requestAnimationFrame(runLoop);
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
////////////////////////
|
|
100
|
+
// ImageBitmap
|
|
101
|
+
////////////////////////
|
|
102
|
+
|
|
103
|
+
override createImageBitmap(
|
|
104
|
+
blob: ImageBitmapSource,
|
|
105
|
+
sxOrOptions?: number | ImageBitmapOptions,
|
|
106
|
+
sy?: number,
|
|
107
|
+
sw?: number,
|
|
108
|
+
sh?: number,
|
|
109
|
+
options?: ImageBitmapOptions,
|
|
110
|
+
): Promise<ImageBitmap> {
|
|
111
|
+
if (typeof sxOrOptions === 'number') {
|
|
112
|
+
return createImageBitmap(
|
|
113
|
+
blob,
|
|
114
|
+
sxOrOptions,
|
|
115
|
+
sy ?? 0,
|
|
116
|
+
sw ?? 0,
|
|
117
|
+
sh ?? 0,
|
|
118
|
+
options,
|
|
119
|
+
);
|
|
120
|
+
} else {
|
|
121
|
+
return createImageBitmap(blob, sxOrOptions);
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
|
|
125
|
+
getTimeStamp(): number {
|
|
126
|
+
return performance ? performance.now() : Date.now();
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
override addFont(font: FontFace): void {
|
|
130
|
+
(document.fonts as FontFaceSetWithAdd).add(font);
|
|
131
|
+
}
|
|
132
|
+
}
|
|
@@ -34,7 +34,8 @@ export abstract class CoreContextTexture {
|
|
|
34
34
|
this.memManager.setTextureMemUse(this.textureSource, byteSize);
|
|
35
35
|
}
|
|
36
36
|
|
|
37
|
-
abstract load(): void
|
|
37
|
+
abstract load(): Promise<void>;
|
|
38
|
+
abstract release(): void;
|
|
38
39
|
abstract free(): void;
|
|
39
40
|
|
|
40
41
|
get renderable(): boolean {
|
|
@@ -17,43 +17,14 @@
|
|
|
17
17
|
* limitations under the License.
|
|
18
18
|
*/
|
|
19
19
|
|
|
20
|
-
import type { Dimensions } from '../../common/CommonTypes.js';
|
|
21
20
|
import type { CoreNode } from '../CoreNode.js';
|
|
22
|
-
import type { TextureOptions } from '../CoreTextureManager.js';
|
|
23
21
|
import type { Stage } from '../Stage.js';
|
|
24
22
|
import type { ContextSpy } from '../lib/ContextSpy.js';
|
|
25
|
-
import type { RenderCoords } from '../lib/RenderCoords.js';
|
|
26
|
-
import type { RectWithValid } from '../lib/utils.js';
|
|
27
23
|
import type { CoreShaderProgram } from './CoreShaderProgram.js';
|
|
28
|
-
import type { Texture } from '../textures/Texture.js';
|
|
24
|
+
import type { Texture, TextureCoords } from '../textures/Texture.js';
|
|
29
25
|
import { CoreContextTexture } from './CoreContextTexture.js';
|
|
30
26
|
import type { CoreShaderType, CoreShaderNode } from './CoreShaderNode.js';
|
|
31
27
|
|
|
32
|
-
export interface QuadOptions {
|
|
33
|
-
width: number;
|
|
34
|
-
height: number;
|
|
35
|
-
colorTl: number;
|
|
36
|
-
colorTr: number;
|
|
37
|
-
colorBl: number;
|
|
38
|
-
colorBr: number;
|
|
39
|
-
texture: Texture | null;
|
|
40
|
-
textureOptions: TextureOptions | null;
|
|
41
|
-
zIndex: number;
|
|
42
|
-
shader: CoreShaderNode | null;
|
|
43
|
-
alpha: number;
|
|
44
|
-
clippingRect: RectWithValid;
|
|
45
|
-
tx: number;
|
|
46
|
-
ty: number;
|
|
47
|
-
ta: number;
|
|
48
|
-
tb: number;
|
|
49
|
-
tc: number;
|
|
50
|
-
td: number;
|
|
51
|
-
renderCoords?: RenderCoords;
|
|
52
|
-
rtt: boolean;
|
|
53
|
-
parentHasRenderTexture: boolean;
|
|
54
|
-
framebufferDimensions: Dimensions;
|
|
55
|
-
}
|
|
56
|
-
|
|
57
28
|
export interface CoreRendererOptions {
|
|
58
29
|
stage: Stage;
|
|
59
30
|
canvas: HTMLCanvasElement | OffscreenCanvas;
|
|
@@ -69,7 +40,7 @@ export interface BufferInfo {
|
|
|
69
40
|
export abstract class CoreRenderer {
|
|
70
41
|
public options: CoreRendererOptions;
|
|
71
42
|
public mode: 'webgl' | 'canvas' | undefined;
|
|
72
|
-
|
|
43
|
+
defaultTextureCoords: TextureCoords | undefined = undefined;
|
|
73
44
|
readonly stage: Stage;
|
|
74
45
|
|
|
75
46
|
//// Core Managers
|
|
@@ -82,7 +53,7 @@ export abstract class CoreRenderer {
|
|
|
82
53
|
|
|
83
54
|
abstract reset(): void;
|
|
84
55
|
abstract render(surface?: 'screen' | CoreContextTexture): void;
|
|
85
|
-
abstract addQuad(
|
|
56
|
+
abstract addQuad(node: CoreNode): void;
|
|
86
57
|
abstract createCtxTexture(textureSource: Texture): CoreContextTexture;
|
|
87
58
|
abstract createShaderProgram(
|
|
88
59
|
shaderConfig: Readonly<CoreShaderType>,
|
|
@@ -103,5 +74,7 @@ export abstract class CoreRenderer {
|
|
|
103
74
|
abstract renderToTexture(node: CoreNode): void;
|
|
104
75
|
abstract getBufferInfo(): BufferInfo | null;
|
|
105
76
|
abstract getQuadCount(): number | null;
|
|
77
|
+
abstract updateViewport(): void;
|
|
106
78
|
abstract updateClearColor(color: number): void;
|
|
79
|
+
getTextureCoords?(node: CoreNode): TextureCoords | undefined;
|
|
107
80
|
}
|
|
@@ -66,9 +66,7 @@ export function resolveShaderProps(
|
|
|
66
66
|
* You could view a ShaderType as a configuration object that contains methods,
|
|
67
67
|
* and values that you can use to alter the way a node is drawn by the Renderer.
|
|
68
68
|
*/
|
|
69
|
-
export interface CoreShaderType<
|
|
70
|
-
Props extends object = Record<string, unknown>,
|
|
71
|
-
> {
|
|
69
|
+
export interface CoreShaderType<Props extends object = any> {
|
|
72
70
|
/**
|
|
73
71
|
* Values you use to draw the Shader
|
|
74
72
|
*/
|
|
@@ -77,6 +75,11 @@ export interface CoreShaderType<
|
|
|
77
75
|
* used for making a cache key to check for reusability, currently only used for webgl ShaderTypes but might be needed for other types of renderer
|
|
78
76
|
*/
|
|
79
77
|
getCacheMarkers?: (props: Props) => string;
|
|
78
|
+
/**
|
|
79
|
+
* timer that updates every loop, by default uses the stage elapsed time If you want to do a special calculation you can define a function.
|
|
80
|
+
* When you calculate your own value you can use the Stage timing values deltaTime, lastFrameTime, and currentFrameTime;
|
|
81
|
+
*/
|
|
82
|
+
time?: boolean | ((stage: Stage) => number);
|
|
80
83
|
}
|
|
81
84
|
|
|
82
85
|
/**
|
|
@@ -91,7 +94,12 @@ export class CoreShaderNode<Props extends object = Record<string, unknown>> {
|
|
|
91
94
|
readonly resolvedProps: Props | undefined = undefined;
|
|
92
95
|
protected definedProps: Props | undefined = undefined;
|
|
93
96
|
protected node: CoreNode | null = null;
|
|
97
|
+
readonly time: CoreShaderType['time'] = undefined;
|
|
94
98
|
update: (() => void) | undefined = undefined;
|
|
99
|
+
private _valueKeyCache = '';
|
|
100
|
+
private _valueKeyDirty = true;
|
|
101
|
+
private _lastW = 0;
|
|
102
|
+
private _lastH = 0;
|
|
95
103
|
|
|
96
104
|
constructor(
|
|
97
105
|
readonly shaderKey: string,
|
|
@@ -101,6 +109,7 @@ export class CoreShaderNode<Props extends object = Record<string, unknown>> {
|
|
|
101
109
|
) {
|
|
102
110
|
this.stage = stage;
|
|
103
111
|
this.shaderType = type;
|
|
112
|
+
this.time = type.time;
|
|
104
113
|
|
|
105
114
|
if (props !== undefined) {
|
|
106
115
|
/**
|
|
@@ -136,6 +145,7 @@ export class CoreShaderNode<Props extends object = Record<string, unknown>> {
|
|
|
136
145
|
} else {
|
|
137
146
|
this.resolvedProps![key] = value;
|
|
138
147
|
}
|
|
148
|
+
this._valueKeyDirty = true;
|
|
139
149
|
|
|
140
150
|
if (this.update !== undefined && this.node !== null) {
|
|
141
151
|
this.node.setUpdateType(UpdateType.RecalcUniforms);
|
|
@@ -152,6 +162,31 @@ export class CoreShaderNode<Props extends object = Record<string, unknown>> {
|
|
|
152
162
|
this.node = node;
|
|
153
163
|
}
|
|
154
164
|
|
|
165
|
+
createValueKey() {
|
|
166
|
+
if (
|
|
167
|
+
this._valueKeyDirty === false &&
|
|
168
|
+
this.node !== null &&
|
|
169
|
+
this.node.w === this._lastW &&
|
|
170
|
+
this.node.h === this._lastH
|
|
171
|
+
) {
|
|
172
|
+
return this._valueKeyCache;
|
|
173
|
+
}
|
|
174
|
+
|
|
175
|
+
let valueKey = '';
|
|
176
|
+
for (const key in this.resolvedProps) {
|
|
177
|
+
valueKey += `${key}:${this.resolvedProps[key]!};`;
|
|
178
|
+
}
|
|
179
|
+
valueKey += `node-width:${this.node!.w}`;
|
|
180
|
+
valueKey += `node-height:${this.node!.h}`;
|
|
181
|
+
|
|
182
|
+
this._valueKeyCache = valueKey;
|
|
183
|
+
this._valueKeyDirty = false;
|
|
184
|
+
this._lastW = this.node!.w;
|
|
185
|
+
this._lastH = this.node!.h;
|
|
186
|
+
|
|
187
|
+
return valueKey;
|
|
188
|
+
}
|
|
189
|
+
|
|
155
190
|
get props(): Props | undefined {
|
|
156
191
|
return this.definedProps;
|
|
157
192
|
}
|