@lightningtv/renderer 2.16.1 → 3.2.3
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/NOTICE +4 -0
- package/README.md +22 -28
- package/dist/exports/canvas-shaders.js +0 -16
- package/dist/exports/canvas-shaders.js.map +1 -1
- package/dist/exports/canvas.d.ts +8 -2
- package/dist/exports/canvas.js +8 -20
- package/dist/exports/canvas.js.map +1 -1
- package/dist/exports/index.d.ts +18 -13
- package/dist/exports/index.js +9 -27
- package/dist/exports/index.js.map +1 -1
- package/dist/exports/inspector.js +0 -18
- package/dist/exports/inspector.js.map +1 -1
- package/dist/exports/utils.d.ts +2 -1
- package/dist/exports/utils.js +2 -19
- package/dist/exports/utils.js.map +1 -1
- package/dist/exports/webgl-shaders.js +0 -16
- package/dist/exports/webgl-shaders.js.map +1 -1
- package/dist/exports/webgl.d.ts +11 -2
- package/dist/exports/webgl.js +11 -20
- package/dist/exports/webgl.js.map +1 -1
- package/dist/src/common/CommonTypes.d.ts +15 -3
- package/dist/src/common/CommonTypes.js +0 -18
- package/dist/src/common/CommonTypes.js.map +1 -1
- package/dist/src/common/EventEmitter.js +0 -18
- package/dist/src/common/EventEmitter.js.map +1 -1
- package/dist/src/common/IEventEmitter.js +0 -16
- package/dist/src/common/IEventEmitter.js.map +1 -1
- package/dist/src/core/Autosizer.d.ts +35 -0
- package/dist/src/core/Autosizer.js +178 -0
- package/dist/src/core/Autosizer.js.map +1 -0
- package/dist/src/core/CoreNode.d.ts +138 -105
- package/dist/src/core/CoreNode.js +805 -526
- package/dist/src/core/CoreNode.js.map +1 -1
- package/dist/src/core/CoreShaderManager.d.ts +29 -73
- package/dist/src/core/CoreShaderManager.js +92 -97
- package/dist/src/core/CoreShaderManager.js.map +1 -1
- package/dist/src/core/CoreTextNode.d.ts +75 -87
- package/dist/src/core/CoreTextNode.js +380 -258
- package/dist/src/core/CoreTextNode.js.map +1 -1
- package/dist/src/core/CoreTextureManager.d.ts +18 -3
- package/dist/src/core/CoreTextureManager.js +63 -107
- package/dist/src/core/CoreTextureManager.js.map +1 -1
- package/dist/src/core/Stage.d.ts +82 -55
- package/dist/src/core/Stage.js +410 -247
- 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 +4 -3
- package/dist/src/core/TextureMemoryManager.js +103 -135
- package/dist/src/core/TextureMemoryManager.js.map +1 -1
- package/dist/src/core/animations/AnimationManager.js +0 -18
- package/dist/src/core/animations/AnimationManager.js.map +1 -1
- package/dist/src/core/animations/CoreAnimation.d.ts +3 -4
- package/dist/src/core/animations/CoreAnimation.js +9 -76
- package/dist/src/core/animations/CoreAnimation.js.map +1 -1
- package/dist/src/core/animations/CoreAnimationController.js +0 -18
- package/dist/src/core/animations/CoreAnimationController.js.map +1 -1
- package/dist/src/core/lib/ContextSpy.js +0 -18
- package/dist/src/core/lib/ContextSpy.js.map +1 -1
- package/dist/src/core/lib/ImageWorker.d.ts +2 -2
- package/dist/src/core/lib/ImageWorker.js +31 -30
- package/dist/src/core/lib/ImageWorker.js.map +1 -1
- package/dist/src/core/lib/Matrix3d.d.ts +1 -0
- package/dist/src/core/lib/Matrix3d.js +7 -19
- package/dist/src/core/lib/Matrix3d.js.map +1 -1
- package/dist/src/core/lib/RenderCoords.d.ts +9 -10
- package/dist/src/core/lib/RenderCoords.js +27 -55
- package/dist/src/core/lib/RenderCoords.js.map +1 -1
- package/dist/src/core/lib/WebGlContextWrapper.d.ts +147 -59
- package/dist/src/core/lib/WebGlContextWrapper.js +252 -158
- 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 +82 -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/{renderers/canvas/internal/ColorUtils.d.ts → lib/colorParser.d.ts} +2 -0
- package/dist/src/core/{renderers/canvas/internal/ColorUtils.js → lib/colorParser.js} +15 -19
- 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 -86
- package/dist/src/core/lib/textureCompression.js.map +1 -1
- package/dist/src/core/lib/textureSvg.js +0 -18
- package/dist/src/core/lib/textureSvg.js.map +1 -1
- package/dist/src/core/lib/utils.d.ts +8 -2
- package/dist/src/core/lib/utils.js +21 -20
- 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/platforms/Platform.d.ts +5 -0
- package/dist/src/core/platforms/Platform.js +0 -18
- package/dist/src/core/platforms/Platform.js.map +1 -1
- package/dist/src/core/platforms/web/WebPlatform.d.ts +1 -0
- package/dist/src/core/platforms/web/WebPlatform.js +39 -7
- package/dist/src/core/platforms/web/WebPlatform.js.map +1 -1
- package/dist/src/core/renderers/CoreContextTexture.d.ts +1 -0
- package/dist/src/core/renderers/CoreContextTexture.js +0 -18
- package/dist/src/core/renderers/CoreContextTexture.js.map +1 -1
- package/dist/src/core/renderers/CoreRenderOp.js +0 -18
- package/dist/src/core/renderers/CoreRenderOp.js.map +1 -1
- package/dist/src/core/renderers/CoreRenderer.d.ts +25 -23
- package/dist/src/core/renderers/CoreRenderer.js +1 -24
- package/dist/src/core/renderers/CoreRenderer.js.map +1 -1
- 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/CoreShaderProgram.js +0 -18
- package/dist/src/core/renderers/CoreShaderProgram.js.map +1 -1
- package/dist/src/core/renderers/canvas/CanvasRenderer.d.ts +3 -5
- package/dist/src/core/renderers/canvas/CanvasRenderer.js +86 -83
- package/dist/src/core/renderers/canvas/CanvasRenderer.js.map +1 -1
- package/dist/src/core/renderers/canvas/CanvasShaderNode.js +2 -17
- 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 -31
- package/dist/src/core/renderers/canvas/CanvasTexture.js.map +1 -1
- package/dist/src/core/renderers/webgl/SdfRenderOp.d.ts +33 -0
- package/dist/src/core/renderers/webgl/SdfRenderOp.js +80 -0
- package/dist/src/core/renderers/webgl/SdfRenderOp.js.map +1 -0
- package/dist/src/core/renderers/webgl/WebGlCtxRenderTexture.d.ts +2 -0
- package/dist/src/core/renderers/webgl/WebGlCtxRenderTexture.js +14 -24
- 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 -23
- 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 -67
- package/dist/src/core/renderers/webgl/WebGlCtxTexture.js.map +1 -1
- package/dist/src/core/renderers/webgl/WebGlRenderer.d.ts +31 -19
- package/dist/src/core/renderers/webgl/WebGlRenderer.js +297 -200
- 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.map +1 -1
- package/dist/src/core/renderers/webgl/WebGlShaderProgram.d.ts +5 -5
- package/dist/src/core/renderers/webgl/WebGlShaderProgram.js +61 -34
- package/dist/src/core/renderers/webgl/WebGlShaderProgram.js.map +1 -1
- package/dist/src/core/renderers/webgl/internal/BufferCollection.d.ts +1 -0
- package/dist/src/core/renderers/webgl/internal/BufferCollection.js +12 -21
- package/dist/src/core/renderers/webgl/internal/BufferCollection.js.map +1 -1
- package/dist/src/core/renderers/webgl/internal/RendererUtils.js +0 -18
- package/dist/src/core/renderers/webgl/internal/RendererUtils.js.map +1 -1
- package/dist/src/core/renderers/webgl/internal/ShaderUtils.d.ts +32 -5
- package/dist/src/core/renderers/webgl/internal/ShaderUtils.js +50 -18
- package/dist/src/core/renderers/webgl/internal/ShaderUtils.js.map +1 -1
- package/dist/src/core/renderers/webgl/internal/WebGlUtils.js +0 -18
- package/dist/src/core/renderers/webgl/internal/WebGlUtils.js.map +1 -1
- package/dist/src/core/shaders/canvas/Border.d.ts +8 -2
- package/dist/src/core/shaders/canvas/Border.js +67 -41
- package/dist/src/core/shaders/canvas/Border.js.map +1 -1
- package/dist/src/core/shaders/canvas/HolePunch.js +3 -19
- package/dist/src/core/shaders/canvas/HolePunch.js.map +1 -1
- package/dist/src/core/shaders/canvas/LinearGradient.js +2 -18
- package/dist/src/core/shaders/canvas/LinearGradient.js.map +1 -1
- package/dist/src/core/shaders/canvas/RadialGradient.js +5 -21
- package/dist/src/core/shaders/canvas/RadialGradient.js.map +1 -1
- package/dist/src/core/shaders/canvas/Rounded.js +1 -17
- 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 +40 -26
- 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 +43 -23
- package/dist/src/core/shaders/canvas/RoundedWithBorderAndShadow.js.map +1 -1
- package/dist/src/core/shaders/canvas/RoundedWithShadow.js +4 -18
- package/dist/src/core/shaders/canvas/RoundedWithShadow.js.map +1 -1
- package/dist/src/core/shaders/canvas/Shadow.js +0 -16
- 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 -34
- package/dist/src/core/shaders/canvas/utils/render.js.map +1 -1
- package/dist/src/core/shaders/templates/BorderTemplate.d.ts +11 -2
- package/dist/src/core/shaders/templates/BorderTemplate.js +30 -26
- 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 -18
- package/dist/src/core/shaders/templates/HolePunchTemplate.js.map +1 -1
- package/dist/src/core/shaders/templates/LinearGradientTemplate.js +0 -16
- package/dist/src/core/shaders/templates/LinearGradientTemplate.js.map +1 -1
- package/dist/src/core/shaders/templates/RadialGradientTemplate.d.ts +8 -6
- package/dist/src/core/shaders/templates/RadialGradientTemplate.js +2 -18
- package/dist/src/core/shaders/templates/RadialGradientTemplate.js.map +1 -1
- package/dist/src/core/shaders/templates/RoundedTemplate.js +0 -16
- package/dist/src/core/shaders/templates/RoundedTemplate.js.map +1 -1
- package/dist/src/core/shaders/templates/RoundedWithBorderAndShadowTemplate.js +0 -16
- package/dist/src/core/shaders/templates/RoundedWithBorderAndShadowTemplate.js.map +1 -1
- package/dist/src/core/shaders/templates/RoundedWithBorderTemplate.d.ts +1 -2
- package/dist/src/core/shaders/templates/RoundedWithBorderTemplate.js +3 -17
- package/dist/src/core/shaders/templates/RoundedWithBorderTemplate.js.map +1 -1
- package/dist/src/core/shaders/templates/RoundedWithShadowTemplate.js +0 -16
- package/dist/src/core/shaders/templates/RoundedWithShadowTemplate.js.map +1 -1
- package/dist/src/core/shaders/templates/ShadowTemplate.js +0 -16
- package/dist/src/core/shaders/templates/ShadowTemplate.js.map +1 -1
- package/dist/src/core/shaders/utils.js +0 -16
- package/dist/src/core/shaders/utils.js.map +1 -1
- package/dist/src/core/shaders/webgl/Border.js +75 -31
- package/dist/src/core/shaders/webgl/Border.js.map +1 -1
- package/dist/src/core/shaders/webgl/Default.js +6 -41
- package/dist/src/core/shaders/webgl/Default.js.map +1 -1
- package/dist/src/core/shaders/webgl/HolePunch.js +2 -18
- package/dist/src/core/shaders/webgl/HolePunch.js.map +1 -1
- package/dist/src/core/shaders/webgl/LinearGradient.js +68 -30
- package/dist/src/core/shaders/webgl/LinearGradient.js.map +1 -1
- package/dist/src/core/shaders/webgl/RadialGradient.js +52 -45
- package/dist/src/core/shaders/webgl/RadialGradient.js.map +1 -1
- package/dist/src/core/shaders/webgl/Rounded.js +25 -23
- package/dist/src/core/shaders/webgl/Rounded.js.map +1 -1
- package/dist/src/core/shaders/webgl/RoundedWithBorder.js +110 -48
- package/dist/src/core/shaders/webgl/RoundedWithBorder.js.map +1 -1
- package/dist/src/core/shaders/webgl/RoundedWithBorderAndShadow.js +114 -54
- package/dist/src/core/shaders/webgl/RoundedWithBorderAndShadow.js.map +1 -1
- package/dist/src/core/shaders/webgl/RoundedWithShadow.js +73 -34
- 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 -35
- package/dist/src/core/shaders/webgl/SdfShader.js.map +1 -1
- package/dist/src/core/shaders/webgl/Shadow.js +39 -34
- 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 +206 -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 +139 -0
- package/dist/src/core/text-rendering/CanvasTextRenderer.js.map +1 -0
- package/dist/src/core/text-rendering/SdfFontHandler.d.ts +167 -0
- package/dist/src/core/text-rendering/SdfFontHandler.js +371 -0
- package/dist/src/core/text-rendering/SdfFontHandler.js.map +1 -0
- package/dist/src/core/text-rendering/SdfTextRenderer.d.ts +18 -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 +384 -0
- package/dist/src/core/text-rendering/TextRenderer.js +2 -0
- package/dist/src/core/text-rendering/TextRenderer.js.map +1 -0
- package/dist/src/core/text-rendering/Utils.d.ts +30 -0
- package/dist/src/core/text-rendering/Utils.js +66 -0
- package/dist/src/core/text-rendering/Utils.js.map +1 -0
- package/dist/src/core/textures/ColorTexture.d.ts +1 -1
- package/dist/src/core/textures/ColorTexture.js +3 -22
- package/dist/src/core/textures/ColorTexture.js.map +1 -1
- package/dist/src/core/textures/ImageTexture.d.ts +10 -3
- package/dist/src/core/textures/ImageTexture.js +33 -62
- 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 -26
- 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 -30
- 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 -55
- package/dist/src/core/textures/SubTexture.js.map +1 -1
- package/dist/src/core/textures/Texture.d.ts +80 -16
- package/dist/src/core/textures/Texture.js +131 -37
- 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 -19
- package/dist/src/core/utils.js.map +1 -1
- package/dist/src/main-api/INode.d.ts +9 -9
- package/dist/src/main-api/INode.js.map +1 -1
- package/dist/src/main-api/Inspector.d.ts +135 -2
- package/dist/src/main-api/Inspector.js +507 -30
- package/dist/src/main-api/Inspector.js.map +1 -1
- package/dist/src/main-api/Renderer.d.ts +246 -162
- package/dist/src/main-api/Renderer.js +192 -152
- package/dist/src/main-api/Renderer.js.map +1 -1
- package/dist/src/utils.d.ts +23 -4
- package/dist/src/utils.js +50 -27
- package/dist/src/utils.js.map +1 -1
- package/dist/tsconfig.dist.tsbuildinfo +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/exports/canvas-shaders.ts +11 -0
- package/exports/canvas.ts +8 -20
- package/exports/index.ts +24 -44
- package/exports/inspector.ts +0 -19
- package/exports/utils.ts +7 -19
- package/exports/webgl-shaders.ts +12 -0
- package/exports/webgl.ts +15 -20
- package/package.json +23 -20
- package/src/common/CommonTypes.ts +20 -22
- package/src/common/EventEmitter.ts +0 -19
- package/src/common/IAnimationController.ts +0 -18
- package/src/common/IEventEmitter.ts +0 -17
- package/src/core/Autosizer.ts +205 -0
- package/src/core/CoreNode.test.ts +378 -46
- package/src/core/CoreNode.ts +1007 -659
- package/src/core/CoreShaderManager.ts +128 -250
- package/src/core/CoreTextNode.ts +457 -321
- package/src/core/CoreTextureManager.ts +94 -115
- package/src/core/Stage.ts +516 -312
- package/src/core/TextureError.ts +46 -0
- package/src/core/TextureMemoryManager.ts +139 -175
- package/src/core/animations/AnimationManager.ts +0 -19
- package/src/core/animations/CoreAnimation.ts +16 -96
- package/src/core/animations/CoreAnimationController.ts +0 -19
- package/src/core/lib/ContextSpy.ts +0 -19
- package/src/core/lib/ImageWorker.ts +43 -31
- package/src/core/lib/Matrix3d.ts +7 -20
- package/src/core/lib/RenderCoords.ts +36 -67
- package/src/core/lib/WebGlContextWrapper.ts +353 -237
- package/src/core/lib/collectionUtils.ts +99 -0
- package/src/core/lib/colorCache.ts +20 -0
- package/src/core/{renderers/canvas/internal/ColorUtils.ts → lib/colorParser.ts} +16 -19
- package/src/core/lib/textureCompression.ts +434 -94
- package/src/core/lib/textureSvg.ts +0 -19
- package/src/core/lib/utils.ts +31 -19
- package/src/core/lib/validateImageBitmap.ts +17 -6
- package/src/core/platforms/Platform.ts +64 -0
- package/src/core/platforms/web/WebPlatform.ts +132 -0
- package/src/core/renderers/CoreContextTexture.ts +1 -19
- package/src/core/renderers/CoreRenderOp.ts +0 -19
- package/src/core/renderers/CoreRenderer.ts +34 -49
- package/src/core/renderers/CoreShaderNode.ts +202 -0
- package/src/core/renderers/CoreShaderProgram.ts +4 -0
- package/src/core/renderers/canvas/CanvasRenderer.ts +270 -0
- package/src/core/renderers/canvas/CanvasShaderNode.ts +79 -0
- package/src/core/renderers/canvas/{CanvasCoreTexture.ts → CanvasTexture.ts} +15 -27
- package/src/core/renderers/webgl/SdfRenderOp.ts +88 -0
- package/src/core/renderers/webgl/{WebGlCoreCtxRenderTexture.ts → WebGlCtxRenderTexture.ts} +15 -36
- package/src/core/renderers/webgl/WebGlCtxSubTexture.ts +76 -0
- package/src/core/renderers/webgl/{WebGlCoreCtxTexture.ts → WebGlCtxTexture.ts} +89 -70
- package/src/core/renderers/webgl/WebGlRenderer.ts +850 -0
- package/src/core/renderers/webgl/WebGlShaderNode.ts +430 -0
- package/src/core/renderers/webgl/WebGlShaderProgram.ts +356 -0
- package/src/core/renderers/webgl/internal/BufferCollection.ts +15 -23
- package/src/core/renderers/webgl/internal/RendererUtils.ts +0 -19
- package/src/core/renderers/webgl/internal/ShaderUtils.ts +143 -24
- package/src/core/renderers/webgl/internal/WebGlUtils.ts +0 -19
- package/src/core/shaders/canvas/Border.ts +119 -0
- package/src/core/shaders/canvas/HolePunch.ts +38 -0
- package/src/core/shaders/canvas/LinearGradient.ts +54 -0
- package/src/core/shaders/canvas/RadialGradient.ts +82 -0
- package/src/core/shaders/canvas/Rounded.ts +38 -0
- package/src/core/shaders/canvas/RoundedWithBorder.ts +105 -0
- package/src/core/shaders/canvas/RoundedWithBorderAndShadow.ts +118 -0
- package/src/core/shaders/canvas/RoundedWithShadow.ts +56 -0
- package/src/core/shaders/canvas/Shadow.ts +35 -0
- package/src/core/shaders/canvas/utils/render.ts +143 -0
- package/src/core/shaders/templates/BorderTemplate.ts +128 -0
- package/src/core/shaders/templates/HolePunchTemplate.ts +65 -0
- package/src/core/shaders/templates/LinearGradientTemplate.ts +54 -0
- package/src/core/shaders/templates/RadialGradientTemplate.ts +66 -0
- package/src/core/shaders/templates/RoundedTemplate.ts +81 -0
- package/src/core/shaders/templates/RoundedWithBorderAndShadowTemplate.ts +21 -0
- package/src/core/shaders/templates/RoundedWithBorderTemplate.ts +23 -0
- package/src/core/shaders/templates/RoundedWithShadowTemplate.ts +18 -0
- package/src/core/shaders/templates/ShadowTemplate.ts +89 -0
- package/src/core/shaders/utils.ts +30 -0
- package/src/core/shaders/webgl/Border.ts +159 -0
- package/src/core/shaders/webgl/Default.ts +52 -0
- package/src/core/shaders/webgl/HolePunch.ts +58 -0
- package/src/core/shaders/webgl/LinearGradient.ts +119 -0
- package/src/core/shaders/webgl/RadialGradient.ts +91 -0
- package/src/core/shaders/webgl/Rounded.ts +97 -0
- package/src/core/shaders/webgl/RoundedWithBorder.ts +212 -0
- package/src/core/shaders/webgl/RoundedWithBorderAndShadow.ts +234 -0
- package/src/core/shaders/webgl/RoundedWithShadow.ts +132 -0
- package/src/core/shaders/webgl/SdfShader.ts +104 -0
- package/src/core/shaders/webgl/Shadow.ts +119 -0
- package/src/core/text-rendering/CanvasFontHandler.ts +285 -0
- package/src/core/text-rendering/CanvasTextRenderer.ts +236 -0
- package/src/core/text-rendering/SdfFontHandler.ts +566 -0
- package/src/core/text-rendering/SdfTextRenderer.ts +406 -0
- package/src/core/text-rendering/TextLayoutEngine.ts +672 -0
- package/src/core/text-rendering/TextRenderer.ts +426 -0
- package/src/core/text-rendering/Utils.ts +80 -0
- package/src/core/text-rendering/tests/TextLayoutEngine.test.ts +434 -0
- package/src/core/textures/ColorTexture.ts +7 -24
- package/src/core/textures/ImageTexture.ts +72 -78
- package/src/core/textures/NoiseTexture.ts +14 -31
- package/src/core/textures/RenderTexture.ts +18 -35
- package/src/core/textures/SubTexture.ts +25 -65
- package/src/core/textures/Texture.ts +182 -53
- package/src/core/utils.ts +9 -26
- package/src/main-api/INode.ts +10 -29
- package/src/main-api/Inspector.ts +794 -38
- package/src/main-api/Renderer.ts +476 -274
- package/src/utils.ts +83 -29
- package/dist/src/core/animations/SimpleAnimation.d.ts +0 -28
- package/dist/src/core/animations/SimpleAnimation.js +0 -96
- package/dist/src/core/animations/SimpleAnimation.js.map +0 -1
- package/dist/src/core/platform.d.ts +0 -10
- package/dist/src/core/platform.js +0 -81
- package/dist/src/core/platform.js.map +0 -1
- package/dist/src/core/renderers/CoreShader.d.ts +0 -9
- package/dist/src/core/renderers/CoreShader.js +0 -28
- package/dist/src/core/renderers/CoreShader.js.map +0 -1
- package/dist/src/core/renderers/canvas/CanvasCoreRenderer.d.ts +0 -33
- package/dist/src/core/renderers/canvas/CanvasCoreRenderer.js +0 -250
- package/dist/src/core/renderers/canvas/CanvasCoreRenderer.js.map +0 -1
- package/dist/src/core/renderers/canvas/CanvasCoreTexture.d.ts +0 -16
- package/dist/src/core/renderers/canvas/CanvasCoreTexture.js +0 -124
- package/dist/src/core/renderers/canvas/CanvasCoreTexture.js.map +0 -1
- package/dist/src/core/renderers/canvas/internal/C2DShaderUtils.d.ts +0 -14
- package/dist/src/core/renderers/canvas/internal/C2DShaderUtils.js +0 -138
- package/dist/src/core/renderers/canvas/internal/C2DShaderUtils.js.map +0 -1
- package/dist/src/core/renderers/canvas/internal/ColorUtils.js.map +0 -1
- package/dist/src/core/renderers/canvas/shaders/UnsupportedShader.d.ts +0 -10
- package/dist/src/core/renderers/canvas/shaders/UnsupportedShader.js +0 -43
- package/dist/src/core/renderers/canvas/shaders/UnsupportedShader.js.map +0 -1
- package/dist/src/core/renderers/webgl/WebGlCoreCtxRenderTexture.d.ts +0 -12
- package/dist/src/core/renderers/webgl/WebGlCoreCtxRenderTexture.js +0 -58
- package/dist/src/core/renderers/webgl/WebGlCoreCtxRenderTexture.js.map +0 -1
- package/dist/src/core/renderers/webgl/WebGlCoreCtxSubTexture.d.ts +0 -9
- package/dist/src/core/renderers/webgl/WebGlCoreCtxSubTexture.js +0 -38
- package/dist/src/core/renderers/webgl/WebGlCoreCtxSubTexture.js.map +0 -1
- package/dist/src/core/renderers/webgl/WebGlCoreCtxTexture.d.ts +0 -56
- package/dist/src/core/renderers/webgl/WebGlCoreCtxTexture.js +0 -239
- package/dist/src/core/renderers/webgl/WebGlCoreCtxTexture.js.map +0 -1
- package/dist/src/core/renderers/webgl/WebGlCoreRenderOp.d.ts +0 -34
- package/dist/src/core/renderers/webgl/WebGlCoreRenderOp.js +0 -114
- package/dist/src/core/renderers/webgl/WebGlCoreRenderOp.js.map +0 -1
- package/dist/src/core/renderers/webgl/WebGlCoreRenderer.d.ts +0 -133
- package/dist/src/core/renderers/webgl/WebGlCoreRenderer.js +0 -616
- package/dist/src/core/renderers/webgl/WebGlCoreRenderer.js.map +0 -1
- package/dist/src/core/renderers/webgl/WebGlCoreShader.d.ts +0 -83
- package/dist/src/core/renderers/webgl/WebGlCoreShader.js +0 -233
- package/dist/src/core/renderers/webgl/WebGlCoreShader.js.map +0 -1
- package/dist/src/core/renderers/webgl/WebGlRenderOp.d.ts +0 -44
- package/dist/src/core/renderers/webgl/WebGlRenderOp.js +0 -118
- package/dist/src/core/renderers/webgl/WebGlRenderOp.js.map +0 -1
- package/dist/src/core/renderers/webgl/shaders/DefaultShader.d.ts +0 -9
- package/dist/src/core/renderers/webgl/shaders/DefaultShader.js +0 -87
- package/dist/src/core/renderers/webgl/shaders/DefaultShader.js.map +0 -1
- package/dist/src/core/renderers/webgl/shaders/DefaultShaderBatched.d.ts +0 -10
- package/dist/src/core/renderers/webgl/shaders/DefaultShaderBatched.js +0 -119
- package/dist/src/core/renderers/webgl/shaders/DefaultShaderBatched.js.map +0 -1
- package/dist/src/core/renderers/webgl/shaders/DynamicShader.d.ts +0 -29
- package/dist/src/core/renderers/webgl/shaders/DynamicShader.js +0 -413
- package/dist/src/core/renderers/webgl/shaders/DynamicShader.js.map +0 -1
- package/dist/src/core/renderers/webgl/shaders/RoundedRectangle.d.ts +0 -28
- package/dist/src/core/renderers/webgl/shaders/RoundedRectangle.js +0 -131
- package/dist/src/core/renderers/webgl/shaders/RoundedRectangle.js.map +0 -1
- package/dist/src/core/renderers/webgl/shaders/SdfShader.d.ts +0 -47
- package/dist/src/core/renderers/webgl/shaders/SdfShader.js +0 -160
- package/dist/src/core/renderers/webgl/shaders/SdfShader.js.map +0 -1
- package/dist/src/core/renderers/webgl/shaders/effects/BorderBottomEffect.d.ts +0 -31
- package/dist/src/core/renderers/webgl/shaders/effects/BorderBottomEffect.js +0 -71
- package/dist/src/core/renderers/webgl/shaders/effects/BorderBottomEffect.js.map +0 -1
- package/dist/src/core/renderers/webgl/shaders/effects/BorderEffect.d.ts +0 -30
- package/dist/src/core/renderers/webgl/shaders/effects/BorderEffect.js +0 -58
- package/dist/src/core/renderers/webgl/shaders/effects/BorderEffect.js.map +0 -1
- package/dist/src/core/renderers/webgl/shaders/effects/BorderLeftEffect.d.ts +0 -31
- package/dist/src/core/renderers/webgl/shaders/effects/BorderLeftEffect.js +0 -71
- package/dist/src/core/renderers/webgl/shaders/effects/BorderLeftEffect.js.map +0 -1
- package/dist/src/core/renderers/webgl/shaders/effects/BorderRightEffect.d.ts +0 -31
- package/dist/src/core/renderers/webgl/shaders/effects/BorderRightEffect.js +0 -71
- package/dist/src/core/renderers/webgl/shaders/effects/BorderRightEffect.js.map +0 -1
- package/dist/src/core/renderers/webgl/shaders/effects/BorderTopEffect.d.ts +0 -31
- package/dist/src/core/renderers/webgl/shaders/effects/BorderTopEffect.js +0 -71
- package/dist/src/core/renderers/webgl/shaders/effects/BorderTopEffect.js.map +0 -1
- package/dist/src/core/renderers/webgl/shaders/effects/EffectUtils.d.ts +0 -9
- package/dist/src/core/renderers/webgl/shaders/effects/EffectUtils.js +0 -136
- package/dist/src/core/renderers/webgl/shaders/effects/EffectUtils.js.map +0 -1
- package/dist/src/core/renderers/webgl/shaders/effects/FadeOutEffect.d.ts +0 -36
- package/dist/src/core/renderers/webgl/shaders/effects/FadeOutEffect.js +0 -85
- package/dist/src/core/renderers/webgl/shaders/effects/FadeOutEffect.js.map +0 -1
- package/dist/src/core/renderers/webgl/shaders/effects/GlitchEffect.d.ts +0 -45
- package/dist/src/core/renderers/webgl/shaders/effects/GlitchEffect.js +0 -104
- package/dist/src/core/renderers/webgl/shaders/effects/GlitchEffect.js.map +0 -1
- package/dist/src/core/renderers/webgl/shaders/effects/GrayscaleEffect.d.ts +0 -22
- package/dist/src/core/renderers/webgl/shaders/effects/GrayscaleEffect.js +0 -45
- package/dist/src/core/renderers/webgl/shaders/effects/GrayscaleEffect.js.map +0 -1
- package/dist/src/core/renderers/webgl/shaders/effects/HolePunchEffect.d.ts +0 -58
- package/dist/src/core/renderers/webgl/shaders/effects/HolePunchEffect.js +0 -80
- package/dist/src/core/renderers/webgl/shaders/effects/HolePunchEffect.js.map +0 -1
- package/dist/src/core/renderers/webgl/shaders/effects/LinearGradientEffect.d.ts +0 -35
- package/dist/src/core/renderers/webgl/shaders/effects/LinearGradientEffect.js +0 -129
- package/dist/src/core/renderers/webgl/shaders/effects/LinearGradientEffect.js.map +0 -1
- package/dist/src/core/renderers/webgl/shaders/effects/RadialGradientEffect.d.ts +0 -39
- package/dist/src/core/renderers/webgl/shaders/effects/RadialGradientEffect.js +0 -116
- package/dist/src/core/renderers/webgl/shaders/effects/RadialGradientEffect.js.map +0 -1
- package/dist/src/core/renderers/webgl/shaders/effects/RadialProgressEffect.d.ts +0 -61
- package/dist/src/core/renderers/webgl/shaders/effects/RadialProgressEffect.js +0 -127
- package/dist/src/core/renderers/webgl/shaders/effects/RadialProgressEffect.js.map +0 -1
- package/dist/src/core/renderers/webgl/shaders/effects/RadiusEffect.d.ts +0 -40
- package/dist/src/core/renderers/webgl/shaders/effects/RadiusEffect.js +0 -71
- package/dist/src/core/renderers/webgl/shaders/effects/RadiusEffect.js.map +0 -1
- package/dist/src/core/renderers/webgl/shaders/effects/ShaderEffect.d.ts +0 -115
- package/dist/src/core/renderers/webgl/shaders/effects/ShaderEffect.js +0 -61
- package/dist/src/core/renderers/webgl/shaders/effects/ShaderEffect.js.map +0 -1
- package/dist/src/core/shaders/templates/shaderUtils.d.ts +0 -5
- package/dist/src/core/shaders/templates/shaderUtils.js +0 -41
- package/dist/src/core/shaders/templates/shaderUtils.js.map +0 -1
- package/dist/src/core/shaders/webgl/Magnifier.d.ts +0 -46
- package/dist/src/core/shaders/webgl/Magnifier.js +0 -107
- package/dist/src/core/shaders/webgl/Magnifier.js.map +0 -1
- package/dist/src/core/shaders/webgl/RoundedWithBorder copy.d.ts +0 -3
- package/dist/src/core/shaders/webgl/RoundedWithBorder copy.js +0 -218
- package/dist/src/core/shaders/webgl/RoundedWithBorder copy.js.map +0 -1
- package/dist/src/core/text-rendering/TextRenderingUtils.d.ts +0 -12
- package/dist/src/core/text-rendering/TextRenderingUtils.js +0 -14
- package/dist/src/core/text-rendering/TextRenderingUtils.js.map +0 -1
- package/dist/src/core/text-rendering/TextTextureRendererUtils.d.ts +0 -72
- package/dist/src/core/text-rendering/TextTextureRendererUtils.js +0 -217
- package/dist/src/core/text-rendering/TextTextureRendererUtils.js.map +0 -1
- package/dist/src/core/text-rendering/TrFontManager.d.ts +0 -26
- package/dist/src/core/text-rendering/TrFontManager.js +0 -131
- package/dist/src/core/text-rendering/TrFontManager.js.map +0 -1
- package/dist/src/core/text-rendering/font-face-types/SdfTrFontFace/SdfTrFontFace.d.ts +0 -39
- package/dist/src/core/text-rendering/font-face-types/SdfTrFontFace/SdfTrFontFace.js +0 -125
- package/dist/src/core/text-rendering/font-face-types/SdfTrFontFace/SdfTrFontFace.js.map +0 -1
- package/dist/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/FontShaper.d.ts +0 -103
- package/dist/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/FontShaper.js +0 -21
- package/dist/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/FontShaper.js.map +0 -1
- package/dist/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/SdfFontShaper.d.ts +0 -62
- package/dist/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/SdfFontShaper.js +0 -88
- package/dist/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/SdfFontShaper.js.map +0 -1
- package/dist/src/core/text-rendering/font-face-types/TrFontFace.d.ts +0 -118
- package/dist/src/core/text-rendering/font-face-types/TrFontFace.js +0 -63
- package/dist/src/core/text-rendering/font-face-types/TrFontFace.js.map +0 -1
- package/dist/src/core/text-rendering/font-face-types/WebTrFontFace.d.ts +0 -14
- package/dist/src/core/text-rendering/font-face-types/WebTrFontFace.js +0 -66
- package/dist/src/core/text-rendering/font-face-types/WebTrFontFace.js.map +0 -1
- package/dist/src/core/text-rendering/font-face-types/utils.d.ts +0 -1
- package/dist/src/core/text-rendering/font-face-types/utils.js +0 -38
- package/dist/src/core/text-rendering/font-face-types/utils.js.map +0 -1
- package/dist/src/core/text-rendering/renderers/CanvasTextRenderer.d.ts +0 -59
- package/dist/src/core/text-rendering/renderers/CanvasTextRenderer.js +0 -397
- package/dist/src/core/text-rendering/renderers/CanvasTextRenderer.js.map +0 -1
- package/dist/src/core/text-rendering/renderers/LightningTextTextureRenderer.d.ts +0 -120
- package/dist/src/core/text-rendering/renderers/LightningTextTextureRenderer.js +0 -551
- package/dist/src/core/text-rendering/renderers/LightningTextTextureRenderer.js.map +0 -1
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.d.ts +0 -92
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.js +0 -607
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.js.map +0 -1
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/PeekableGenerator.d.ts +0 -12
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/PeekableGenerator.js +0 -61
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/PeekableGenerator.js.map +0 -1
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/SpecialCodepoints.d.ts +0 -33
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/SpecialCodepoints.js +0 -52
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/SpecialCodepoints.js.map +0 -1
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/constants.d.ts +0 -13
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/constants.js +0 -32
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/constants.js.map +0 -1
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/getStartConditions.d.ts +0 -23
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/getStartConditions.js +0 -84
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/getStartConditions.js.map +0 -1
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/getUnicodeCodepoints.d.ts +0 -4
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/getUnicodeCodepoints.js +0 -34
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/getUnicodeCodepoints.js.map +0 -1
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText.d.ts +0 -20
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText.js +0 -308
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText.js.map +0 -1
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/measureText.d.ts +0 -10
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/measureText.js +0 -40
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/measureText.js.map +0 -1
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/setRenderWindow.d.ts +0 -26
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/setRenderWindow.js +0 -70
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/setRenderWindow.js.map +0 -1
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/util.d.ts +0 -16
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/util.js +0 -39
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/util.js.map +0 -1
- package/dist/src/core/text-rendering/renderers/TextRenderer.d.ts +0 -373
- package/dist/src/core/text-rendering/renderers/TextRenderer.js +0 -178
- package/dist/src/core/text-rendering/renderers/TextRenderer.js.map +0 -1
- package/dist/src/main-api/DynamicShaderController.d.ts +0 -29
- package/dist/src/main-api/DynamicShaderController.js +0 -58
- package/dist/src/main-api/DynamicShaderController.js.map +0 -1
- package/dist/src/main-api/ShaderController.d.ts +0 -31
- package/dist/src/main-api/ShaderController.js +0 -37
- package/dist/src/main-api/ShaderController.js.map +0 -1
- package/scripts/please-use-pnpm.js +0 -13
- package/src/core/platform.ts +0 -100
- package/src/core/renderers/CoreShader.ts +0 -41
- package/src/core/renderers/canvas/CanvasCoreRenderer.ts +0 -375
- package/src/core/renderers/canvas/internal/C2DShaderUtils.ts +0 -231
- package/src/core/renderers/canvas/shaders/UnsupportedShader.ts +0 -48
- package/src/core/renderers/webgl/WebGlCoreCtxSubTexture.ts +0 -50
- package/src/core/renderers/webgl/WebGlCoreRenderOp.ts +0 -125
- package/src/core/renderers/webgl/WebGlCoreRenderer.ts +0 -821
- package/src/core/renderers/webgl/WebGlCoreShader.ts +0 -365
- package/src/core/renderers/webgl/shaders/DefaultShader.ts +0 -93
- package/src/core/renderers/webgl/shaders/DefaultShaderBatched.ts +0 -132
- package/src/core/renderers/webgl/shaders/DynamicShader.ts +0 -580
- package/src/core/renderers/webgl/shaders/RoundedRectangle.ts +0 -167
- package/src/core/renderers/webgl/shaders/SdfShader.ts +0 -204
- package/src/core/renderers/webgl/shaders/effects/BorderBottomEffect.ts +0 -101
- package/src/core/renderers/webgl/shaders/effects/BorderEffect.ts +0 -87
- package/src/core/renderers/webgl/shaders/effects/BorderLeftEffect.ts +0 -101
- package/src/core/renderers/webgl/shaders/effects/BorderRightEffect.ts +0 -101
- package/src/core/renderers/webgl/shaders/effects/BorderTopEffect.ts +0 -101
- package/src/core/renderers/webgl/shaders/effects/EffectUtils.ts +0 -159
- package/src/core/renderers/webgl/shaders/effects/FadeOutEffect.ts +0 -127
- package/src/core/renderers/webgl/shaders/effects/GlitchEffect.ts +0 -148
- package/src/core/renderers/webgl/shaders/effects/GrayscaleEffect.ts +0 -67
- package/src/core/renderers/webgl/shaders/effects/HolePunchEffect.ts +0 -157
- package/src/core/renderers/webgl/shaders/effects/LinearGradientEffect.ts +0 -171
- package/src/core/renderers/webgl/shaders/effects/RadialGradientEffect.ts +0 -168
- package/src/core/renderers/webgl/shaders/effects/RadialProgressEffect.ts +0 -187
- package/src/core/renderers/webgl/shaders/effects/RadiusEffect.ts +0 -110
- package/src/core/renderers/webgl/shaders/effects/ShaderEffect.ts +0 -196
- 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 -808
- package/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.ts +0 -853
- 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 -557
- package/src/main-api/DynamicShaderController.ts +0 -104
- package/src/main-api/ShaderController.ts +0 -80
|
@@ -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,64 @@
|
|
|
1
|
+
import { type Stage } from '../Stage.js';
|
|
2
|
+
|
|
3
|
+
export abstract class Platform {
|
|
4
|
+
/**
|
|
5
|
+
* Creates a new canvas element.
|
|
6
|
+
* @returns The created HTMLCanvasElement.
|
|
7
|
+
*/
|
|
8
|
+
abstract createCanvas(): HTMLCanvasElement;
|
|
9
|
+
|
|
10
|
+
/**
|
|
11
|
+
* Get a DOM element by ID
|
|
12
|
+
* @returns The DOM element (or null)
|
|
13
|
+
*/
|
|
14
|
+
abstract getElementById(id: string): HTMLElement | null;
|
|
15
|
+
|
|
16
|
+
/**
|
|
17
|
+
* Starts the main rendering loop, calling the provided update function every frame.
|
|
18
|
+
* @param Stage - The stage for rendering
|
|
19
|
+
*/
|
|
20
|
+
abstract startLoop(stage: Stage): void;
|
|
21
|
+
|
|
22
|
+
/**
|
|
23
|
+
* Abstracted createImageBitmap method.
|
|
24
|
+
* @param blob - The image source to create the ImageBitmap from.
|
|
25
|
+
* @param sxOrOptions - The source rectangle x coordinate or ImageBitmapOptions.
|
|
26
|
+
* @param sy - The source rectangle y coordinate.
|
|
27
|
+
* @param sw - The source rectangle width.
|
|
28
|
+
* @param sh - The source rectangle height.
|
|
29
|
+
* @param options - The ImageBitmapOptions.
|
|
30
|
+
* @returns A promise that resolves with the created ImageBitmap.
|
|
31
|
+
*/
|
|
32
|
+
abstract createImageBitmap(blob: ImageBitmapSource): Promise<ImageBitmap>;
|
|
33
|
+
abstract createImageBitmap(
|
|
34
|
+
blob: ImageBitmapSource,
|
|
35
|
+
options: ImageBitmapOptions,
|
|
36
|
+
): Promise<ImageBitmap>;
|
|
37
|
+
abstract createImageBitmap(
|
|
38
|
+
blob: ImageBitmapSource,
|
|
39
|
+
sx: number,
|
|
40
|
+
sy: number,
|
|
41
|
+
sw: number,
|
|
42
|
+
sh: number,
|
|
43
|
+
): Promise<ImageBitmap>;
|
|
44
|
+
abstract createImageBitmap(
|
|
45
|
+
blob: ImageBitmapSource,
|
|
46
|
+
sx: number,
|
|
47
|
+
sy: number,
|
|
48
|
+
sw: number,
|
|
49
|
+
sh: number,
|
|
50
|
+
options: ImageBitmapOptions,
|
|
51
|
+
): Promise<ImageBitmap>;
|
|
52
|
+
|
|
53
|
+
/**
|
|
54
|
+
* Retrieves the current timestamp.
|
|
55
|
+
* @returns The current timestamp.
|
|
56
|
+
*/
|
|
57
|
+
abstract getTimeStamp(): number;
|
|
58
|
+
|
|
59
|
+
/**
|
|
60
|
+
* Adds a FontFace to the platforms FontFaceSet
|
|
61
|
+
* @param font - The FontFace to add
|
|
62
|
+
*/
|
|
63
|
+
abstract addFont(font: FontFace): void;
|
|
64
|
+
}
|
|
@@ -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
|
+
const buffer = 4;
|
|
33
|
+
|
|
34
|
+
const runLoop = (currentTime: number = 0) => {
|
|
35
|
+
const targetFrameTime = stage.targetFrameTime;
|
|
36
|
+
|
|
37
|
+
// Frame Limiting logic
|
|
38
|
+
if (targetFrameTime > 0) {
|
|
39
|
+
// Calculate elapsed time since the last frame
|
|
40
|
+
const elapsed = currentTime - lastFrameTime;
|
|
41
|
+
|
|
42
|
+
// If not enough time has passed, skip this frame
|
|
43
|
+
if (elapsed < targetFrameTime) {
|
|
44
|
+
const wait = targetFrameTime - elapsed;
|
|
45
|
+
|
|
46
|
+
if (wait > buffer) {
|
|
47
|
+
setTimeout(requestLoop, wait - buffer);
|
|
48
|
+
} else {
|
|
49
|
+
requestAnimationFrame(runLoop);
|
|
50
|
+
}
|
|
51
|
+
return;
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
// Adjust lastFrameTime to maintain the target FPS
|
|
55
|
+
lastFrameTime = currentTime - (elapsed % targetFrameTime);
|
|
56
|
+
} else {
|
|
57
|
+
lastFrameTime = currentTime;
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
stage.updateFrameTime();
|
|
61
|
+
const hasActiveAnimations = stage.updateAnimations();
|
|
62
|
+
|
|
63
|
+
if (!stage.hasSceneUpdates()) {
|
|
64
|
+
// We still need to calculate the fps else it looks like the app is frozen
|
|
65
|
+
stage.calculateFps();
|
|
66
|
+
|
|
67
|
+
// We use 15ms instead of 16.6ms to provide a safety buffer.
|
|
68
|
+
// This ensures we wake up slightly before the next frame to check for updates,
|
|
69
|
+
// preventing us from missing a frame due to timer variances.
|
|
70
|
+
setTimeout(requestLoop, Math.max(targetFrameTime, 15));
|
|
71
|
+
|
|
72
|
+
if (isIdle === false) {
|
|
73
|
+
stage.shManager.cleanup();
|
|
74
|
+
stage.eventBus.emit('idle');
|
|
75
|
+
isIdle = true;
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
if (stage.txMemManager.checkCleanup() === true) {
|
|
79
|
+
stage.txMemManager.cleanup();
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
stage.flushFrameEvents();
|
|
83
|
+
return;
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
isIdle = false;
|
|
87
|
+
stage.drawFrame(hasActiveAnimations);
|
|
88
|
+
stage.flushFrameEvents();
|
|
89
|
+
|
|
90
|
+
// Schedule next frame
|
|
91
|
+
requestAnimationFrame(runLoop);
|
|
92
|
+
};
|
|
93
|
+
|
|
94
|
+
const requestLoop = () => requestAnimationFrame(runLoop);
|
|
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 Date.now();
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
override addFont(font: FontFace): void {
|
|
130
|
+
(document.fonts as FontFaceSetWithAdd).add(font);
|
|
131
|
+
}
|
|
132
|
+
}
|
|
@@ -1,22 +1,3 @@
|
|
|
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
1
|
import type { TextureMemoryManager } from '../TextureMemoryManager.js';
|
|
21
2
|
import type { Texture } from '../textures/Texture.js';
|
|
22
3
|
|
|
@@ -35,6 +16,7 @@ export abstract class CoreContextTexture {
|
|
|
35
16
|
}
|
|
36
17
|
|
|
37
18
|
abstract load(): Promise<void>;
|
|
19
|
+
abstract release(): void;
|
|
38
20
|
abstract free(): void;
|
|
39
21
|
|
|
40
22
|
get renderable(): boolean {
|
|
@@ -1,22 +1,3 @@
|
|
|
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
1
|
export abstract class CoreRenderOp {
|
|
21
2
|
abstract draw(): void;
|
|
22
3
|
}
|
|
@@ -1,38 +1,14 @@
|
|
|
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
1
|
import type { Dimensions } from '../../common/CommonTypes.js';
|
|
21
|
-
import type { BaseShaderController } from '../../main-api/ShaderController.js';
|
|
22
2
|
import type { CoreNode } from '../CoreNode.js';
|
|
23
|
-
import type {
|
|
24
|
-
import type {
|
|
25
|
-
CoreTextureManager,
|
|
26
|
-
TextureOptions,
|
|
27
|
-
} from '../CoreTextureManager.js';
|
|
3
|
+
import type { TextureOptions } from '../CoreTextureManager.js';
|
|
28
4
|
import type { Stage } from '../Stage.js';
|
|
29
|
-
import type { TextureMemoryManager } from '../TextureMemoryManager.js';
|
|
30
5
|
import type { ContextSpy } from '../lib/ContextSpy.js';
|
|
31
6
|
import type { RenderCoords } from '../lib/RenderCoords.js';
|
|
32
7
|
import type { RectWithValid } from '../lib/utils.js';
|
|
33
|
-
import type {
|
|
8
|
+
import type { CoreShaderProgram } from './CoreShaderProgram.js';
|
|
9
|
+
import type { Texture, TextureCoords } from '../textures/Texture.js';
|
|
34
10
|
import { CoreContextTexture } from './CoreContextTexture.js';
|
|
35
|
-
import type {
|
|
11
|
+
import type { CoreShaderType, CoreShaderNode } from './CoreShaderNode.js';
|
|
36
12
|
|
|
37
13
|
export interface QuadOptions {
|
|
38
14
|
width: number;
|
|
@@ -43,9 +19,9 @@ export interface QuadOptions {
|
|
|
43
19
|
colorBr: number;
|
|
44
20
|
texture: Texture | null;
|
|
45
21
|
textureOptions: TextureOptions | null;
|
|
22
|
+
textureCoords: TextureCoords | undefined;
|
|
46
23
|
zIndex: number;
|
|
47
|
-
shader:
|
|
48
|
-
shaderProps: Record<string, unknown> | null;
|
|
24
|
+
shader: CoreShaderNode | null;
|
|
49
25
|
alpha: number;
|
|
50
26
|
clippingRect: RectWithValid;
|
|
51
27
|
tx: number;
|
|
@@ -55,20 +31,15 @@ export interface QuadOptions {
|
|
|
55
31
|
tc: number;
|
|
56
32
|
td: number;
|
|
57
33
|
renderCoords?: RenderCoords;
|
|
58
|
-
rtt
|
|
59
|
-
parentHasRenderTexture
|
|
60
|
-
framebufferDimensions
|
|
34
|
+
rtt: boolean;
|
|
35
|
+
parentHasRenderTexture: boolean;
|
|
36
|
+
framebufferDimensions: Dimensions | null;
|
|
37
|
+
time?: number | null;
|
|
61
38
|
}
|
|
62
39
|
|
|
63
40
|
export interface CoreRendererOptions {
|
|
64
41
|
stage: Stage;
|
|
65
42
|
canvas: HTMLCanvasElement | OffscreenCanvas;
|
|
66
|
-
pixelRatio: number;
|
|
67
|
-
txManager: CoreTextureManager;
|
|
68
|
-
txMemManager: TextureMemoryManager;
|
|
69
|
-
shManager: CoreShaderManager;
|
|
70
|
-
clearColor: number;
|
|
71
|
-
bufferMemory: number;
|
|
72
43
|
contextSpy: ContextSpy | null;
|
|
73
44
|
forceWebGL2: boolean;
|
|
74
45
|
}
|
|
@@ -81,28 +52,33 @@ export interface BufferInfo {
|
|
|
81
52
|
export abstract class CoreRenderer {
|
|
82
53
|
public options: CoreRendererOptions;
|
|
83
54
|
public mode: 'webgl' | 'canvas' | undefined;
|
|
84
|
-
|
|
55
|
+
defaultTextureCoords: TextureCoords | undefined = undefined;
|
|
85
56
|
readonly stage: Stage;
|
|
86
57
|
|
|
87
58
|
//// Core Managers
|
|
88
|
-
txManager: CoreTextureManager;
|
|
89
|
-
txMemManager: TextureMemoryManager;
|
|
90
|
-
shManager: CoreShaderManager;
|
|
91
59
|
rttNodes: CoreNode[] = [];
|
|
92
60
|
|
|
93
61
|
constructor(options: CoreRendererOptions) {
|
|
94
62
|
this.options = options;
|
|
95
63
|
this.stage = options.stage;
|
|
96
|
-
this.txManager = options.txManager;
|
|
97
|
-
this.txMemManager = options.txMemManager;
|
|
98
|
-
this.shManager = options.shManager;
|
|
99
64
|
}
|
|
100
65
|
|
|
101
66
|
abstract reset(): void;
|
|
102
67
|
abstract render(surface?: 'screen' | CoreContextTexture): void;
|
|
103
|
-
abstract addQuad(
|
|
68
|
+
abstract addQuad(node: CoreNode): void;
|
|
104
69
|
abstract createCtxTexture(textureSource: Texture): CoreContextTexture;
|
|
105
|
-
abstract
|
|
70
|
+
abstract createShaderProgram(
|
|
71
|
+
shaderConfig: Readonly<CoreShaderType>,
|
|
72
|
+
props?: Record<string, unknown>,
|
|
73
|
+
): CoreShaderProgram | null;
|
|
74
|
+
abstract createShaderNode(
|
|
75
|
+
shaderKey: string,
|
|
76
|
+
shaderType: Readonly<CoreShaderType>,
|
|
77
|
+
props?: Record<string, unknown>,
|
|
78
|
+
program?: CoreShaderProgram,
|
|
79
|
+
): CoreShaderNode;
|
|
80
|
+
abstract supportsShaderType(shaderType: Readonly<CoreShaderType>): boolean;
|
|
81
|
+
abstract getDefaultShaderNode(): CoreShaderNode | null;
|
|
106
82
|
abstract get renderToTextureActive(): boolean;
|
|
107
83
|
abstract get activeRttNode(): CoreNode | null;
|
|
108
84
|
abstract renderRTTNodes(): void;
|
|
@@ -110,6 +86,15 @@ export abstract class CoreRenderer {
|
|
|
110
86
|
abstract renderToTexture(node: CoreNode): void;
|
|
111
87
|
abstract getBufferInfo(): BufferInfo | null;
|
|
112
88
|
abstract getQuadCount(): number | null;
|
|
113
|
-
abstract
|
|
89
|
+
abstract updateViewport(): void;
|
|
114
90
|
abstract updateClearColor(color: number): void;
|
|
91
|
+
getTextureCoords?(node: CoreNode): TextureCoords | undefined;
|
|
92
|
+
|
|
93
|
+
/**
|
|
94
|
+
* Optional hook called when the render list changes structurally
|
|
95
|
+
* (node added / removed / reordered). Implementations may use this to
|
|
96
|
+
* invalidate any cached GPU buffer layouts and force a full re-upload
|
|
97
|
+
* on the next render call.
|
|
98
|
+
*/
|
|
99
|
+
invalidateQuadBuffer?(): void;
|
|
115
100
|
}
|
|
@@ -0,0 +1,202 @@
|
|
|
1
|
+
import { deepClone } from '../../utils.js';
|
|
2
|
+
import { UpdateType, type CoreNode } from '../CoreNode.js';
|
|
3
|
+
import type { Stage } from '../Stage.js';
|
|
4
|
+
|
|
5
|
+
export interface AdvShaderProp<T = any, Props = Record<string, unknown>> {
|
|
6
|
+
/**
|
|
7
|
+
* default value
|
|
8
|
+
*/
|
|
9
|
+
default: T;
|
|
10
|
+
resolve?: (this: AdvShaderProp<T, Props>, value: T, props: Props) => T;
|
|
11
|
+
transform?: (start: T, end: T, progress: number) => T;
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
export type AdvancedShaderProp<T = any, Props = Record<string, unknown>> =
|
|
15
|
+
| (AdvShaderProp<T, Props> & {
|
|
16
|
+
set: (value: T, props: Props) => void;
|
|
17
|
+
get: (props: Props) => T;
|
|
18
|
+
})
|
|
19
|
+
| (AdvShaderProp<T, Props> & { set?: never; get?: never });
|
|
20
|
+
|
|
21
|
+
export type ShaderProp<T, Props> = T | AdvancedShaderProp<T, Props>;
|
|
22
|
+
|
|
23
|
+
export type ShaderProps<Props> = {
|
|
24
|
+
[K in keyof Props]: ShaderProp<Props[K], Props>;
|
|
25
|
+
};
|
|
26
|
+
|
|
27
|
+
export function isAdvancedShaderProp(obj: any): obj is AdvancedShaderProp {
|
|
28
|
+
return obj !== null && typeof obj === 'object' && obj.default !== undefined;
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
export function resolveShaderProps(
|
|
32
|
+
props: Record<string, unknown>,
|
|
33
|
+
propsConfig: ShaderProps<Record<string, unknown>>,
|
|
34
|
+
) {
|
|
35
|
+
for (const key in propsConfig) {
|
|
36
|
+
if (!isAdvancedShaderProp(propsConfig[key]) && props[key] === undefined) {
|
|
37
|
+
props[key] = propsConfig[key];
|
|
38
|
+
continue;
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
const pConfig = propsConfig[key]! as AdvancedShaderProp;
|
|
42
|
+
const hasValue = props[key] !== undefined;
|
|
43
|
+
|
|
44
|
+
if (pConfig.resolve !== undefined) {
|
|
45
|
+
props[key] = pConfig.resolve!(props[key], props);
|
|
46
|
+
continue;
|
|
47
|
+
}
|
|
48
|
+
if (hasValue && pConfig.set !== undefined) {
|
|
49
|
+
pConfig.set(props[key], props);
|
|
50
|
+
continue;
|
|
51
|
+
}
|
|
52
|
+
if (hasValue) {
|
|
53
|
+
continue;
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
if (props[key] === undefined && pConfig.get === undefined) {
|
|
57
|
+
props[key] = deepClone(pConfig.default);
|
|
58
|
+
continue;
|
|
59
|
+
}
|
|
60
|
+
props[key] = pConfig.get!(props);
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
/**
|
|
65
|
+
* CoreShaderType is a template for ShaderTypes the renderer.
|
|
66
|
+
* You could view a ShaderType as a configuration object that contains methods,
|
|
67
|
+
* and values that you can use to alter the way a node is drawn by the Renderer.
|
|
68
|
+
*/
|
|
69
|
+
export interface CoreShaderType<Props extends object = any> {
|
|
70
|
+
/**
|
|
71
|
+
* Values you use to draw the Shader
|
|
72
|
+
*/
|
|
73
|
+
props?: ShaderProps<Props>;
|
|
74
|
+
/**
|
|
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
|
|
76
|
+
*/
|
|
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);
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
/**
|
|
86
|
+
* CoreShaderNode is a base class that manages the shader prop values.
|
|
87
|
+
* When a prop is being updated the CoreShaderNode will notify either the associated CoreNode,
|
|
88
|
+
* or the Stage that there has been a change and a new render of the scene.
|
|
89
|
+
*/
|
|
90
|
+
export class CoreShaderNode<Props extends object = Record<string, unknown>> {
|
|
91
|
+
readonly stage: Stage;
|
|
92
|
+
readonly shaderType: CoreShaderType<Props>;
|
|
93
|
+
protected propsConfig: ShaderProps<Props> | undefined;
|
|
94
|
+
readonly resolvedProps: Props | undefined = undefined;
|
|
95
|
+
protected definedProps: Props | undefined = undefined;
|
|
96
|
+
protected node: CoreNode | null = null;
|
|
97
|
+
readonly time: CoreShaderType['time'] = undefined;
|
|
98
|
+
update: (() => void) | undefined = undefined;
|
|
99
|
+
private _valueKeyCache = '';
|
|
100
|
+
private _valueKeyDirty = true;
|
|
101
|
+
private _lastW = 0;
|
|
102
|
+
private _lastH = 0;
|
|
103
|
+
|
|
104
|
+
constructor(
|
|
105
|
+
readonly shaderKey: string,
|
|
106
|
+
type: CoreShaderType<Props>,
|
|
107
|
+
stage: Stage,
|
|
108
|
+
props?: Props,
|
|
109
|
+
) {
|
|
110
|
+
this.stage = stage;
|
|
111
|
+
this.shaderType = type;
|
|
112
|
+
this.time = type.time;
|
|
113
|
+
|
|
114
|
+
if (props !== undefined) {
|
|
115
|
+
/**
|
|
116
|
+
* props are already resolved by shadermanager
|
|
117
|
+
*/
|
|
118
|
+
this.resolvedProps = props;
|
|
119
|
+
this.defineProps(props);
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
private defineProps(props: Props) {
|
|
124
|
+
const definedProps = {};
|
|
125
|
+
for (const key in props) {
|
|
126
|
+
const propConfig = this.shaderType.props![key];
|
|
127
|
+
const isAdvancedProp = isAdvancedShaderProp(propConfig);
|
|
128
|
+
|
|
129
|
+
Object.defineProperty(definedProps, key, {
|
|
130
|
+
get: () => {
|
|
131
|
+
return this.resolvedProps![key as keyof Props];
|
|
132
|
+
},
|
|
133
|
+
set: (value) => {
|
|
134
|
+
// this.resolvedProps![key as keyof Props] = value;
|
|
135
|
+
if (isAdvancedProp === true && propConfig.resolve !== undefined) {
|
|
136
|
+
this.resolvedProps![key] = propConfig.resolve(
|
|
137
|
+
value,
|
|
138
|
+
this.resolvedProps as Record<string, unknown>,
|
|
139
|
+
);
|
|
140
|
+
} else if (isAdvancedProp === true && propConfig.set !== undefined) {
|
|
141
|
+
propConfig.set(
|
|
142
|
+
value,
|
|
143
|
+
this.resolvedProps as Record<string, unknown>,
|
|
144
|
+
);
|
|
145
|
+
} else {
|
|
146
|
+
this.resolvedProps![key] = value;
|
|
147
|
+
}
|
|
148
|
+
this._valueKeyDirty = true;
|
|
149
|
+
|
|
150
|
+
if (this.update !== undefined && this.node !== null) {
|
|
151
|
+
this.node.setUpdateType(UpdateType.RecalcUniforms);
|
|
152
|
+
} else {
|
|
153
|
+
this.stage.requestRender();
|
|
154
|
+
}
|
|
155
|
+
},
|
|
156
|
+
});
|
|
157
|
+
}
|
|
158
|
+
this.definedProps = definedProps as Props;
|
|
159
|
+
}
|
|
160
|
+
|
|
161
|
+
attachNode(node: CoreNode) {
|
|
162
|
+
this.node = node;
|
|
163
|
+
}
|
|
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
|
+
|
|
190
|
+
get props(): Props | undefined {
|
|
191
|
+
return this.definedProps;
|
|
192
|
+
}
|
|
193
|
+
|
|
194
|
+
set props(props: Props | undefined) {
|
|
195
|
+
if (props === undefined) {
|
|
196
|
+
return;
|
|
197
|
+
}
|
|
198
|
+
for (const key in props) {
|
|
199
|
+
this.props![key] = props[key];
|
|
200
|
+
}
|
|
201
|
+
}
|
|
202
|
+
}
|