@lightningjs/renderer 3.0.0-beta10 → 3.0.0-beta12
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +202 -202
- package/NOTICE +3 -3
- package/README.md +133 -133
- package/dist/src/common/CommonTypes.d.ts +2 -2
- package/dist/src/core/CoreNode.d.ts +8 -7
- package/dist/src/core/CoreNode.js +57 -61
- package/dist/src/core/CoreNode.js.map +1 -1
- package/dist/src/core/CoreTextNode.d.ts +3 -0
- package/dist/src/core/CoreTextNode.js +54 -19
- package/dist/src/core/CoreTextNode.js.map +1 -1
- package/dist/src/core/Stage.js +4 -4
- package/dist/src/core/Stage.js.map +1 -1
- package/dist/src/core/lib/textureCompression.js +4 -4
- package/dist/src/core/lib/textureCompression.js.map +1 -1
- package/dist/src/core/platform.d.ts +10 -0
- package/dist/src/core/platform.js +81 -0
- package/dist/src/core/platform.js.map +1 -0
- package/dist/src/core/renderers/CoreShader.d.ts +9 -0
- package/dist/src/core/renderers/CoreShader.js +28 -0
- package/dist/src/core/renderers/CoreShader.js.map +1 -0
- package/dist/src/core/renderers/CoreShaderNode.js +2 -2
- package/dist/src/core/renderers/CoreShaderNode.js.map +1 -1
- package/dist/src/core/renderers/canvas/CanvasCoreRenderer.d.ts +33 -0
- package/dist/src/core/renderers/canvas/CanvasCoreRenderer.js +250 -0
- package/dist/src/core/renderers/canvas/CanvasCoreRenderer.js.map +1 -0
- package/dist/src/core/renderers/canvas/CanvasCoreTexture.d.ts +16 -0
- package/dist/src/core/renderers/canvas/CanvasCoreTexture.js +124 -0
- package/dist/src/core/renderers/canvas/CanvasCoreTexture.js.map +1 -0
- package/dist/src/core/renderers/canvas/CanvasRenderer.js +1 -1
- package/dist/src/core/renderers/canvas/CanvasRenderer.js.map +1 -1
- package/dist/src/core/renderers/canvas/CanvasTexture.js +5 -5
- package/dist/src/core/renderers/canvas/CanvasTexture.js.map +1 -1
- package/dist/src/core/renderers/canvas/internal/C2DShaderUtils.d.ts +13 -0
- package/dist/src/core/renderers/canvas/internal/C2DShaderUtils.js +113 -192
- package/dist/src/core/renderers/canvas/internal/C2DShaderUtils.js.map +1 -1
- package/dist/src/core/renderers/canvas/internal/ColorUtils.d.ts +0 -2
- package/dist/src/core/renderers/canvas/internal/ColorUtils.js +0 -14
- package/dist/src/core/renderers/canvas/internal/ColorUtils.js.map +1 -1
- package/dist/src/core/renderers/canvas/shaders/UnsupportedShader.d.ts +10 -0
- package/dist/src/core/renderers/canvas/shaders/UnsupportedShader.js +43 -0
- package/dist/src/core/renderers/canvas/shaders/UnsupportedShader.js.map +1 -0
- package/dist/src/core/renderers/webgl/WebGlCoreCtxRenderTexture.d.ts +12 -0
- package/dist/src/core/renderers/webgl/WebGlCoreCtxRenderTexture.js +58 -0
- package/dist/src/core/renderers/webgl/WebGlCoreCtxRenderTexture.js.map +1 -0
- package/dist/src/core/renderers/webgl/WebGlCoreCtxSubTexture.d.ts +9 -0
- package/dist/src/core/renderers/webgl/WebGlCoreCtxSubTexture.js +38 -0
- package/dist/src/core/renderers/webgl/WebGlCoreCtxSubTexture.js.map +1 -0
- package/dist/src/core/renderers/webgl/WebGlCoreCtxTexture.d.ts +56 -0
- package/dist/src/core/renderers/webgl/WebGlCoreCtxTexture.js +239 -0
- package/dist/src/core/renderers/webgl/WebGlCoreCtxTexture.js.map +1 -0
- package/dist/src/core/renderers/webgl/WebGlCoreRenderOp.d.ts +34 -0
- package/dist/src/core/renderers/webgl/WebGlCoreRenderOp.js +114 -0
- package/dist/src/core/renderers/webgl/WebGlCoreRenderOp.js.map +1 -0
- package/dist/src/core/renderers/webgl/WebGlCoreRenderer.d.ts +133 -0
- package/dist/src/core/renderers/webgl/WebGlCoreRenderer.js +616 -0
- package/dist/src/core/renderers/webgl/WebGlCoreRenderer.js.map +1 -0
- package/dist/src/core/renderers/webgl/WebGlCoreShader.d.ts +83 -0
- package/dist/src/core/renderers/webgl/WebGlCoreShader.js +233 -0
- package/dist/src/core/renderers/webgl/WebGlCoreShader.js.map +1 -0
- package/dist/src/core/renderers/webgl/WebGlCtxRenderTexture.js +5 -6
- package/dist/src/core/renderers/webgl/WebGlCtxRenderTexture.js.map +1 -1
- package/dist/src/core/renderers/webgl/WebGlCtxSubTexture.d.ts +13 -0
- package/dist/src/core/renderers/webgl/WebGlCtxSubTexture.js +34 -5
- package/dist/src/core/renderers/webgl/WebGlCtxSubTexture.js.map +1 -1
- package/dist/src/core/renderers/webgl/WebGlCtxTexture.js +21 -21
- package/dist/src/core/renderers/webgl/WebGlCtxTexture.js.map +1 -1
- package/dist/src/core/renderers/webgl/WebGlRenderOp.js +1 -1
- package/dist/src/core/renderers/webgl/WebGlRenderOp.js.map +1 -1
- package/dist/src/core/renderers/webgl/WebGlRenderer.js +12 -11
- package/dist/src/core/renderers/webgl/WebGlRenderer.js.map +1 -1
- package/dist/src/core/renderers/webgl/WebGlShaderProgram.js +2 -2
- package/dist/src/core/renderers/webgl/WebGlShaderProgram.js.map +1 -1
- package/dist/src/core/renderers/webgl/internal/ShaderUtils.js +35 -35
- package/dist/src/core/renderers/webgl/shaders/DefaultShader.d.ts +9 -0
- package/dist/src/core/renderers/webgl/shaders/DefaultShader.js +87 -0
- package/dist/src/core/renderers/webgl/shaders/DefaultShader.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/DefaultShaderBatched.d.ts +10 -0
- package/dist/src/core/renderers/webgl/shaders/DefaultShaderBatched.js +119 -0
- package/dist/src/core/renderers/webgl/shaders/DefaultShaderBatched.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/DynamicShader.d.ts +29 -0
- package/dist/src/core/renderers/webgl/shaders/DynamicShader.js +413 -0
- package/dist/src/core/renderers/webgl/shaders/DynamicShader.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/RoundedRectangle.d.ts +28 -0
- package/dist/src/core/renderers/webgl/shaders/RoundedRectangle.js +131 -0
- package/dist/src/core/renderers/webgl/shaders/RoundedRectangle.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/SdfShader.d.ts +47 -0
- package/dist/src/core/renderers/webgl/shaders/SdfShader.js +160 -0
- package/dist/src/core/renderers/webgl/shaders/SdfShader.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/effects/BorderBottomEffect.d.ts +31 -0
- package/dist/src/core/renderers/webgl/shaders/effects/BorderBottomEffect.js +71 -0
- package/dist/src/core/renderers/webgl/shaders/effects/BorderBottomEffect.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/effects/BorderEffect.d.ts +30 -0
- package/dist/src/core/renderers/webgl/shaders/effects/BorderEffect.js +58 -0
- package/dist/src/core/renderers/webgl/shaders/effects/BorderEffect.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/effects/BorderLeftEffect.d.ts +31 -0
- package/dist/src/core/renderers/webgl/shaders/effects/BorderLeftEffect.js +71 -0
- package/dist/src/core/renderers/webgl/shaders/effects/BorderLeftEffect.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/effects/BorderRightEffect.d.ts +31 -0
- package/dist/src/core/renderers/webgl/shaders/effects/BorderRightEffect.js +71 -0
- package/dist/src/core/renderers/webgl/shaders/effects/BorderRightEffect.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/effects/BorderTopEffect.d.ts +31 -0
- package/dist/src/core/renderers/webgl/shaders/effects/BorderTopEffect.js +71 -0
- package/dist/src/core/renderers/webgl/shaders/effects/BorderTopEffect.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/effects/EffectUtils.d.ts +9 -0
- package/dist/src/core/renderers/webgl/shaders/effects/EffectUtils.js +136 -0
- package/dist/src/core/renderers/webgl/shaders/effects/EffectUtils.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/effects/FadeOutEffect.d.ts +36 -0
- package/dist/src/core/renderers/webgl/shaders/effects/FadeOutEffect.js +85 -0
- package/dist/src/core/renderers/webgl/shaders/effects/FadeOutEffect.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/effects/GlitchEffect.d.ts +45 -0
- package/dist/src/core/renderers/webgl/shaders/effects/GlitchEffect.js +104 -0
- package/dist/src/core/renderers/webgl/shaders/effects/GlitchEffect.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/effects/GrayscaleEffect.d.ts +22 -0
- package/dist/src/core/renderers/webgl/shaders/effects/GrayscaleEffect.js +45 -0
- package/dist/src/core/renderers/webgl/shaders/effects/GrayscaleEffect.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/effects/HolePunchEffect.d.ts +58 -0
- package/dist/src/core/renderers/webgl/shaders/effects/HolePunchEffect.js +80 -0
- package/dist/src/core/renderers/webgl/shaders/effects/HolePunchEffect.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/effects/LinearGradientEffect.d.ts +35 -0
- package/dist/src/core/renderers/webgl/shaders/effects/LinearGradientEffect.js +129 -0
- package/dist/src/core/renderers/webgl/shaders/effects/LinearGradientEffect.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/effects/RadialGradientEffect.d.ts +39 -0
- package/dist/src/core/renderers/webgl/shaders/effects/RadialGradientEffect.js +116 -0
- package/dist/src/core/renderers/webgl/shaders/effects/RadialGradientEffect.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/effects/RadialProgressEffect.d.ts +61 -0
- package/dist/src/core/renderers/webgl/shaders/effects/RadialProgressEffect.js +127 -0
- package/dist/src/core/renderers/webgl/shaders/effects/RadialProgressEffect.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/effects/RadiusEffect.d.ts +40 -0
- package/dist/src/core/renderers/webgl/shaders/effects/RadiusEffect.js +71 -0
- package/dist/src/core/renderers/webgl/shaders/effects/RadiusEffect.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/effects/ShaderEffect.d.ts +115 -0
- package/dist/src/core/renderers/webgl/shaders/effects/ShaderEffect.js +61 -0
- package/dist/src/core/renderers/webgl/shaders/effects/ShaderEffect.js.map +1 -0
- package/dist/src/core/shaders/canvas/Border.js +4 -4
- package/dist/src/core/shaders/canvas/Border.js.map +1 -1
- package/dist/src/core/shaders/canvas/HolePunch.js +3 -3
- package/dist/src/core/shaders/canvas/HolePunch.js.map +1 -1
- package/dist/src/core/shaders/canvas/LinearGradient.js +2 -2
- package/dist/src/core/shaders/canvas/LinearGradient.js.map +1 -1
- package/dist/src/core/shaders/canvas/RadialGradient.js +4 -4
- package/dist/src/core/shaders/canvas/RadialGradient.js.map +1 -1
- package/dist/src/core/shaders/canvas/Rounded.js +1 -1
- package/dist/src/core/shaders/canvas/Rounded.js.map +1 -1
- package/dist/src/core/shaders/canvas/RoundedWithBorder.js +3 -3
- package/dist/src/core/shaders/canvas/RoundedWithBorder.js.map +1 -1
- package/dist/src/core/shaders/canvas/RoundedWithBorderAndShadow.js +3 -3
- package/dist/src/core/shaders/canvas/RoundedWithBorderAndShadow.js.map +1 -1
- package/dist/src/core/shaders/canvas/RoundedWithShadow.js +1 -1
- package/dist/src/core/shaders/canvas/RoundedWithShadow.js.map +1 -1
- package/dist/src/core/shaders/templates/BorderTemplate.d.ts +1 -1
- package/dist/src/core/shaders/templates/BorderTemplate.js +10 -10
- package/dist/src/core/shaders/templates/BorderTemplate.js.map +1 -1
- package/dist/src/core/shaders/templates/HolePunchTemplate.d.ts +2 -2
- package/dist/src/core/shaders/templates/HolePunchTemplate.js +2 -2
- package/dist/src/core/shaders/templates/HolePunchTemplate.js.map +1 -1
- package/dist/src/core/shaders/templates/RadialGradientTemplate.d.ts +2 -2
- package/dist/src/core/shaders/templates/RadialGradientTemplate.js +2 -2
- package/dist/src/core/shaders/templates/RadialGradientTemplate.js.map +1 -1
- package/dist/src/core/shaders/templates/shaderUtils.d.ts +5 -0
- package/dist/src/core/shaders/templates/shaderUtils.js +41 -0
- package/dist/src/core/shaders/templates/shaderUtils.js.map +1 -0
- package/dist/src/core/shaders/webgl/Border.js +83 -83
- package/dist/src/core/shaders/webgl/Border.js.map +1 -1
- package/dist/src/core/shaders/webgl/Default.js +47 -47
- package/dist/src/core/shaders/webgl/DefaultBatched.js +61 -61
- package/dist/src/core/shaders/webgl/HolePunch.js +34 -34
- package/dist/src/core/shaders/webgl/HolePunch.js.map +1 -1
- package/dist/src/core/shaders/webgl/LinearGradient.js +36 -36
- package/dist/src/core/shaders/webgl/RadialGradient.js +35 -35
- package/dist/src/core/shaders/webgl/RadialGradient.js.map +1 -1
- package/dist/src/core/shaders/webgl/Rounded.js +72 -72
- package/dist/src/core/shaders/webgl/Rounded.js.map +1 -1
- package/dist/src/core/shaders/webgl/RoundedWithBorder.js +113 -113
- package/dist/src/core/shaders/webgl/RoundedWithBorder.js.map +1 -1
- package/dist/src/core/shaders/webgl/RoundedWithBorderAndShadow.js +132 -132
- package/dist/src/core/shaders/webgl/RoundedWithBorderAndShadow.js.map +1 -1
- package/dist/src/core/shaders/webgl/RoundedWithShadow.js +55 -55
- package/dist/src/core/shaders/webgl/RoundedWithShadow.js.map +1 -1
- package/dist/src/core/shaders/webgl/SdfShader.js +62 -62
- package/dist/src/core/shaders/webgl/Shadow.js +83 -83
- package/dist/src/core/shaders/webgl/Spinner.d.ts +1 -0
- package/dist/src/core/shaders/webgl/Spinner.js +2 -0
- package/dist/src/core/shaders/webgl/Spinner.js.map +1 -0
- package/dist/src/core/text-rendering/CanvasFontHandler.d.ts +16 -0
- package/dist/src/core/text-rendering/CanvasFontHandler.js +29 -0
- package/dist/src/core/text-rendering/CanvasFontHandler.js.map +1 -1
- package/dist/src/core/text-rendering/SdfFontHandler.d.ts +15 -0
- package/dist/src/core/text-rendering/SdfFontHandler.js +34 -2
- package/dist/src/core/text-rendering/SdfFontHandler.js.map +1 -1
- package/dist/src/core/text-rendering/TextRenderer.d.ts +2 -0
- package/dist/src/core/text-rendering/TextTextureRendererUtils.js.map +1 -1
- package/dist/src/core/text-rendering/font-face-types/SdfTrFontFace/SdfTrFontFace.js +2 -2
- package/dist/src/core/text-rendering/font-face-types/SdfTrFontFace/SdfTrFontFace.js.map +1 -1
- package/dist/src/core/text-rendering/renderers/CanvasTextRenderer.js +0 -5
- package/dist/src/core/text-rendering/renderers/CanvasTextRenderer.js.map +1 -1
- package/dist/src/core/text-rendering/renderers/LightningTextTextureRenderer.d.ts +1 -7
- package/dist/src/core/text-rendering/renderers/LightningTextTextureRenderer.js +2 -50
- package/dist/src/core/text-rendering/renderers/LightningTextTextureRenderer.js.map +1 -1
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.d.ts +3 -2
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.js +83 -42
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.js.map +1 -1
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText.d.ts +1 -1
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText.js +8 -66
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText.js.map +1 -1
- package/dist/src/core/text-rendering/renderers/TextRenderer.d.ts +4 -14
- package/dist/src/core/text-rendering/renderers/TextRenderer.js +0 -3
- package/dist/src/core/text-rendering/renderers/TextRenderer.js.map +1 -1
- package/dist/src/core/text-rendering/sdf/PeekableGenerator.d.ts +12 -0
- package/dist/src/core/text-rendering/sdf/PeekableGenerator.js +61 -0
- package/dist/src/core/text-rendering/sdf/PeekableGenerator.js.map +1 -0
- package/dist/src/core/text-rendering/sdf/SimpleFontShaper.d.ts +45 -0
- package/dist/src/core/text-rendering/sdf/SimpleFontShaper.js +69 -0
- package/dist/src/core/text-rendering/sdf/SimpleFontShaper.js.map +1 -0
- package/dist/src/core/textures/ColorTexture.js +1 -1
- package/dist/src/core/textures/ColorTexture.js.map +1 -1
- package/dist/src/core/textures/ImageTexture.d.ts +2 -2
- package/dist/src/core/textures/ImageTexture.js +11 -11
- package/dist/src/core/textures/ImageTexture.js.map +1 -1
- package/dist/src/core/textures/NoiseTexture.d.ts +2 -2
- package/dist/src/core/textures/NoiseTexture.js +6 -6
- package/dist/src/core/textures/NoiseTexture.js.map +1 -1
- package/dist/src/core/textures/RenderTexture.d.ts +6 -6
- package/dist/src/core/textures/RenderTexture.js +10 -10
- package/dist/src/core/textures/RenderTexture.js.map +1 -1
- package/dist/src/core/textures/SubTexture.d.ts +4 -4
- package/dist/src/core/textures/SubTexture.js +8 -8
- package/dist/src/core/textures/SubTexture.js.map +1 -1
- package/dist/src/core/textures/Texture.d.ts +3 -4
- package/dist/src/core/textures/Texture.js +4 -4
- package/dist/src/core/textures/Texture.js.map +1 -1
- package/dist/src/main-api/DynamicShaderController.d.ts +29 -0
- package/dist/src/main-api/DynamicShaderController.js +58 -0
- package/dist/src/main-api/DynamicShaderController.js.map +1 -0
- package/dist/src/main-api/Inspector.js +7 -7
- package/dist/src/main-api/Inspector.js.map +1 -1
- package/dist/src/main-api/Renderer.js +2 -2
- package/dist/src/main-api/Renderer.js.map +1 -1
- package/dist/src/main-api/ShaderController.d.ts +31 -0
- package/dist/src/main-api/ShaderController.js +37 -0
- package/dist/src/main-api/ShaderController.js.map +1 -0
- package/dist/tsconfig.dist.tsbuildinfo +1 -1
- package/exports/canvas-shaders.ts +28 -28
- package/exports/canvas.ts +45 -45
- package/exports/index.ts +82 -82
- package/exports/inspector.ts +24 -24
- package/exports/utils.ts +50 -50
- package/exports/webgl-shaders.ts +28 -28
- package/exports/webgl.ts +52 -52
- package/package.json +2 -1
- package/src/common/CommonTypes.ts +146 -146
- package/src/common/EventEmitter.ts +77 -77
- package/src/common/IAnimationController.ts +92 -92
- package/src/common/IEventEmitter.ts +28 -28
- package/src/core/CoreNode.test.ts +202 -202
- package/src/core/CoreNode.ts +2481 -2491
- package/src/core/CoreShaderManager.ts +188 -188
- package/src/core/CoreTextNode.ts +483 -443
- package/src/core/CoreTextureManager.ts +565 -565
- package/src/core/Stage.ts +906 -906
- package/src/core/TextureMemoryManager.ts +445 -445
- package/src/core/animations/AnimationManager.ts +38 -38
- package/src/core/animations/CoreAnimation.ts +291 -291
- package/src/core/animations/CoreAnimationController.ts +166 -166
- package/src/core/lib/ContextSpy.ts +41 -41
- package/src/core/lib/ImageWorker.ts +286 -286
- package/src/core/lib/Matrix3d.ts +244 -244
- package/src/core/lib/RenderCoords.ts +71 -71
- package/src/core/lib/WebGlContextWrapper.ts +1381 -1381
- package/src/core/lib/colorCache.ts +20 -20
- package/src/core/lib/colorParser.ts +85 -85
- package/src/core/lib/textureCompression.ts +152 -152
- package/src/core/lib/textureSvg.ts +78 -78
- package/src/core/lib/utils.ts +412 -412
- package/src/core/lib/validateImageBitmap.ts +87 -87
- package/src/core/platforms/Platform.ts +77 -77
- package/src/core/platforms/web/WebPlatform.ts +121 -121
- package/src/core/renderers/CoreContextTexture.ts +43 -43
- package/src/core/renderers/CoreRenderOp.ts +22 -22
- package/src/core/renderers/CoreRenderer.ts +110 -110
- package/src/core/renderers/CoreShaderNode.ts +175 -175
- package/src/core/renderers/CoreShaderProgram.ts +23 -23
- package/src/core/renderers/canvas/CanvasRenderer.ts +283 -283
- package/src/core/renderers/canvas/CanvasShaderNode.ts +96 -96
- package/src/core/renderers/canvas/CanvasTexture.ts +156 -156
- package/src/core/renderers/webgl/WebGlCtxRenderTexture.ts +81 -91
- package/src/core/renderers/webgl/WebGlCtxSubTexture.ts +95 -50
- package/src/core/renderers/webgl/WebGlCtxTexture.ts +301 -310
- package/src/core/renderers/webgl/WebGlRenderOp.ts +167 -167
- package/src/core/renderers/webgl/WebGlRenderer.ts +746 -747
- package/src/core/renderers/webgl/WebGlShaderNode.ts +435 -435
- package/src/core/renderers/webgl/WebGlShaderProgram.ts +341 -341
- package/src/core/renderers/webgl/internal/BufferCollection.ts +54 -54
- package/src/core/renderers/webgl/internal/RendererUtils.ts +155 -155
- package/src/core/renderers/webgl/internal/ShaderUtils.ts +281 -281
- package/src/core/renderers/webgl/internal/WebGlUtils.ts +35 -35
- package/src/core/shaders/canvas/Border.ts +75 -75
- package/src/core/shaders/canvas/HolePunch.ts +55 -62
- package/src/core/shaders/canvas/LinearGradient.ts +71 -71
- package/src/core/shaders/canvas/RadialGradient.ts +99 -99
- package/src/core/shaders/canvas/Rounded.ts +55 -55
- package/src/core/shaders/canvas/RoundedWithBorder.ts +72 -74
- package/src/core/shaders/canvas/RoundedWithBorderAndShadow.ts +88 -90
- package/src/core/shaders/canvas/RoundedWithShadow.ts +70 -70
- package/src/core/shaders/canvas/Shadow.ts +52 -52
- package/src/core/shaders/canvas/utils/render.ts +151 -151
- package/src/core/shaders/templates/BorderTemplate.ts +115 -115
- package/src/core/shaders/templates/HolePunchTemplate.ts +82 -82
- package/src/core/shaders/templates/LinearGradientTemplate.ts +71 -71
- package/src/core/shaders/templates/RadialGradientTemplate.ts +81 -81
- package/src/core/shaders/templates/RoundedTemplate.ts +98 -98
- package/src/core/shaders/templates/RoundedWithBorderAndShadowTemplate.ts +38 -38
- package/src/core/shaders/templates/RoundedWithBorderTemplate.ts +35 -35
- package/src/core/shaders/templates/RoundedWithShadowTemplate.ts +35 -35
- package/src/core/shaders/templates/ShadowTemplate.ts +106 -106
- package/src/core/shaders/utils.ts +46 -46
- package/src/core/shaders/webgl/Border.ts +116 -116
- package/src/core/shaders/webgl/Default.ts +89 -89
- package/src/core/shaders/webgl/DefaultBatched.ts +129 -129
- package/src/core/shaders/webgl/HolePunch.ts +75 -75
- package/src/core/shaders/webgl/LinearGradient.ts +82 -82
- package/src/core/shaders/webgl/RadialGradient.ts +85 -85
- package/src/core/shaders/webgl/Rounded.ts +113 -117
- package/src/core/shaders/webgl/RoundedWithBorder.ts +151 -155
- package/src/core/shaders/webgl/RoundedWithBorderAndShadow.ts +175 -175
- package/src/core/shaders/webgl/RoundedWithShadow.ts +94 -98
- package/src/core/shaders/webgl/SdfShader.ts +134 -134
- package/src/core/shaders/webgl/Shadow.ts +115 -115
- package/src/core/text-rendering/CanvasFontHandler.ts +210 -176
- package/src/core/text-rendering/CanvasTextRenderer.ts +622 -622
- package/src/core/text-rendering/SdfFontHandler.ts +554 -517
- package/src/core/text-rendering/SdfTextRenderer.ts +466 -466
- package/src/core/text-rendering/TextRenderer.ts +406 -404
- package/src/core/text-rendering/Utils.ts +257 -257
- package/src/core/text-rendering/canvas/Settings.ts +99 -99
- package/src/core/text-rendering/canvas/Utils.test.ts +206 -206
- package/src/core/text-rendering/canvas/Utils.ts +178 -178
- package/src/core/text-rendering/canvas/calculateRenderInfo.ts +299 -299
- package/src/core/text-rendering/canvas/draw.ts +165 -165
- package/src/core/text-rendering/sdf/Utils.test.ts +402 -402
- package/src/core/text-rendering/sdf/Utils.ts +436 -436
- package/src/core/text-rendering/sdf/index.ts +20 -20
- package/src/core/textures/ColorTexture.ts +102 -102
- package/src/core/textures/ImageTexture.ts +418 -418
- package/src/core/textures/NoiseTexture.ts +104 -104
- package/src/core/textures/RenderTexture.ts +85 -85
- package/src/core/textures/SubTexture.ts +205 -205
- package/src/core/textures/Texture.ts +381 -381
- package/src/core/utils.ts +227 -227
- package/src/env.d.ts +7 -7
- package/src/main-api/INode.ts +100 -100
- package/src/main-api/Inspector.ts +567 -567
- package/src/main-api/Renderer.ts +873 -873
- package/src/main-api/utils.ts +45 -45
- package/src/utils.ts +267 -267
- package/COPYING +0 -1
|
@@ -1,517 +1,554 @@
|
|
|
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 2025 Comcast Cable Communications Management, LLC.
|
|
6
|
-
*
|
|
7
|
-
* Licensed under the Apache License, Version 2.0 (the License);
|
|
8
|
-
* you may not use this file except in compliance with the License.
|
|
9
|
-
* You may obtain a copy of the License at
|
|
10
|
-
*
|
|
11
|
-
* http://www.apache.org/licenses/LICENSE-2.0
|
|
12
|
-
*
|
|
13
|
-
* Unless required by applicable law or agreed to in writing, software
|
|
14
|
-
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
15
|
-
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
16
|
-
* See the License for the specific language governing permissions and
|
|
17
|
-
* limitations under the License.
|
|
18
|
-
*/
|
|
19
|
-
|
|
20
|
-
import type {
|
|
21
|
-
FontFamilyMap,
|
|
22
|
-
FontMetrics,
|
|
23
|
-
NormalizedFontMetrics,
|
|
24
|
-
TrProps,
|
|
25
|
-
FontLoadOptions,
|
|
26
|
-
} from './TextRenderer.js';
|
|
27
|
-
import type { ImageTexture } from '../textures/ImageTexture.js';
|
|
28
|
-
import type { Stage } from '../Stage.js';
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
}
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
* @
|
|
92
|
-
* @property {number}
|
|
93
|
-
* @property {
|
|
94
|
-
* @property {number}
|
|
95
|
-
* @property {number}
|
|
96
|
-
* @property {number}
|
|
97
|
-
* @property {number}
|
|
98
|
-
* @property {number}
|
|
99
|
-
* @property {number}
|
|
100
|
-
* @property {number}
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
const
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
const
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
}
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
}
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
*
|
|
208
|
-
* @param {
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
282
|
-
*
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
}
|
|
294
|
-
|
|
295
|
-
|
|
296
|
-
|
|
297
|
-
|
|
298
|
-
|
|
299
|
-
|
|
300
|
-
|
|
301
|
-
if (
|
|
302
|
-
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
|
|
309
|
-
|
|
310
|
-
|
|
311
|
-
|
|
312
|
-
|
|
313
|
-
|
|
314
|
-
|
|
315
|
-
const
|
|
316
|
-
if (!
|
|
317
|
-
throw new Error(
|
|
318
|
-
}
|
|
319
|
-
|
|
320
|
-
|
|
321
|
-
if (!
|
|
322
|
-
throw new Error('
|
|
323
|
-
}
|
|
324
|
-
|
|
325
|
-
//
|
|
326
|
-
|
|
327
|
-
|
|
328
|
-
|
|
329
|
-
|
|
330
|
-
|
|
331
|
-
|
|
332
|
-
|
|
333
|
-
atlasTexture
|
|
334
|
-
|
|
335
|
-
|
|
336
|
-
|
|
337
|
-
|
|
338
|
-
|
|
339
|
-
|
|
340
|
-
|
|
341
|
-
|
|
342
|
-
|
|
343
|
-
|
|
344
|
-
|
|
345
|
-
|
|
346
|
-
|
|
347
|
-
|
|
348
|
-
|
|
349
|
-
|
|
350
|
-
|
|
351
|
-
|
|
352
|
-
|
|
353
|
-
|
|
354
|
-
|
|
355
|
-
|
|
356
|
-
|
|
357
|
-
|
|
358
|
-
|
|
359
|
-
|
|
360
|
-
|
|
361
|
-
|
|
362
|
-
|
|
363
|
-
|
|
364
|
-
|
|
365
|
-
|
|
366
|
-
|
|
367
|
-
|
|
368
|
-
|
|
369
|
-
|
|
370
|
-
|
|
371
|
-
|
|
372
|
-
|
|
373
|
-
|
|
374
|
-
|
|
375
|
-
|
|
376
|
-
|
|
377
|
-
|
|
378
|
-
|
|
379
|
-
|
|
380
|
-
|
|
381
|
-
|
|
382
|
-
|
|
383
|
-
|
|
384
|
-
|
|
385
|
-
|
|
386
|
-
|
|
387
|
-
|
|
388
|
-
|
|
389
|
-
|
|
390
|
-
|
|
391
|
-
|
|
392
|
-
|
|
393
|
-
|
|
394
|
-
|
|
395
|
-
|
|
396
|
-
|
|
397
|
-
|
|
398
|
-
*
|
|
399
|
-
|
|
400
|
-
|
|
401
|
-
|
|
402
|
-
|
|
403
|
-
|
|
404
|
-
|
|
405
|
-
|
|
406
|
-
|
|
407
|
-
|
|
408
|
-
|
|
409
|
-
|
|
410
|
-
|
|
411
|
-
):
|
|
412
|
-
const
|
|
413
|
-
|
|
414
|
-
|
|
415
|
-
|
|
416
|
-
|
|
417
|
-
|
|
418
|
-
|
|
419
|
-
|
|
420
|
-
|
|
421
|
-
|
|
422
|
-
|
|
423
|
-
|
|
424
|
-
|
|
425
|
-
|
|
426
|
-
|
|
427
|
-
}
|
|
428
|
-
|
|
429
|
-
|
|
430
|
-
|
|
431
|
-
|
|
432
|
-
|
|
433
|
-
|
|
434
|
-
|
|
435
|
-
|
|
436
|
-
|
|
437
|
-
|
|
438
|
-
)
|
|
439
|
-
|
|
440
|
-
|
|
441
|
-
|
|
442
|
-
|
|
443
|
-
|
|
444
|
-
|
|
445
|
-
|
|
446
|
-
|
|
447
|
-
|
|
448
|
-
|
|
449
|
-
|
|
450
|
-
|
|
451
|
-
|
|
452
|
-
|
|
453
|
-
|
|
454
|
-
|
|
455
|
-
|
|
456
|
-
|
|
457
|
-
|
|
458
|
-
|
|
459
|
-
|
|
460
|
-
const
|
|
461
|
-
|
|
462
|
-
|
|
463
|
-
|
|
464
|
-
|
|
465
|
-
|
|
466
|
-
|
|
467
|
-
*
|
|
468
|
-
|
|
469
|
-
|
|
470
|
-
|
|
471
|
-
|
|
472
|
-
|
|
473
|
-
|
|
474
|
-
|
|
475
|
-
|
|
476
|
-
|
|
477
|
-
|
|
478
|
-
|
|
479
|
-
|
|
480
|
-
|
|
481
|
-
|
|
482
|
-
|
|
483
|
-
|
|
484
|
-
|
|
485
|
-
*
|
|
486
|
-
* @param {
|
|
487
|
-
* @returns {number}
|
|
488
|
-
*/
|
|
489
|
-
export const
|
|
490
|
-
|
|
491
|
-
|
|
492
|
-
|
|
493
|
-
|
|
494
|
-
|
|
495
|
-
|
|
496
|
-
|
|
497
|
-
|
|
498
|
-
|
|
499
|
-
|
|
500
|
-
|
|
501
|
-
|
|
502
|
-
|
|
503
|
-
*
|
|
504
|
-
* @
|
|
505
|
-
*/
|
|
506
|
-
export const
|
|
507
|
-
const cache = fontCache[fontFamily];
|
|
508
|
-
|
|
509
|
-
|
|
510
|
-
|
|
511
|
-
|
|
512
|
-
|
|
513
|
-
|
|
514
|
-
|
|
515
|
-
|
|
516
|
-
|
|
517
|
-
|
|
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 2025 Comcast Cable Communications Management, LLC.
|
|
6
|
+
*
|
|
7
|
+
* Licensed under the Apache License, Version 2.0 (the License);
|
|
8
|
+
* you may not use this file except in compliance with the License.
|
|
9
|
+
* You may obtain a copy of the License at
|
|
10
|
+
*
|
|
11
|
+
* http://www.apache.org/licenses/LICENSE-2.0
|
|
12
|
+
*
|
|
13
|
+
* Unless required by applicable law or agreed to in writing, software
|
|
14
|
+
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
15
|
+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
16
|
+
* See the License for the specific language governing permissions and
|
|
17
|
+
* limitations under the License.
|
|
18
|
+
*/
|
|
19
|
+
|
|
20
|
+
import type {
|
|
21
|
+
FontFamilyMap,
|
|
22
|
+
FontMetrics,
|
|
23
|
+
NormalizedFontMetrics,
|
|
24
|
+
TrProps,
|
|
25
|
+
FontLoadOptions,
|
|
26
|
+
} from './TextRenderer.js';
|
|
27
|
+
import type { ImageTexture } from '../textures/ImageTexture.js';
|
|
28
|
+
import type { Stage } from '../Stage.js';
|
|
29
|
+
import type { CoreTextNode } from '../CoreTextNode.js';
|
|
30
|
+
import { UpdateType } from '../CoreNode.js';
|
|
31
|
+
|
|
32
|
+
/**
|
|
33
|
+
* SDF Font Data structure matching msdf-bmfont-xml output
|
|
34
|
+
*/
|
|
35
|
+
export interface SdfFontData {
|
|
36
|
+
pages: string[];
|
|
37
|
+
chars: Array<{
|
|
38
|
+
id: number;
|
|
39
|
+
char: string;
|
|
40
|
+
x: number;
|
|
41
|
+
y: number;
|
|
42
|
+
width: number;
|
|
43
|
+
height: number;
|
|
44
|
+
xoffset: number;
|
|
45
|
+
yoffset: number;
|
|
46
|
+
xadvance: number;
|
|
47
|
+
page: number;
|
|
48
|
+
chnl: number;
|
|
49
|
+
}>;
|
|
50
|
+
|
|
51
|
+
kernings: Array<{
|
|
52
|
+
first: number;
|
|
53
|
+
second: number;
|
|
54
|
+
amount: number;
|
|
55
|
+
}>;
|
|
56
|
+
info: {
|
|
57
|
+
face: string;
|
|
58
|
+
size: number;
|
|
59
|
+
bold: number;
|
|
60
|
+
italic: number;
|
|
61
|
+
charset: string[];
|
|
62
|
+
unicode: number;
|
|
63
|
+
stretchH: number;
|
|
64
|
+
smooth: number;
|
|
65
|
+
aa: number;
|
|
66
|
+
padding: [number, number, number, number]; // [up, right, down, left]
|
|
67
|
+
spacing: [number, number]; // [horizontal, vertical]
|
|
68
|
+
outline: number;
|
|
69
|
+
};
|
|
70
|
+
common: {
|
|
71
|
+
lineHeight: number;
|
|
72
|
+
base: number;
|
|
73
|
+
scaleW: number;
|
|
74
|
+
scaleH: number;
|
|
75
|
+
pages: number;
|
|
76
|
+
packed: number;
|
|
77
|
+
alphaChnl: number;
|
|
78
|
+
redChnl: number;
|
|
79
|
+
greenChnl: number;
|
|
80
|
+
blueChnl: number;
|
|
81
|
+
};
|
|
82
|
+
distanceField: {
|
|
83
|
+
// msdf-bmfont-xml uses the string 'sdf' for single-channel SDF.
|
|
84
|
+
fieldType: 'sdf' | 'msdf';
|
|
85
|
+
distanceRange: number;
|
|
86
|
+
};
|
|
87
|
+
lightningMetrics?: FontMetrics;
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
/**
|
|
91
|
+
* @typedef {Object} SdfGlyph
|
|
92
|
+
* @property {number} id - Glyph ID
|
|
93
|
+
* @property {string} char - Character
|
|
94
|
+
* @property {number} x - Atlas x position
|
|
95
|
+
* @property {number} y - Atlas y position
|
|
96
|
+
* @property {number} width - Glyph width
|
|
97
|
+
* @property {number} height - Glyph height
|
|
98
|
+
* @property {number} xoffset - X offset
|
|
99
|
+
* @property {number} yoffset - Y offset
|
|
100
|
+
* @property {number} xadvance - Character advance width
|
|
101
|
+
* @property {number} page - Page number
|
|
102
|
+
* @property {number} chnl - Channel
|
|
103
|
+
*/
|
|
104
|
+
|
|
105
|
+
/**
|
|
106
|
+
* @typedef {Object} KerningTable
|
|
107
|
+
* Fast lookup table for kerning values
|
|
108
|
+
*/
|
|
109
|
+
type KerningTable = Record<
|
|
110
|
+
number,
|
|
111
|
+
Record<number, number | undefined> | undefined
|
|
112
|
+
>;
|
|
113
|
+
|
|
114
|
+
/**
|
|
115
|
+
* @typedef {Object} SdfFontCache
|
|
116
|
+
* Cached font data for performance
|
|
117
|
+
*/
|
|
118
|
+
interface SdfFontCache {
|
|
119
|
+
data: SdfFontData;
|
|
120
|
+
glyphMap: Map<number, SdfFontData['chars'][0]>;
|
|
121
|
+
kernings: KerningTable;
|
|
122
|
+
atlasTexture: ImageTexture;
|
|
123
|
+
metrics: NormalizedFontMetrics;
|
|
124
|
+
maxCharHeight: number;
|
|
125
|
+
}
|
|
126
|
+
|
|
127
|
+
//global state variables for SdfFontHandler
|
|
128
|
+
const fontCache: Record<string, SdfFontCache> = Object.create(null);
|
|
129
|
+
const loadedFonts = new Set<string>();
|
|
130
|
+
const fontLoadPromises = new Map<string, Promise<void>>();
|
|
131
|
+
const nodesWaitingForFont: Record<string, CoreTextNode[]> = Object.create(null);
|
|
132
|
+
let initialized = false;
|
|
133
|
+
|
|
134
|
+
/**
|
|
135
|
+
* Normalize font metrics to be in the range of 0 to 1
|
|
136
|
+
*/
|
|
137
|
+
const normalizeMetrics = (metrics: FontMetrics): NormalizedFontMetrics => ({
|
|
138
|
+
ascender: metrics.ascender / metrics.unitsPerEm,
|
|
139
|
+
descender: metrics.descender / metrics.unitsPerEm,
|
|
140
|
+
lineGap: metrics.lineGap / metrics.unitsPerEm,
|
|
141
|
+
});
|
|
142
|
+
|
|
143
|
+
/**
|
|
144
|
+
* Build kerning lookup table for fast access
|
|
145
|
+
* @param {Array} kernings - Kerning data from font
|
|
146
|
+
* @returns {KerningTable} Optimized kerning lookup table
|
|
147
|
+
*/
|
|
148
|
+
const buildKerningTable = (kernings: SdfFontData['kernings']): KerningTable => {
|
|
149
|
+
const kerningTable: KerningTable = {};
|
|
150
|
+
|
|
151
|
+
let i = 0;
|
|
152
|
+
const length = kernings.length;
|
|
153
|
+
|
|
154
|
+
while (i < length) {
|
|
155
|
+
const kerning = kernings[i];
|
|
156
|
+
i++;
|
|
157
|
+
if (kerning === undefined) {
|
|
158
|
+
continue;
|
|
159
|
+
}
|
|
160
|
+
const second = kerning.second;
|
|
161
|
+
|
|
162
|
+
let firsts = kerningTable[second];
|
|
163
|
+
if (firsts === undefined) {
|
|
164
|
+
firsts = {};
|
|
165
|
+
kerningTable[second] = firsts;
|
|
166
|
+
}
|
|
167
|
+
firsts[kerning.first] = kerning.amount;
|
|
168
|
+
}
|
|
169
|
+
|
|
170
|
+
return kerningTable;
|
|
171
|
+
};
|
|
172
|
+
|
|
173
|
+
/**
|
|
174
|
+
* Build glyph map from font data for fast character lookup
|
|
175
|
+
* @param {Array} chars - Character data from font
|
|
176
|
+
* @returns {Map} Glyph map for character to glyph lookup
|
|
177
|
+
*/
|
|
178
|
+
const buildGlyphMap = (
|
|
179
|
+
chars: SdfFontData['chars'],
|
|
180
|
+
): Map<number, SdfFontData['chars'][0]> => {
|
|
181
|
+
const glyphMap = new Map<number, SdfFontData['chars'][0]>();
|
|
182
|
+
let maxCharHeight = 0;
|
|
183
|
+
|
|
184
|
+
let i = 0;
|
|
185
|
+
const length = chars.length;
|
|
186
|
+
|
|
187
|
+
while (i < length) {
|
|
188
|
+
const glyph = chars[i];
|
|
189
|
+
|
|
190
|
+
i++;
|
|
191
|
+
if (glyph === undefined) {
|
|
192
|
+
continue;
|
|
193
|
+
}
|
|
194
|
+
|
|
195
|
+
glyphMap.set(glyph.id, glyph);
|
|
196
|
+
|
|
197
|
+
const charHeight = glyph.yoffset + glyph.height;
|
|
198
|
+
if (charHeight > maxCharHeight) {
|
|
199
|
+
maxCharHeight = charHeight;
|
|
200
|
+
}
|
|
201
|
+
}
|
|
202
|
+
|
|
203
|
+
return glyphMap;
|
|
204
|
+
};
|
|
205
|
+
|
|
206
|
+
/**
|
|
207
|
+
* Process font data and create optimized cache entry
|
|
208
|
+
* @param {string} fontFamily - Font family name
|
|
209
|
+
* @param {SdfFontData} fontData - Raw font data
|
|
210
|
+
* @param {ImageTexture} atlasTexture - Atlas texture
|
|
211
|
+
* @param {FontMetrics} metrics - Font metrics
|
|
212
|
+
*/
|
|
213
|
+
const processFontData = (
|
|
214
|
+
fontFamily: string,
|
|
215
|
+
fontData: SdfFontData,
|
|
216
|
+
atlasTexture: ImageTexture,
|
|
217
|
+
metrics?: FontMetrics,
|
|
218
|
+
): void => {
|
|
219
|
+
// Build optimized data structures
|
|
220
|
+
const glyphMap = buildGlyphMap(fontData.chars);
|
|
221
|
+
const kernings = buildKerningTable(fontData.kernings);
|
|
222
|
+
|
|
223
|
+
// Calculate max char height
|
|
224
|
+
let maxCharHeight = 0;
|
|
225
|
+
let i = 0;
|
|
226
|
+
const length = fontData.chars.length;
|
|
227
|
+
|
|
228
|
+
while (i < length) {
|
|
229
|
+
const glyph = fontData.chars[i];
|
|
230
|
+
if (glyph !== undefined) {
|
|
231
|
+
const charHeight = glyph.yoffset + glyph.height;
|
|
232
|
+
if (charHeight > maxCharHeight) {
|
|
233
|
+
maxCharHeight = charHeight;
|
|
234
|
+
}
|
|
235
|
+
}
|
|
236
|
+
i++;
|
|
237
|
+
}
|
|
238
|
+
|
|
239
|
+
// Determine metrics
|
|
240
|
+
let normalizedMetrics: NormalizedFontMetrics;
|
|
241
|
+
|
|
242
|
+
if (metrics !== undefined) {
|
|
243
|
+
normalizedMetrics = normalizeMetrics(metrics);
|
|
244
|
+
} else if (fontData.lightningMetrics !== undefined) {
|
|
245
|
+
normalizedMetrics = normalizeMetrics(fontData.lightningMetrics);
|
|
246
|
+
} else {
|
|
247
|
+
console.warn(
|
|
248
|
+
`Font metrics not found for SDF font ${fontFamily}. ` +
|
|
249
|
+
'Make sure you are using the latest version of the Lightning ' +
|
|
250
|
+
'3 msdf-generator tool to generate your SDF fonts. Using default metrics.',
|
|
251
|
+
);
|
|
252
|
+
// Use default metrics
|
|
253
|
+
normalizedMetrics = {
|
|
254
|
+
ascender: 0.8,
|
|
255
|
+
descender: -0.2,
|
|
256
|
+
lineGap: 0.2,
|
|
257
|
+
};
|
|
258
|
+
}
|
|
259
|
+
// Cache processed data
|
|
260
|
+
fontCache[fontFamily] = {
|
|
261
|
+
data: fontData,
|
|
262
|
+
glyphMap,
|
|
263
|
+
kernings,
|
|
264
|
+
atlasTexture,
|
|
265
|
+
metrics: normalizedMetrics,
|
|
266
|
+
maxCharHeight,
|
|
267
|
+
};
|
|
268
|
+
};
|
|
269
|
+
|
|
270
|
+
/**
|
|
271
|
+
* Check if the SDF font handler can render a font
|
|
272
|
+
* @param {TrProps} trProps - Text rendering properties
|
|
273
|
+
* @returns {boolean} True if the font can be rendered
|
|
274
|
+
*/
|
|
275
|
+
export const canRenderFont = (trProps: TrProps): boolean => {
|
|
276
|
+
return (
|
|
277
|
+
isFontLoaded(trProps.fontFamily) || fontLoadPromises.has(trProps.fontFamily)
|
|
278
|
+
);
|
|
279
|
+
};
|
|
280
|
+
|
|
281
|
+
/**
|
|
282
|
+
* Load SDF font from JSON + PNG atlas
|
|
283
|
+
* @param {Object} options - Font loading options
|
|
284
|
+
* @param {string} options.fontFamily - Font family name
|
|
285
|
+
* @param {string} options.fontUrl - JSON font data URL (atlasDataUrl)
|
|
286
|
+
* @param {string} options.atlasUrl - PNG atlas texture URL
|
|
287
|
+
* @param {FontMetrics} options.metrics - Optional font metrics
|
|
288
|
+
*/
|
|
289
|
+
export const loadFont = async (
|
|
290
|
+
stage: Stage,
|
|
291
|
+
options: FontLoadOptions,
|
|
292
|
+
): Promise<void> => {
|
|
293
|
+
const { fontFamily, atlasUrl, atlasDataUrl, metrics } = options;
|
|
294
|
+
// Early return if already loaded
|
|
295
|
+
if (loadedFonts.has(fontFamily) === true) {
|
|
296
|
+
return;
|
|
297
|
+
}
|
|
298
|
+
|
|
299
|
+
// Early return if already loading
|
|
300
|
+
const existingPromise = fontLoadPromises.get(fontFamily);
|
|
301
|
+
if (existingPromise !== undefined) {
|
|
302
|
+
return existingPromise;
|
|
303
|
+
}
|
|
304
|
+
|
|
305
|
+
if (atlasDataUrl === undefined) {
|
|
306
|
+
throw new Error(
|
|
307
|
+
`Atlas data URL must be provided for SDF font: ${fontFamily}`,
|
|
308
|
+
);
|
|
309
|
+
}
|
|
310
|
+
|
|
311
|
+
const nwff: CoreTextNode[] = (nodesWaitingForFont[fontFamily] = []);
|
|
312
|
+
// Create loading promise
|
|
313
|
+
const loadPromise = (async (): Promise<void> => {
|
|
314
|
+
// Load font JSON data
|
|
315
|
+
const response = await fetch(atlasDataUrl);
|
|
316
|
+
if (!response.ok) {
|
|
317
|
+
throw new Error(`Failed to load font data: ${response.statusText}`);
|
|
318
|
+
}
|
|
319
|
+
|
|
320
|
+
const fontData = (await response.json()) as SdfFontData;
|
|
321
|
+
if (!fontData || !fontData.chars) {
|
|
322
|
+
throw new Error('Invalid SDF font data format');
|
|
323
|
+
}
|
|
324
|
+
|
|
325
|
+
// Atlas texture should be provided externally
|
|
326
|
+
if (!atlasUrl) {
|
|
327
|
+
throw new Error('Atlas texture must be provided for SDF fonts');
|
|
328
|
+
}
|
|
329
|
+
|
|
330
|
+
// Wait for atlas texture to load
|
|
331
|
+
return new Promise<void>((resolve, reject) => {
|
|
332
|
+
// create new atlas texture using ImageTexture
|
|
333
|
+
const atlasTexture = stage.txManager.createTexture('ImageTexture', {
|
|
334
|
+
src: atlasUrl,
|
|
335
|
+
premultiplyAlpha: false,
|
|
336
|
+
});
|
|
337
|
+
|
|
338
|
+
atlasTexture.setRenderableOwner(this, true);
|
|
339
|
+
atlasTexture.preventCleanup = true; // Prevent automatic cleanup
|
|
340
|
+
|
|
341
|
+
if (atlasTexture.state === 'loaded') {
|
|
342
|
+
// If already loaded, process immediately
|
|
343
|
+
processFontData(fontFamily, fontData, atlasTexture, metrics);
|
|
344
|
+
loadedFonts.add(fontFamily);
|
|
345
|
+
fontLoadPromises.delete(fontFamily);
|
|
346
|
+
|
|
347
|
+
for (let key in nwff) {
|
|
348
|
+
nwff[key]!.setUpdateType(UpdateType.Local);
|
|
349
|
+
}
|
|
350
|
+
delete nodesWaitingForFont[fontFamily];
|
|
351
|
+
return resolve();
|
|
352
|
+
}
|
|
353
|
+
|
|
354
|
+
atlasTexture.on('loaded', () => {
|
|
355
|
+
// Process and cache font data
|
|
356
|
+
processFontData(fontFamily, fontData, atlasTexture, metrics);
|
|
357
|
+
|
|
358
|
+
// Mark as loaded
|
|
359
|
+
loadedFonts.add(fontFamily);
|
|
360
|
+
fontLoadPromises.delete(fontFamily);
|
|
361
|
+
|
|
362
|
+
for (let key in nwff) {
|
|
363
|
+
nwff[key]!.setUpdateType(UpdateType.Local);
|
|
364
|
+
}
|
|
365
|
+
delete nodesWaitingForFont[fontFamily];
|
|
366
|
+
resolve();
|
|
367
|
+
});
|
|
368
|
+
|
|
369
|
+
atlasTexture.on('failed', (error: Error) => {
|
|
370
|
+
// Cleanup on error
|
|
371
|
+
fontLoadPromises.delete(fontFamily);
|
|
372
|
+
if (fontCache[fontFamily]) {
|
|
373
|
+
delete fontCache[fontFamily];
|
|
374
|
+
}
|
|
375
|
+
console.error(`Failed to load SDF font: ${fontFamily}`, error);
|
|
376
|
+
reject(error);
|
|
377
|
+
});
|
|
378
|
+
});
|
|
379
|
+
})();
|
|
380
|
+
|
|
381
|
+
fontLoadPromises.set(fontFamily, loadPromise);
|
|
382
|
+
return loadPromise;
|
|
383
|
+
};
|
|
384
|
+
|
|
385
|
+
/**
|
|
386
|
+
* Stop waiting for a font to load
|
|
387
|
+
* @param {string} fontFamily - Font family name
|
|
388
|
+
* @param {CoreTextNode} node - Node that was waiting for the font
|
|
389
|
+
*/
|
|
390
|
+
export const waitingForFont = (fontFamily: string, node: CoreTextNode) => {
|
|
391
|
+
nodesWaitingForFont[fontFamily]![node.id] = node;
|
|
392
|
+
};
|
|
393
|
+
|
|
394
|
+
/**
|
|
395
|
+
* Stop waiting for a font to load
|
|
396
|
+
*
|
|
397
|
+
* @param fontFamily
|
|
398
|
+
* @param node
|
|
399
|
+
* @returns
|
|
400
|
+
*/
|
|
401
|
+
export const stopWaitingForFont = (fontFamily: string, node: CoreTextNode) => {
|
|
402
|
+
if (nodesWaitingForFont[fontFamily] === undefined) {
|
|
403
|
+
return;
|
|
404
|
+
}
|
|
405
|
+
delete nodesWaitingForFont[fontFamily][node.id];
|
|
406
|
+
};
|
|
407
|
+
|
|
408
|
+
/**
|
|
409
|
+
* Get the font families map for resolving fonts
|
|
410
|
+
*/
|
|
411
|
+
export const getFontFamilies = (): FontFamilyMap => {
|
|
412
|
+
const families: FontFamilyMap = {};
|
|
413
|
+
|
|
414
|
+
// SDF fonts don't use the traditional FontFamilyMap structure
|
|
415
|
+
// Return empty map since SDF fonts are handled differently
|
|
416
|
+
return families;
|
|
417
|
+
};
|
|
418
|
+
|
|
419
|
+
/**
|
|
420
|
+
* Initialize the SDF font handler
|
|
421
|
+
*/
|
|
422
|
+
export const init = (
|
|
423
|
+
c?: CanvasRenderingContext2D | OffscreenCanvasRenderingContext2D,
|
|
424
|
+
): void => {
|
|
425
|
+
if (initialized === true) {
|
|
426
|
+
return;
|
|
427
|
+
}
|
|
428
|
+
|
|
429
|
+
initialized = true;
|
|
430
|
+
};
|
|
431
|
+
|
|
432
|
+
export const type = 'sdf';
|
|
433
|
+
|
|
434
|
+
/**
|
|
435
|
+
* Check if a font is already loaded by font family
|
|
436
|
+
*/
|
|
437
|
+
export const isFontLoaded = (fontFamily: string): boolean => {
|
|
438
|
+
return loadedFonts.has(fontFamily);
|
|
439
|
+
};
|
|
440
|
+
|
|
441
|
+
/**
|
|
442
|
+
* Get normalized font metrics for a font family
|
|
443
|
+
*/
|
|
444
|
+
export const getFontMetrics = (
|
|
445
|
+
fontFamily: string,
|
|
446
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
447
|
+
fontSize: number,
|
|
448
|
+
): NormalizedFontMetrics => {
|
|
449
|
+
const cache = fontCache[fontFamily];
|
|
450
|
+
return cache ? cache.metrics : { ascender: 0, descender: 0, lineGap: 0 };
|
|
451
|
+
};
|
|
452
|
+
|
|
453
|
+
/**
|
|
454
|
+
* Set font metrics for a font family
|
|
455
|
+
*/
|
|
456
|
+
export const setFontMetrics = (
|
|
457
|
+
fontFamily: string,
|
|
458
|
+
metrics: NormalizedFontMetrics,
|
|
459
|
+
): void => {
|
|
460
|
+
const cache = fontCache[fontFamily];
|
|
461
|
+
if (cache !== undefined) {
|
|
462
|
+
cache.metrics = metrics;
|
|
463
|
+
}
|
|
464
|
+
};
|
|
465
|
+
|
|
466
|
+
/**
|
|
467
|
+
* Get glyph data for a character in a specific font
|
|
468
|
+
* @param {string} fontFamily - Font family name
|
|
469
|
+
* @param {number} codepoint - Character codepoint
|
|
470
|
+
* @returns {Object|null} Glyph data or null if not found
|
|
471
|
+
*/
|
|
472
|
+
export const getGlyph = (
|
|
473
|
+
fontFamily: string,
|
|
474
|
+
codepoint: number,
|
|
475
|
+
): SdfFontData['chars'][0] | null => {
|
|
476
|
+
const cache = fontCache[fontFamily];
|
|
477
|
+
if (cache === undefined) return null;
|
|
478
|
+
|
|
479
|
+
return cache.glyphMap.get(codepoint) || cache.glyphMap.get(63) || null; // 63 = '?'
|
|
480
|
+
};
|
|
481
|
+
|
|
482
|
+
/**
|
|
483
|
+
* Get kerning value between two glyphs
|
|
484
|
+
* @param {string} fontFamily - Font family name
|
|
485
|
+
* @param {number} firstGlyph - First glyph ID
|
|
486
|
+
* @param {number} secondGlyph - Second glyph ID
|
|
487
|
+
* @returns {number} Kerning value or 0
|
|
488
|
+
*/
|
|
489
|
+
export const getKerning = (
|
|
490
|
+
fontFamily: string,
|
|
491
|
+
firstGlyph: number,
|
|
492
|
+
secondGlyph: number,
|
|
493
|
+
): number => {
|
|
494
|
+
const cache = fontCache[fontFamily];
|
|
495
|
+
if (cache === undefined) return 0;
|
|
496
|
+
|
|
497
|
+
const seconds = cache.kernings[secondGlyph];
|
|
498
|
+
return seconds ? seconds[firstGlyph] || 0 : 0;
|
|
499
|
+
};
|
|
500
|
+
|
|
501
|
+
/**
|
|
502
|
+
* Get atlas texture for a font family
|
|
503
|
+
* @param {string} fontFamily - Font family name
|
|
504
|
+
* @returns {ImageTexture|null} Atlas texture or null
|
|
505
|
+
*/
|
|
506
|
+
export const getAtlas = (fontFamily: string): ImageTexture | null => {
|
|
507
|
+
const cache = fontCache[fontFamily];
|
|
508
|
+
return cache !== undefined ? cache.atlasTexture : null;
|
|
509
|
+
};
|
|
510
|
+
|
|
511
|
+
/**
|
|
512
|
+
* Get font data for a font family
|
|
513
|
+
* @param {string} fontFamily - Font family name
|
|
514
|
+
* @returns {SdfFontData|null} Font data or null
|
|
515
|
+
*/
|
|
516
|
+
export const getFontData = (fontFamily: string): SdfFontData | null => {
|
|
517
|
+
const cache = fontCache[fontFamily];
|
|
518
|
+
return cache !== undefined ? cache.data : null;
|
|
519
|
+
};
|
|
520
|
+
|
|
521
|
+
/**
|
|
522
|
+
* Get maximum character height for a font family
|
|
523
|
+
* @param {string} fontFamily - Font family name
|
|
524
|
+
* @returns {number} Max character height or 0
|
|
525
|
+
*/
|
|
526
|
+
export const getMaxCharHeight = (fontFamily: string): number => {
|
|
527
|
+
const cache = fontCache[fontFamily];
|
|
528
|
+
return cache !== undefined ? cache.maxCharHeight : 0;
|
|
529
|
+
};
|
|
530
|
+
|
|
531
|
+
/**
|
|
532
|
+
* Get all loaded font families
|
|
533
|
+
* @returns {string[]} Array of font family names
|
|
534
|
+
*/
|
|
535
|
+
export const getLoadedFonts = (): string[] => {
|
|
536
|
+
return Array.from(loadedFonts);
|
|
537
|
+
};
|
|
538
|
+
|
|
539
|
+
/**
|
|
540
|
+
* Unload a font and free resources
|
|
541
|
+
* @param {string} fontFamily - Font family name
|
|
542
|
+
*/
|
|
543
|
+
export const unloadFont = (fontFamily: string): void => {
|
|
544
|
+
const cache = fontCache[fontFamily];
|
|
545
|
+
if (cache !== undefined) {
|
|
546
|
+
// Free texture if needed
|
|
547
|
+
if (typeof cache.atlasTexture.free === 'function') {
|
|
548
|
+
cache.atlasTexture.free();
|
|
549
|
+
}
|
|
550
|
+
|
|
551
|
+
delete fontCache[fontFamily];
|
|
552
|
+
loadedFonts.delete(fontFamily);
|
|
553
|
+
}
|
|
554
|
+
};
|