@lightningtv/renderer 3.0.0-beta1 → 3.2.4
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 +1 -1
- package/dist/exports/canvas.js +1 -19
- package/dist/exports/canvas.js.map +1 -1
- package/dist/exports/index.d.ts +2 -5
- package/dist/exports/index.js +1 -23
- 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 +2 -1
- package/dist/exports/webgl.js +2 -19
- 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 +139 -101
- package/dist/src/core/CoreNode.js +813 -528
- package/dist/src/core/CoreNode.js.map +1 -1
- package/dist/src/core/CoreShaderManager.d.ts +3 -3
- package/dist/src/core/CoreShaderManager.js +0 -18
- 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 +25 -14
- package/dist/src/core/CoreTextureManager.js +83 -140
- package/dist/src/core/CoreTextureManager.js.map +1 -1
- package/dist/src/core/Stage.d.ts +102 -36
- package/dist/src/core/Stage.js +424 -191
- 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 +114 -134
- 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 -3
- package/dist/src/core/animations/CoreAnimation.js +8 -24
- 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 -22
- 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 +33 -31
- 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 +78 -3
- package/dist/src/core/lib/WebGlContextWrapper.js +150 -25
- 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.js → lib/colorParser.js} +1 -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 -85
- 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 -1
- package/dist/src/core/lib/utils.js +44 -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 +42 -0
- package/dist/src/core/platforms/Platform.js +4 -0
- 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 +90 -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 +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 +15 -3
- package/dist/src/core/renderers/CoreRenderer.js +1 -18
- package/dist/src/core/renderers/CoreRenderer.js.map +1 -1
- package/dist/src/core/renderers/CoreShaderNode.d.ts +13 -3
- package/dist/src/core/renderers/CoreShaderNode.js +25 -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 +4 -5
- package/dist/src/core/renderers/canvas/CanvasRenderer.js +89 -83
- package/dist/src/core/renderers/canvas/CanvasRenderer.js.map +1 -1
- package/dist/src/core/renderers/canvas/CanvasShaderNode.js +3 -21
- 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 +18 -31
- package/dist/src/core/renderers/canvas/CanvasTexture.js.map +1 -1
- package/dist/src/core/renderers/webgl/BatchRenderOp.d.ts +25 -0
- package/dist/src/core/renderers/webgl/BatchRenderOp.js +60 -0
- package/dist/src/core/renderers/webgl/BatchRenderOp.js.map +1 -0
- 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 -70
- package/dist/src/core/renderers/webgl/WebGlCtxTexture.js.map +1 -1
- package/dist/src/core/renderers/webgl/WebGlRenderer.d.ts +34 -20
- package/dist/src/core/renderers/webgl/WebGlRenderer.js +319 -195
- package/dist/src/core/renderers/webgl/WebGlRenderer.js.map +1 -1
- package/dist/src/core/renderers/webgl/WebGlShaderNode.d.ts +2 -3
- 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 +99 -48
- 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.js +0 -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 +7 -21
- package/dist/src/core/shaders/canvas/LinearGradient.js.map +1 -1
- package/dist/src/core/shaders/canvas/RadialGradient.js +14 -28
- 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 +44 -22
- 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 +47 -25
- package/dist/src/core/shaders/canvas/RoundedWithBorderAndShadow.js.map +1 -1
- package/dist/src/core/shaders/canvas/RoundedWithShadow.js +9 -21
- 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 +12 -2
- package/dist/src/core/shaders/templates/BorderTemplate.js +31 -27
- 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 -19
- 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 +1 -17
- 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/RoundedWithBorderAndShadowTemplate.js +0 -16
- package/dist/src/core/shaders/templates/RoundedWithBorderAndShadowTemplate.js.map +1 -1
- package/dist/src/core/shaders/templates/RoundedWithBorderTemplate.d.ts +4 -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.d.ts +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.d.ts +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/{templates/shaderUtils.d.ts → utils.d.ts} +1 -1
- package/dist/src/core/shaders/utils.js +25 -0
- package/dist/src/core/shaders/utils.js.map +1 -0
- package/dist/src/core/shaders/webgl/Border.js +118 -51
- 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 +4 -19
- package/dist/src/core/shaders/webgl/HolePunch.js.map +1 -1
- package/dist/src/core/shaders/webgl/LinearGradient.js +73 -34
- package/dist/src/core/shaders/webgl/LinearGradient.js.map +1 -1
- package/dist/src/core/shaders/webgl/RadialGradient.js +56 -48
- 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 +160 -55
- package/dist/src/core/shaders/webgl/RoundedWithBorder.js.map +1 -1
- package/dist/src/core/shaders/webgl/RoundedWithBorderAndShadow.js +168 -58
- 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 +8 -36
- 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 +13 -6
- package/dist/src/core/textures/ImageTexture.js +57 -66
- 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 +90 -12
- package/dist/src/core/textures/Texture.js +160 -35
- 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.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 +294 -81
- package/dist/src/main-api/Renderer.js +225 -96
- package/dist/src/main-api/Renderer.js.map +1 -1
- package/dist/src/utils.d.ts +19 -6
- package/dist/src/utils.js +32 -27
- package/dist/src/utils.js.map +1 -1
- package/dist/tsconfig.dist.tsbuildinfo +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/exports/canvas-shaders.ts +0 -17
- package/exports/canvas.ts +1 -19
- package/exports/index.ts +6 -27
- package/exports/inspector.ts +0 -19
- package/exports/utils.ts +7 -19
- package/exports/webgl-shaders.ts +0 -16
- package/exports/webgl.ts +3 -20
- package/package.json +23 -22
- 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 +376 -45
- package/src/core/CoreNode.ts +1017 -656
- package/src/core/CoreShaderManager.ts +3 -21
- package/src/core/CoreTextNode.ts +457 -314
- package/src/core/CoreTextureManager.ts +123 -168
- package/src/core/Stage.ts +526 -236
- package/src/core/TextureError.ts +46 -0
- package/src/core/TextureMemoryManager.ts +150 -167
- package/src/core/animations/AnimationManager.ts +0 -19
- package/src/core/animations/CoreAnimation.ts +15 -32
- package/src/core/animations/CoreAnimationController.ts +13 -23
- package/src/core/lib/ContextSpy.ts +0 -19
- package/src/core/lib/ImageWorker.ts +45 -32
- package/src/core/lib/Matrix3d.ts +7 -20
- package/src/core/lib/RenderCoords.ts +36 -67
- package/src/core/lib/WebGlContextWrapper.ts +196 -72
- 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} +2 -21
- package/src/core/lib/textureCompression.ts +433 -93
- package/src/core/lib/textureSvg.ts +0 -19
- package/src/core/lib/utils.ts +58 -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 +2 -20
- package/src/core/renderers/CoreRenderOp.ts +0 -19
- package/src/core/renderers/CoreRenderer.ts +16 -23
- package/src/core/renderers/CoreShaderNode.ts +37 -6
- package/src/core/renderers/CoreShaderProgram.ts +0 -19
- package/src/core/renderers/canvas/CanvasRenderer.ts +108 -137
- package/src/core/renderers/canvas/CanvasShaderNode.ts +3 -23
- package/src/core/renderers/canvas/CanvasTexture.ts +25 -37
- package/src/core/renderers/webgl/SdfRenderOp.ts +88 -0
- package/src/core/renderers/webgl/WebGlCtxRenderTexture.ts +18 -34
- package/src/core/renderers/webgl/WebGlCtxSubTexture.ts +50 -24
- package/src/core/renderers/webgl/WebGlCtxTexture.ts +134 -103
- package/src/core/renderers/webgl/WebGlRenderer.ts +368 -233
- package/src/core/renderers/webgl/WebGlShaderNode.ts +4 -7
- package/src/core/renderers/webgl/WebGlShaderProgram.ts +122 -76
- 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 +0 -19
- package/src/core/renderers/webgl/internal/WebGlUtils.ts +0 -19
- package/src/core/shaders/canvas/Border.ts +91 -50
- package/src/core/shaders/canvas/HolePunch.ts +4 -28
- package/src/core/shaders/canvas/LinearGradient.ts +10 -25
- package/src/core/shaders/canvas/RadialGradient.ts +23 -54
- package/src/core/shaders/canvas/Rounded.ts +2 -19
- package/src/core/shaders/canvas/RoundedWithBorder.ts +72 -35
- package/src/core/shaders/canvas/RoundedWithBorderAndShadow.ts +77 -47
- package/src/core/shaders/canvas/RoundedWithShadow.ts +21 -34
- package/src/core/shaders/canvas/Shadow.ts +0 -17
- package/src/core/shaders/canvas/utils/render.ts +45 -53
- package/src/core/shaders/templates/BorderTemplate.ts +42 -29
- package/src/core/shaders/templates/HolePunchTemplate.ts +5 -22
- package/src/core/shaders/templates/LinearGradientTemplate.ts +0 -17
- package/src/core/shaders/templates/RadialGradientTemplate.ts +10 -25
- package/src/core/shaders/templates/RoundedTemplate.ts +1 -18
- package/src/core/shaders/templates/RoundedWithBorderAndShadowTemplate.ts +1 -18
- package/src/core/shaders/templates/RoundedWithBorderTemplate.ts +7 -19
- package/src/core/shaders/templates/RoundedWithShadowTemplate.ts +1 -18
- package/src/core/shaders/templates/ShadowTemplate.ts +1 -18
- package/src/core/shaders/utils.ts +30 -0
- package/src/core/shaders/webgl/Border.ts +118 -55
- package/src/core/shaders/webgl/Default.ts +6 -43
- package/src/core/shaders/webgl/HolePunch.ts +4 -24
- package/src/core/shaders/webgl/LinearGradient.ts +73 -35
- package/src/core/shaders/webgl/RadialGradient.ts +58 -51
- package/src/core/shaders/webgl/Rounded.ts +25 -45
- package/src/core/shaders/webgl/RoundedWithBorder.ts +161 -63
- package/src/core/shaders/webgl/RoundedWithBorderAndShadow.ts +169 -68
- package/src/core/shaders/webgl/RoundedWithShadow.ts +73 -39
- package/src/core/shaders/webgl/SdfShader.ts +8 -41
- package/src/core/shaders/webgl/Shadow.ts +39 -35
- 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 +110 -92
- 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 +214 -46
- package/src/core/utils.ts +9 -26
- package/src/main-api/INode.ts +0 -18
- package/src/main-api/Inspector.ts +794 -38
- package/src/main-api/Renderer.ts +519 -159
- package/src/utils.ts +64 -29
- package/dist/src/core/platform.d.ts +0 -10
- package/dist/src/core/platform.js +0 -56
- package/dist/src/core/platform.js.map +0 -1
- package/dist/src/core/renderers/canvas/internal/C2DShaderUtils.d.ts +0 -1
- package/dist/src/core/renderers/canvas/internal/C2DShaderUtils.js +0 -217
- 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/webgl/WebGlRenderOp.d.ts +0 -36
- package/dist/src/core/renderers/webgl/WebGlRenderOp.js +0 -107
- package/dist/src/core/renderers/webgl/WebGlRenderOp.js.map +0 -1
- 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/DefaultBatched.d.ts +0 -2
- package/dist/src/core/shaders/webgl/DefaultBatched.js +0 -104
- package/dist/src/core/shaders/webgl/DefaultBatched.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 -126
- 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 -91
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.js +0 -611
- 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 -370
- package/dist/src/core/text-rendering/renderers/TextRenderer.js +0 -178
- package/dist/src/core/text-rendering/renderers/TextRenderer.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 -145
- package/src/core/shaders/templates/shaderUtils.ts +0 -47
- package/src/core/shaders/webgl/DefaultBatched.ts +0 -129
- 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 -841
- 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/dist/src/core/{renderers/canvas/internal/ColorUtils.d.ts → lib/colorParser.d.ts} +0 -0
package/src/core/lib/utils.ts
CHANGED
|
@@ -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 { Vec4 } from '../renderers/webgl/internal/ShaderUtils.js';
|
|
21
2
|
|
|
22
3
|
export const PROTOCOL_REGEX = /^(data|ftps?|https?):/;
|
|
@@ -97,6 +78,11 @@ export interface Bound {
|
|
|
97
78
|
y2: number;
|
|
98
79
|
}
|
|
99
80
|
|
|
81
|
+
export interface Coord {
|
|
82
|
+
x: number;
|
|
83
|
+
y: number;
|
|
84
|
+
}
|
|
85
|
+
|
|
100
86
|
export interface BoundWithValid extends Bound {
|
|
101
87
|
valid: boolean;
|
|
102
88
|
}
|
|
@@ -255,6 +241,10 @@ export function boundLargeThanBound(bound1: Bound, bound2: Bound) {
|
|
|
255
241
|
);
|
|
256
242
|
}
|
|
257
243
|
|
|
244
|
+
export function pointInBound(x: number, y: number, bound: Bound) {
|
|
245
|
+
return !(x < bound.x1 || x > bound.x2 || y < bound.y1 || y > bound.y2);
|
|
246
|
+
}
|
|
247
|
+
|
|
258
248
|
export function isBoundPositive(bound: Bound): boolean {
|
|
259
249
|
return bound.x1 < bound.x2 && bound.y1 < bound.y2;
|
|
260
250
|
}
|
|
@@ -273,12 +263,14 @@ export function isRectPositive(rect: Rect): boolean {
|
|
|
273
263
|
export function createPreloadBounds(
|
|
274
264
|
strictBound: Bound,
|
|
275
265
|
boundsMargin: [number, number, number, number],
|
|
266
|
+
out?: Bound,
|
|
276
267
|
): Bound {
|
|
277
268
|
return createBound(
|
|
278
269
|
strictBound.x1 - boundsMargin[3],
|
|
279
270
|
strictBound.y1 - boundsMargin[0],
|
|
280
271
|
strictBound.x2 + boundsMargin[1],
|
|
281
272
|
strictBound.y2 + boundsMargin[2],
|
|
273
|
+
out,
|
|
282
274
|
);
|
|
283
275
|
}
|
|
284
276
|
|
|
@@ -359,3 +351,50 @@ export function calcFactoredRadiusArray(
|
|
|
359
351
|
result[3] *= factor;
|
|
360
352
|
return result;
|
|
361
353
|
}
|
|
354
|
+
|
|
355
|
+
export function dataURIToBlob(dataURI: string): Blob {
|
|
356
|
+
dataURI = dataURI.replace(/^data:/, '');
|
|
357
|
+
|
|
358
|
+
const type = dataURI.match(/image\/[^;]+/)?.[0] || '';
|
|
359
|
+
const base64 = dataURI.replace(/^[^,]+,/, '');
|
|
360
|
+
|
|
361
|
+
const sliceSize = 1024;
|
|
362
|
+
const byteCharacters = atob(base64);
|
|
363
|
+
const bytesLength = byteCharacters.length;
|
|
364
|
+
const slicesCount = Math.ceil(bytesLength / sliceSize);
|
|
365
|
+
const byteArrays = new Array(slicesCount);
|
|
366
|
+
|
|
367
|
+
for (let sliceIndex = 0; sliceIndex < slicesCount; ++sliceIndex) {
|
|
368
|
+
const begin = sliceIndex * sliceSize;
|
|
369
|
+
const end = Math.min(begin + sliceSize, bytesLength);
|
|
370
|
+
|
|
371
|
+
const bytes = new Array(end - begin);
|
|
372
|
+
for (let offset = begin, i = 0; offset < end; ++i, ++offset) {
|
|
373
|
+
bytes[i] = byteCharacters[offset]?.charCodeAt(0);
|
|
374
|
+
}
|
|
375
|
+
byteArrays[sliceIndex] = new Uint8Array(bytes);
|
|
376
|
+
}
|
|
377
|
+
return new Blob(byteArrays, { type });
|
|
378
|
+
}
|
|
379
|
+
|
|
380
|
+
export function fetchJson(
|
|
381
|
+
url: string,
|
|
382
|
+
responseType: XMLHttpRequestResponseType = '',
|
|
383
|
+
): Promise<unknown> {
|
|
384
|
+
return new Promise((resolve, reject) => {
|
|
385
|
+
const xhr = new XMLHttpRequest();
|
|
386
|
+
xhr.responseType = responseType;
|
|
387
|
+
xhr.onreadystatechange = function () {
|
|
388
|
+
if (xhr.readyState == XMLHttpRequest.DONE) {
|
|
389
|
+
// On most devices like WebOS and Tizen, the file protocol returns 0 while http(s) protocol returns 200
|
|
390
|
+
if (xhr.status === 0 || xhr.status === 200) {
|
|
391
|
+
resolve(xhr.response);
|
|
392
|
+
} else {
|
|
393
|
+
reject(xhr.statusText);
|
|
394
|
+
}
|
|
395
|
+
}
|
|
396
|
+
};
|
|
397
|
+
xhr.open('GET', url, true);
|
|
398
|
+
xhr.send(null);
|
|
399
|
+
});
|
|
400
|
+
}
|
|
@@ -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
|
|
|
@@ -34,7 +15,8 @@ export abstract class CoreContextTexture {
|
|
|
34
15
|
this.memManager.setTextureMemUse(this.textureSource, byteSize);
|
|
35
16
|
}
|
|
36
17
|
|
|
37
|
-
abstract load(): void
|
|
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,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 { Dimensions } from '../../common/CommonTypes.js';
|
|
21
2
|
import type { CoreNode } from '../CoreNode.js';
|
|
22
3
|
import type { TextureOptions } from '../CoreTextureManager.js';
|
|
@@ -25,7 +6,7 @@ import type { ContextSpy } from '../lib/ContextSpy.js';
|
|
|
25
6
|
import type { RenderCoords } from '../lib/RenderCoords.js';
|
|
26
7
|
import type { RectWithValid } from '../lib/utils.js';
|
|
27
8
|
import type { CoreShaderProgram } from './CoreShaderProgram.js';
|
|
28
|
-
import type { Texture } from '../textures/Texture.js';
|
|
9
|
+
import type { Texture, TextureCoords } from '../textures/Texture.js';
|
|
29
10
|
import { CoreContextTexture } from './CoreContextTexture.js';
|
|
30
11
|
import type { CoreShaderType, CoreShaderNode } from './CoreShaderNode.js';
|
|
31
12
|
|
|
@@ -38,6 +19,7 @@ export interface QuadOptions {
|
|
|
38
19
|
colorBr: number;
|
|
39
20
|
texture: Texture | null;
|
|
40
21
|
textureOptions: TextureOptions | null;
|
|
22
|
+
textureCoords: TextureCoords | undefined;
|
|
41
23
|
zIndex: number;
|
|
42
24
|
shader: CoreShaderNode | null;
|
|
43
25
|
alpha: number;
|
|
@@ -51,7 +33,8 @@ export interface QuadOptions {
|
|
|
51
33
|
renderCoords?: RenderCoords;
|
|
52
34
|
rtt: boolean;
|
|
53
35
|
parentHasRenderTexture: boolean;
|
|
54
|
-
framebufferDimensions: Dimensions;
|
|
36
|
+
framebufferDimensions: Dimensions | null;
|
|
37
|
+
time?: number | null;
|
|
55
38
|
}
|
|
56
39
|
|
|
57
40
|
export interface CoreRendererOptions {
|
|
@@ -69,7 +52,7 @@ export interface BufferInfo {
|
|
|
69
52
|
export abstract class CoreRenderer {
|
|
70
53
|
public options: CoreRendererOptions;
|
|
71
54
|
public mode: 'webgl' | 'canvas' | undefined;
|
|
72
|
-
|
|
55
|
+
defaultTextureCoords: TextureCoords | undefined = undefined;
|
|
73
56
|
readonly stage: Stage;
|
|
74
57
|
|
|
75
58
|
//// Core Managers
|
|
@@ -82,7 +65,7 @@ export abstract class CoreRenderer {
|
|
|
82
65
|
|
|
83
66
|
abstract reset(): void;
|
|
84
67
|
abstract render(surface?: 'screen' | CoreContextTexture): void;
|
|
85
|
-
abstract addQuad(
|
|
68
|
+
abstract addQuad(node: CoreNode): void;
|
|
86
69
|
abstract createCtxTexture(textureSource: Texture): CoreContextTexture;
|
|
87
70
|
abstract createShaderProgram(
|
|
88
71
|
shaderConfig: Readonly<CoreShaderType>,
|
|
@@ -103,5 +86,15 @@ export abstract class CoreRenderer {
|
|
|
103
86
|
abstract renderToTexture(node: CoreNode): void;
|
|
104
87
|
abstract getBufferInfo(): BufferInfo | null;
|
|
105
88
|
abstract getQuadCount(): number | null;
|
|
89
|
+
abstract updateViewport(): void;
|
|
106
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;
|
|
107
100
|
}
|
|
@@ -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
|
/**
|
|
@@ -88,10 +91,15 @@ export class CoreShaderNode<Props extends object = Record<string, unknown>> {
|
|
|
88
91
|
readonly stage: Stage;
|
|
89
92
|
readonly shaderType: CoreShaderType<Props>;
|
|
90
93
|
protected propsConfig: ShaderProps<Props> | undefined;
|
|
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,8 +162,29 @@ export class CoreShaderNode<Props extends object = Record<string, unknown>> {
|
|
|
152
162
|
this.node = node;
|
|
153
163
|
}
|
|
154
164
|
|
|
155
|
-
|
|
156
|
-
|
|
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;
|
|
157
188
|
}
|
|
158
189
|
|
|
159
190
|
get props(): Props | undefined {
|
|
@@ -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 interface CoreShaderProgram {
|
|
21
2
|
attach?: () => void;
|
|
22
3
|
detach?: () => void;
|