@lightningjs/renderer 3.0.0-beta14 → 3.0.0-beta16
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/dist/exports/index.d.ts +1 -0
- package/dist/exports/index.js.map +1 -1
- package/dist/src/core/CoreNode.d.ts +1 -1
- package/dist/src/core/CoreTextNode.d.ts +1 -2
- package/dist/src/core/CoreTextNode.js +43 -21
- package/dist/src/core/CoreTextNode.js.map +1 -1
- package/dist/src/core/Stage.js +2 -3
- 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/animations/CoreAnimation.d.ts +3 -3
- package/dist/src/core/animations/CoreAnimation.js +3 -3
- package/dist/src/core/animations/CoreAnimation.js.map +1 -1
- package/dist/src/core/lib/WebGlContextWrapper.d.ts +5 -5
- package/dist/src/core/lib/textureCompression.js +1 -1
- 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/{src/core/text-rendering/sdf/index.ts → dist/src/core/renderers/CoreShader.js} +11 -3
- package/dist/src/core/renderers/CoreShader.js.map +1 -0
- package/dist/src/core/renderers/canvas/CanvasCoreRenderer.d.ts +33 -0
- package/dist/src/core/renderers/canvas/CanvasCoreRenderer.js +250 -0
- package/dist/src/core/renderers/canvas/CanvasCoreRenderer.js.map +1 -0
- package/dist/src/core/renderers/canvas/CanvasCoreTexture.d.ts +17 -0
- package/dist/src/core/renderers/canvas/CanvasCoreTexture.js +125 -0
- package/dist/src/core/renderers/canvas/CanvasCoreTexture.js.map +1 -0
- package/dist/src/core/renderers/canvas/internal/C2DShaderUtils.d.ts +14 -0
- package/dist/src/core/renderers/canvas/internal/C2DShaderUtils.js +138 -0
- package/dist/src/core/renderers/canvas/internal/C2DShaderUtils.js.map +1 -0
- package/dist/src/core/renderers/canvas/internal/ColorUtils.d.ts +19 -0
- package/dist/src/core/renderers/canvas/internal/ColorUtils.js +58 -0
- package/dist/src/core/renderers/canvas/internal/ColorUtils.js.map +1 -0
- 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 +69 -0
- package/dist/src/core/renderers/webgl/WebGlCoreCtxTexture.js +272 -0
- package/dist/src/core/renderers/webgl/WebGlCoreCtxTexture.js.map +1 -0
- package/dist/src/core/renderers/webgl/WebGlCoreRenderOp.d.ts +34 -0
- package/dist/src/core/renderers/webgl/WebGlCoreRenderOp.js +114 -0
- package/dist/src/core/renderers/webgl/WebGlCoreRenderOp.js.map +1 -0
- package/dist/src/core/renderers/webgl/WebGlCoreRenderer.d.ts +133 -0
- package/dist/src/core/renderers/webgl/WebGlCoreRenderer.js +641 -0
- package/dist/src/core/renderers/webgl/WebGlCoreRenderer.js.map +1 -0
- package/dist/src/core/renderers/webgl/WebGlCoreShader.d.ts +78 -0
- package/dist/src/core/renderers/webgl/WebGlCoreShader.js +202 -0
- package/dist/src/core/renderers/webgl/WebGlCoreShader.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/DefaultShader.d.ts +9 -0
- package/dist/src/core/renderers/webgl/shaders/DefaultShader.js +84 -0
- package/dist/src/core/renderers/webgl/shaders/DefaultShader.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/DefaultShaderBatched.d.ts +10 -0
- package/dist/src/core/renderers/webgl/shaders/DefaultShaderBatched.js +108 -0
- package/dist/src/core/renderers/webgl/shaders/DefaultShaderBatched.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/DynamicShader.d.ts +29 -0
- package/dist/src/core/renderers/webgl/shaders/DynamicShader.js +408 -0
- package/dist/src/core/renderers/webgl/shaders/DynamicShader.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/RoundedRectangle.d.ts +28 -0
- package/dist/src/core/renderers/webgl/shaders/RoundedRectangle.js +126 -0
- package/dist/src/core/renderers/webgl/shaders/RoundedRectangle.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/SdfShader.d.ts +47 -0
- package/dist/src/core/renderers/webgl/shaders/SdfShader.js +148 -0
- package/dist/src/core/renderers/webgl/shaders/SdfShader.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/effects/BorderBottomEffect.d.ts +31 -0
- package/dist/src/core/renderers/webgl/shaders/effects/BorderBottomEffect.js +71 -0
- package/dist/src/core/renderers/webgl/shaders/effects/BorderBottomEffect.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/effects/BorderEffect.d.ts +30 -0
- package/dist/src/core/renderers/webgl/shaders/effects/BorderEffect.js +58 -0
- package/dist/src/core/renderers/webgl/shaders/effects/BorderEffect.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/effects/BorderLeftEffect.d.ts +31 -0
- package/dist/src/core/renderers/webgl/shaders/effects/BorderLeftEffect.js +71 -0
- package/dist/src/core/renderers/webgl/shaders/effects/BorderLeftEffect.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/effects/BorderRightEffect.d.ts +31 -0
- package/dist/src/core/renderers/webgl/shaders/effects/BorderRightEffect.js +71 -0
- package/dist/src/core/renderers/webgl/shaders/effects/BorderRightEffect.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/effects/BorderTopEffect.d.ts +31 -0
- package/dist/src/core/renderers/webgl/shaders/effects/BorderTopEffect.js +71 -0
- package/dist/src/core/renderers/webgl/shaders/effects/BorderTopEffect.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/effects/EffectUtils.d.ts +9 -0
- package/dist/src/core/renderers/webgl/shaders/effects/EffectUtils.js +136 -0
- package/dist/src/core/renderers/webgl/shaders/effects/EffectUtils.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/effects/FadeOutEffect.d.ts +36 -0
- package/dist/src/core/renderers/webgl/shaders/effects/FadeOutEffect.js +85 -0
- package/dist/src/core/renderers/webgl/shaders/effects/FadeOutEffect.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/effects/GlitchEffect.d.ts +45 -0
- package/dist/src/core/renderers/webgl/shaders/effects/GlitchEffect.js +104 -0
- package/dist/src/core/renderers/webgl/shaders/effects/GlitchEffect.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/effects/GrayscaleEffect.d.ts +22 -0
- package/dist/src/core/renderers/webgl/shaders/effects/GrayscaleEffect.js +45 -0
- package/dist/src/core/renderers/webgl/shaders/effects/GrayscaleEffect.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/effects/HolePunchEffect.d.ts +58 -0
- package/dist/src/core/renderers/webgl/shaders/effects/HolePunchEffect.js +80 -0
- package/dist/src/core/renderers/webgl/shaders/effects/HolePunchEffect.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/effects/LinearGradientEffect.d.ts +35 -0
- package/dist/src/core/renderers/webgl/shaders/effects/LinearGradientEffect.js +134 -0
- package/dist/src/core/renderers/webgl/shaders/effects/LinearGradientEffect.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/effects/RadialGradientEffect.d.ts +40 -0
- package/dist/src/core/renderers/webgl/shaders/effects/RadialGradientEffect.js +143 -0
- package/dist/src/core/renderers/webgl/shaders/effects/RadialGradientEffect.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/effects/RadialProgressEffect.d.ts +61 -0
- package/dist/src/core/renderers/webgl/shaders/effects/RadialProgressEffect.js +127 -0
- package/dist/src/core/renderers/webgl/shaders/effects/RadialProgressEffect.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/effects/RadiusEffect.d.ts +40 -0
- package/dist/src/core/renderers/webgl/shaders/effects/RadiusEffect.js +71 -0
- package/dist/src/core/renderers/webgl/shaders/effects/RadiusEffect.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/effects/ShaderEffect.d.ts +115 -0
- package/dist/src/core/renderers/webgl/shaders/effects/ShaderEffect.js +61 -0
- package/dist/src/core/renderers/webgl/shaders/effects/ShaderEffect.js.map +1 -0
- package/dist/src/core/shaders/canvas/RoundedWithBorder.js +1 -1
- package/dist/src/core/shaders/canvas/RoundedWithBorder.js.map +1 -1
- package/dist/src/core/shaders/canvas/RoundedWithBorderAndShadow.js +1 -1
- package/dist/src/core/shaders/canvas/RoundedWithBorderAndShadow.js.map +1 -1
- package/dist/src/core/shaders/webgl/LinearGradient.js +26 -3
- package/dist/src/core/shaders/webgl/LinearGradient.js.map +1 -1
- package/dist/src/core/shaders/webgl/RadialGradient.js +49 -27
- package/dist/src/core/shaders/webgl/RadialGradient.js.map +1 -1
- package/dist/src/core/shaders/webgl/SdfShader.d.ts +0 -2
- package/dist/src/core/shaders/webgl/SdfShader.js +1 -10
- package/dist/src/core/shaders/webgl/SdfShader.js.map +1 -1
- package/dist/src/core/text-rendering/CanvasFont.d.ts +14 -0
- package/dist/src/core/text-rendering/CanvasFont.js +111 -0
- package/dist/src/core/text-rendering/CanvasFont.js.map +1 -0
- package/dist/src/core/text-rendering/CanvasFontHandler.d.ts +21 -3
- package/dist/src/core/text-rendering/CanvasFontHandler.js +97 -32
- package/dist/src/core/text-rendering/CanvasFontHandler.js.map +1 -1
- package/dist/src/core/text-rendering/CanvasTextRenderer.d.ts +2 -7
- package/dist/src/core/text-rendering/CanvasTextRenderer.js +51 -260
- package/dist/src/core/text-rendering/CanvasTextRenderer.js.map +1 -1
- package/dist/src/core/text-rendering/CoreFont.d.ts +33 -0
- package/dist/src/core/text-rendering/CoreFont.js +48 -0
- package/dist/src/core/text-rendering/CoreFont.js.map +1 -0
- package/dist/src/core/text-rendering/FontManager.d.ts +11 -0
- package/dist/src/core/text-rendering/FontManager.js +42 -0
- package/dist/src/core/text-rendering/FontManager.js.map +1 -0
- package/dist/src/core/text-rendering/SdfFont.d.ts +29 -0
- package/dist/src/core/text-rendering/SdfFont.js +142 -0
- package/dist/src/core/text-rendering/SdfFont.js.map +1 -0
- package/dist/src/core/text-rendering/SdfFontHandler.d.ts +35 -5
- package/dist/src/core/text-rendering/SdfFontHandler.js +79 -56
- package/dist/src/core/text-rendering/SdfFontHandler.js.map +1 -1
- package/dist/src/core/text-rendering/SdfTextRenderer.d.ts +1 -1
- package/dist/src/core/text-rendering/SdfTextRenderer.js +38 -82
- package/dist/src/core/text-rendering/SdfTextRenderer.js.map +1 -1
- package/dist/src/core/text-rendering/TextLayoutEngine.d.ts +19 -0
- package/dist/src/core/text-rendering/{sdf/Utils.js → TextLayoutEngine.js} +125 -107
- package/dist/src/core/text-rendering/TextLayoutEngine.js.map +1 -0
- package/dist/src/core/text-rendering/TextRenderer.d.ts +30 -13
- package/dist/src/core/text-rendering/TextRenderingUtils.d.ts +12 -0
- package/dist/src/core/text-rendering/TextRenderingUtils.js +14 -0
- package/dist/src/core/text-rendering/TextRenderingUtils.js.map +1 -0
- package/dist/src/core/text-rendering/TextTextureRendererUtils.d.ts +72 -0
- package/dist/src/core/text-rendering/TextTextureRendererUtils.js +217 -0
- package/dist/src/core/text-rendering/TextTextureRendererUtils.js.map +1 -0
- package/dist/src/core/text-rendering/TrFontManager.d.ts +26 -0
- package/dist/src/core/text-rendering/TrFontManager.js +131 -0
- package/dist/src/core/text-rendering/TrFontManager.js.map +1 -0
- package/dist/src/core/text-rendering/Utils.d.ts +1 -42
- package/dist/src/core/text-rendering/Utils.js +4 -132
- package/dist/src/core/text-rendering/Utils.js.map +1 -1
- package/dist/src/core/text-rendering/font-face-types/SdfTrFontFace/SdfTrFontFace.d.ts +39 -0
- package/dist/src/core/text-rendering/font-face-types/SdfTrFontFace/SdfTrFontFace.js +125 -0
- package/dist/src/core/text-rendering/font-face-types/SdfTrFontFace/SdfTrFontFace.js.map +1 -0
- package/dist/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/FontShaper.d.ts +103 -0
- package/dist/src/core/text-rendering/{sdf/index.js → font-face-types/SdfTrFontFace/internal/FontShaper.js} +4 -3
- package/dist/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/FontShaper.js.map +1 -0
- package/dist/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/SdfFontShaper.d.ts +62 -0
- package/dist/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/SdfFontShaper.js +88 -0
- package/dist/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/SdfFontShaper.js.map +1 -0
- package/dist/src/core/text-rendering/font-face-types/TrFontFace.d.ts +118 -0
- package/dist/src/core/text-rendering/font-face-types/TrFontFace.js +63 -0
- package/dist/src/core/text-rendering/font-face-types/TrFontFace.js.map +1 -0
- package/dist/src/core/text-rendering/font-face-types/WebTrFontFace.d.ts +14 -0
- package/dist/src/core/text-rendering/font-face-types/WebTrFontFace.js +66 -0
- package/dist/src/core/text-rendering/font-face-types/WebTrFontFace.js.map +1 -0
- package/dist/src/core/text-rendering/font-face-types/utils.d.ts +1 -0
- package/dist/src/core/text-rendering/font-face-types/utils.js +38 -0
- package/dist/src/core/text-rendering/font-face-types/utils.js.map +1 -0
- package/dist/src/core/text-rendering/renderers/CanvasTextRenderer.d.ts +59 -0
- package/dist/src/core/text-rendering/renderers/CanvasTextRenderer.js +397 -0
- package/dist/src/core/text-rendering/renderers/CanvasTextRenderer.js.map +1 -0
- package/dist/src/core/text-rendering/renderers/LightningTextTextureRenderer.d.ts +120 -0
- package/dist/src/core/text-rendering/renderers/LightningTextTextureRenderer.js +551 -0
- package/dist/src/core/text-rendering/renderers/LightningTextTextureRenderer.js.map +1 -0
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.d.ts +92 -0
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.js +607 -0
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.js.map +1 -0
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/PeekableGenerator.d.ts +12 -0
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/PeekableGenerator.js +61 -0
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/PeekableGenerator.js.map +1 -0
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/SpecialCodepoints.d.ts +33 -0
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/SpecialCodepoints.js +52 -0
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/SpecialCodepoints.js.map +1 -0
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/constants.d.ts +13 -0
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/constants.js +32 -0
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/constants.js.map +1 -0
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/getStartConditions.d.ts +23 -0
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/getStartConditions.js +84 -0
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/getStartConditions.js.map +1 -0
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/getUnicodeCodepoints.d.ts +4 -0
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/getUnicodeCodepoints.js +34 -0
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/getUnicodeCodepoints.js.map +1 -0
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText.d.ts +20 -0
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText.js +308 -0
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText.js.map +1 -0
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/measureText.d.ts +10 -0
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/measureText.js +40 -0
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/measureText.js.map +1 -0
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/setRenderWindow.d.ts +26 -0
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/setRenderWindow.js +70 -0
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/setRenderWindow.js.map +1 -0
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/util.d.ts +16 -0
- package/dist/src/core/text-rendering/{canvas/Settings.js → renderers/SdfTextRenderer/internal/util.js} +22 -3
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/util.js.map +1 -0
- package/dist/src/core/text-rendering/renderers/TextRenderer.d.ts +373 -0
- package/dist/src/core/text-rendering/renderers/TextRenderer.js +178 -0
- package/dist/src/core/text-rendering/renderers/TextRenderer.js.map +1 -0
- package/dist/src/core/utils.d.ts +2 -1
- package/dist/src/core/utils.js +1 -1
- package/dist/src/core/utils.js.map +1 -1
- package/dist/src/main-api/DynamicShaderController.d.ts +29 -0
- package/dist/src/main-api/DynamicShaderController.js +58 -0
- package/dist/src/main-api/DynamicShaderController.js.map +1 -0
- package/dist/src/main-api/Inspector.d.ts +124 -0
- package/dist/src/main-api/Inspector.js +292 -13
- package/dist/src/main-api/Inspector.js.map +1 -1
- package/dist/src/main-api/Renderer.d.ts +150 -26
- package/dist/src/main-api/Renderer.js +27 -25
- 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/index.ts +1 -0
- package/package.json +14 -15
- package/src/core/CoreTextNode.ts +55 -27
- package/src/core/Stage.ts +2 -3
- package/src/core/animations/CoreAnimation.ts +8 -9
- package/src/core/lib/textureCompression.ts +4 -2
- package/src/core/shaders/canvas/RoundedWithBorder.ts +1 -1
- package/src/core/shaders/canvas/RoundedWithBorderAndShadow.ts +1 -1
- package/src/core/shaders/webgl/LinearGradient.ts +26 -3
- package/src/core/shaders/webgl/RadialGradient.ts +50 -28
- package/src/core/shaders/webgl/SdfShader.ts +1 -12
- package/src/core/text-rendering/CanvasFontHandler.ts +139 -39
- package/src/core/text-rendering/CanvasTextRenderer.ts +75 -440
- package/src/core/text-rendering/SdfFontHandler.ts +97 -60
- package/src/core/text-rendering/SdfTextRenderer.ts +62 -116
- package/src/core/text-rendering/{sdf/Utils.ts → TextLayoutEngine.ts} +211 -145
- package/src/core/text-rendering/TextRenderer.ts +36 -13
- package/src/core/text-rendering/Utils.ts +5 -163
- package/src/core/text-rendering/{sdf/Utils.test.ts → tests/Canvas.test.ts} +98 -122
- package/src/core/text-rendering/tests/SdfTests.test.ts +414 -0
- package/src/core/utils.ts +9 -7
- package/src/main-api/Inspector.ts +511 -17
- package/src/main-api/Renderer.ts +158 -26
- package/dist/src/core/text-rendering/canvas/Settings.d.ts +0 -64
- package/dist/src/core/text-rendering/canvas/Settings.js.map +0 -1
- package/dist/src/core/text-rendering/canvas/Utils.d.ts +0 -20
- package/dist/src/core/text-rendering/canvas/Utils.js +0 -144
- package/dist/src/core/text-rendering/canvas/Utils.js.map +0 -1
- package/dist/src/core/text-rendering/canvas/calculateRenderInfo.d.ts +0 -60
- package/dist/src/core/text-rendering/canvas/calculateRenderInfo.js +0 -183
- package/dist/src/core/text-rendering/canvas/calculateRenderInfo.js.map +0 -1
- package/dist/src/core/text-rendering/canvas/draw.d.ts +0 -5
- package/dist/src/core/text-rendering/canvas/draw.js +0 -132
- package/dist/src/core/text-rendering/canvas/draw.js.map +0 -1
- package/dist/src/core/text-rendering/sdf/Utils.d.ts +0 -26
- package/dist/src/core/text-rendering/sdf/Utils.js.map +0 -1
- package/dist/src/core/text-rendering/sdf/index.d.ts +0 -1
- package/dist/src/core/text-rendering/sdf/index.js.map +0 -1
- package/src/core/text-rendering/canvas/Settings.ts +0 -99
- package/src/core/text-rendering/canvas/Utils.test.ts +0 -206
- package/src/core/text-rendering/canvas/Utils.ts +0 -178
- package/src/core/text-rendering/canvas/calculateRenderInfo.ts +0 -299
- package/src/core/text-rendering/canvas/draw.ts +0 -165
|
@@ -1,206 +0,0 @@
|
|
|
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 { describe, it, expect, beforeEach, vi } from 'vitest';
|
|
21
|
-
import { wrapText, measureText, wrapWord } from './Utils.js';
|
|
22
|
-
|
|
23
|
-
// Mock canvas context for testing
|
|
24
|
-
const createMockContext = (): CanvasRenderingContext2D =>
|
|
25
|
-
({
|
|
26
|
-
measureText: vi.fn((text: string) => {
|
|
27
|
-
// Mock: each character is 10px wide, spaces are 5px
|
|
28
|
-
// ZWSP has 0 width
|
|
29
|
-
let width = 0;
|
|
30
|
-
for (const char of text) {
|
|
31
|
-
if (char === '\u200B') {
|
|
32
|
-
width += 0; // ZWSP has zero width
|
|
33
|
-
} else if (char === ' ') {
|
|
34
|
-
width += 5;
|
|
35
|
-
} else {
|
|
36
|
-
width += 10;
|
|
37
|
-
}
|
|
38
|
-
}
|
|
39
|
-
return { width };
|
|
40
|
-
}),
|
|
41
|
-
} as unknown as CanvasRenderingContext2D);
|
|
42
|
-
|
|
43
|
-
describe('Canvas Text Utils', () => {
|
|
44
|
-
let mockContext: ReturnType<typeof createMockContext>;
|
|
45
|
-
|
|
46
|
-
beforeEach(() => {
|
|
47
|
-
mockContext = createMockContext();
|
|
48
|
-
});
|
|
49
|
-
|
|
50
|
-
describe('measureText', () => {
|
|
51
|
-
it('should measure text width correctly', () => {
|
|
52
|
-
const width = measureText(mockContext, 'hello', 0);
|
|
53
|
-
expect(width).toBe(50); // 5 characters * 10px each
|
|
54
|
-
});
|
|
55
|
-
|
|
56
|
-
it('should handle empty text', () => {
|
|
57
|
-
const width = measureText(mockContext, '', 0);
|
|
58
|
-
expect(width).toBe(0);
|
|
59
|
-
});
|
|
60
|
-
|
|
61
|
-
it('should account for letter spacing', () => {
|
|
62
|
-
const width = measureText(mockContext, 'hello', 2);
|
|
63
|
-
expect(width).toBe(60); // 5 characters * 10px + 5 * 2 letter spacing
|
|
64
|
-
});
|
|
65
|
-
|
|
66
|
-
it('should skip zero-width spaces in letter spacing calculation', () => {
|
|
67
|
-
const width = measureText(mockContext, 'hel\u200Blo', 2);
|
|
68
|
-
// With letter spacing=2: 'h'(10) + 2 + 'e'(10) + 2 + 'l'(10) + 2 + ZWSP(0) + 'l'(10) + 2 + 'o'(10) = 60
|
|
69
|
-
// The ZWSP is in the string but gets 0 width, letter spacing is still added for non-ZWSP chars
|
|
70
|
-
expect(width).toBe(60);
|
|
71
|
-
});
|
|
72
|
-
|
|
73
|
-
it('should handle spaces correctly', () => {
|
|
74
|
-
const width = measureText(mockContext, 'hi there', 0);
|
|
75
|
-
// With space=0, uses context.measureText() directly
|
|
76
|
-
// Mock returns: 'h'(10) + 'i'(10) + ' '(5) + 't'(10) + 'h'(10) + 'e'(10) + 'r'(10) + 'e'(10) = 75px
|
|
77
|
-
expect(width).toBe(75);
|
|
78
|
-
});
|
|
79
|
-
});
|
|
80
|
-
|
|
81
|
-
describe('wrapWord', () => {
|
|
82
|
-
it('should wrap long words that exceed width', () => {
|
|
83
|
-
const result = wrapWord(
|
|
84
|
-
mockContext,
|
|
85
|
-
'verylongword', // 12 chars = 120px
|
|
86
|
-
100, // maxWidth
|
|
87
|
-
'...',
|
|
88
|
-
0, // letterSpacing
|
|
89
|
-
);
|
|
90
|
-
expect(result).toContain('...');
|
|
91
|
-
expect(result.length).toBeLessThan('verylongword'.length);
|
|
92
|
-
});
|
|
93
|
-
|
|
94
|
-
it('should return word unchanged if it fits', () => {
|
|
95
|
-
const result = wrapWord(
|
|
96
|
-
mockContext,
|
|
97
|
-
'short', // 5 chars = 50px
|
|
98
|
-
100, // maxWidth
|
|
99
|
-
'...',
|
|
100
|
-
0,
|
|
101
|
-
);
|
|
102
|
-
expect(result).toBe('short');
|
|
103
|
-
});
|
|
104
|
-
});
|
|
105
|
-
|
|
106
|
-
describe('wrapText', () => {
|
|
107
|
-
it('should wrap text that exceeds max width', () => {
|
|
108
|
-
const result = wrapText(
|
|
109
|
-
mockContext,
|
|
110
|
-
'hello world test', // hello=50px + space=5px + world=50px = 105px > 100px
|
|
111
|
-
100, // wordWrapWidth
|
|
112
|
-
0, // letterSpacing
|
|
113
|
-
0, // indent
|
|
114
|
-
);
|
|
115
|
-
expect(result.l).toEqual(['hello', 'world test']);
|
|
116
|
-
expect(result.n).toEqual([]); // no real newlines
|
|
117
|
-
});
|
|
118
|
-
|
|
119
|
-
it('should handle single word that fits', () => {
|
|
120
|
-
const result = wrapText(mockContext, 'hello', 100, 0, 0);
|
|
121
|
-
expect(result.l).toEqual(['hello']);
|
|
122
|
-
});
|
|
123
|
-
|
|
124
|
-
it('should handle real newlines', () => {
|
|
125
|
-
const result = wrapText(mockContext, 'hello\nworld', 100, 0, 0);
|
|
126
|
-
expect(result.l).toEqual(['hello', 'world']);
|
|
127
|
-
expect(result.n).toEqual([1]); // newline after first line
|
|
128
|
-
});
|
|
129
|
-
|
|
130
|
-
it('should handle ZWSP as word break opportunity', () => {
|
|
131
|
-
// Test 1: ZWSP should provide break opportunity when needed
|
|
132
|
-
const result1 = wrapText(
|
|
133
|
-
mockContext,
|
|
134
|
-
'hello\u200Bworld test', // hello=50px + world=50px + space=5px + test=40px = 145px
|
|
135
|
-
100,
|
|
136
|
-
0,
|
|
137
|
-
0,
|
|
138
|
-
);
|
|
139
|
-
expect(result1.l).toEqual(['helloworld', 'test']); // Break at regular space, not ZWSP
|
|
140
|
-
|
|
141
|
-
// Test 2: ZWSP should NOT break when text fits on one line
|
|
142
|
-
const result2 = wrapText(
|
|
143
|
-
mockContext,
|
|
144
|
-
'hi\u200Bthere', // hi=20px + there=50px = 70px < 200px
|
|
145
|
-
200,
|
|
146
|
-
0,
|
|
147
|
-
0,
|
|
148
|
-
);
|
|
149
|
-
expect(result2.l).toEqual(['hithere']); // ZWSP is invisible, no space added
|
|
150
|
-
|
|
151
|
-
// Test 3: ZWSP should break when necessary due to width constraints
|
|
152
|
-
const result3 = wrapText(
|
|
153
|
-
mockContext,
|
|
154
|
-
'verylongword\u200Bmore', // First word will exceed 100px
|
|
155
|
-
100,
|
|
156
|
-
0,
|
|
157
|
-
0,
|
|
158
|
-
);
|
|
159
|
-
expect(result3.l.length).toBeGreaterThan(1); // Should break at ZWSP position
|
|
160
|
-
});
|
|
161
|
-
|
|
162
|
-
it('should handle indent correctly', () => {
|
|
163
|
-
const result = wrapText(
|
|
164
|
-
mockContext,
|
|
165
|
-
'hello world', // hello=50px + space=5px + world=50px = 105px, but with indent only 95px available
|
|
166
|
-
100,
|
|
167
|
-
0,
|
|
168
|
-
10, // indent
|
|
169
|
-
);
|
|
170
|
-
expect(result.l).toEqual(['hello', 'world']);
|
|
171
|
-
});
|
|
172
|
-
|
|
173
|
-
it('should preserve spaces but not ZWSP in output', () => {
|
|
174
|
-
const result = wrapText(
|
|
175
|
-
mockContext,
|
|
176
|
-
'word1 word2\u200Bword3',
|
|
177
|
-
200, // Wide enough to fit all
|
|
178
|
-
0,
|
|
179
|
-
0,
|
|
180
|
-
);
|
|
181
|
-
expect(result.l).toEqual(['word1 word2word3']); // Space preserved, ZWSP removed
|
|
182
|
-
});
|
|
183
|
-
|
|
184
|
-
it('should handle mixed ZWSP and regular spaces', () => {
|
|
185
|
-
const result = wrapText(
|
|
186
|
-
mockContext,
|
|
187
|
-
'word1\u200Bword2 word3\u200Bword4', // Mix of ZWSP and spaces
|
|
188
|
-
50, // Force wrapping
|
|
189
|
-
0,
|
|
190
|
-
0,
|
|
191
|
-
);
|
|
192
|
-
// Should break at both ZWSP and space opportunities when needed
|
|
193
|
-
expect(result.l.length).toBeGreaterThan(1);
|
|
194
|
-
|
|
195
|
-
// Test that ZWSP is not included in any line (invisible)
|
|
196
|
-
for (const line of result.l) {
|
|
197
|
-
expect(line).not.toContain('\u200B');
|
|
198
|
-
}
|
|
199
|
-
|
|
200
|
-
// Test that at least one line contains a regular space (if not broken at that point)
|
|
201
|
-
const hasSpace = result.l.some((line) => line.includes(' '));
|
|
202
|
-
// Note: spaces might be at break points, so this test is flexible
|
|
203
|
-
expect(typeof hasSpace).toBe('boolean'); // Just verify the test runs
|
|
204
|
-
});
|
|
205
|
-
});
|
|
206
|
-
});
|
|
@@ -1,178 +0,0 @@
|
|
|
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 { NormalizedFontMetrics } from '../TextRenderer.js';
|
|
21
|
-
import { isZeroWidthSpace } from '../Utils.js';
|
|
22
|
-
import type { TextBaseline } from './Settings.js';
|
|
23
|
-
|
|
24
|
-
export const measureText = (
|
|
25
|
-
context: CanvasRenderingContext2D | OffscreenCanvasRenderingContext2D,
|
|
26
|
-
word: string,
|
|
27
|
-
space = 0,
|
|
28
|
-
) => {
|
|
29
|
-
if (space === 0) {
|
|
30
|
-
return context.measureText(word).width;
|
|
31
|
-
}
|
|
32
|
-
return word.split('').reduce((acc, char) => {
|
|
33
|
-
if (isZeroWidthSpace(char) === true) {
|
|
34
|
-
return acc;
|
|
35
|
-
}
|
|
36
|
-
return acc + context.measureText(char).width + space;
|
|
37
|
-
}, 0);
|
|
38
|
-
};
|
|
39
|
-
|
|
40
|
-
// Helper functions
|
|
41
|
-
export const wrapWord = (
|
|
42
|
-
context: CanvasRenderingContext2D | OffscreenCanvasRenderingContext2D,
|
|
43
|
-
word: string,
|
|
44
|
-
wordWrapWidth: number,
|
|
45
|
-
suffix: string,
|
|
46
|
-
letterSpacing: number,
|
|
47
|
-
) => {
|
|
48
|
-
const suffixWidth = measureText(context, suffix, letterSpacing);
|
|
49
|
-
const wordLen = word.length;
|
|
50
|
-
const wordWidth = measureText(context, word, letterSpacing);
|
|
51
|
-
if (wordWidth <= wordWrapWidth) {
|
|
52
|
-
return word;
|
|
53
|
-
}
|
|
54
|
-
let cutoffIndex = Math.floor((wordWrapWidth * wordLen) / wordWidth);
|
|
55
|
-
let truncWordWidth =
|
|
56
|
-
measureText(context, word.substring(0, cutoffIndex), letterSpacing) +
|
|
57
|
-
suffixWidth;
|
|
58
|
-
if (truncWordWidth > wordWrapWidth) {
|
|
59
|
-
while (cutoffIndex > 0) {
|
|
60
|
-
truncWordWidth =
|
|
61
|
-
measureText(context, word.substring(0, cutoffIndex), letterSpacing) +
|
|
62
|
-
suffixWidth;
|
|
63
|
-
if (truncWordWidth > wordWrapWidth) {
|
|
64
|
-
cutoffIndex -= 1;
|
|
65
|
-
} else {
|
|
66
|
-
break;
|
|
67
|
-
}
|
|
68
|
-
}
|
|
69
|
-
} else {
|
|
70
|
-
while (cutoffIndex < wordLen) {
|
|
71
|
-
truncWordWidth =
|
|
72
|
-
measureText(context, word.substring(0, cutoffIndex), letterSpacing) +
|
|
73
|
-
suffixWidth;
|
|
74
|
-
if (truncWordWidth < wordWrapWidth) {
|
|
75
|
-
cutoffIndex += 1;
|
|
76
|
-
} else {
|
|
77
|
-
cutoffIndex -= 1;
|
|
78
|
-
break;
|
|
79
|
-
}
|
|
80
|
-
}
|
|
81
|
-
}
|
|
82
|
-
return (
|
|
83
|
-
word.substring(0, cutoffIndex) +
|
|
84
|
-
(wordWrapWidth >= suffixWidth ? suffix : '')
|
|
85
|
-
);
|
|
86
|
-
};
|
|
87
|
-
|
|
88
|
-
export const wrapText = (
|
|
89
|
-
context: CanvasRenderingContext2D | OffscreenCanvasRenderingContext2D,
|
|
90
|
-
text: string,
|
|
91
|
-
wordWrapWidth: number,
|
|
92
|
-
letterSpacing: number,
|
|
93
|
-
indent: number,
|
|
94
|
-
) => {
|
|
95
|
-
const spaceRegex = / |\u200B/g;
|
|
96
|
-
const lines = text.split(/\r?\n/g);
|
|
97
|
-
let allLines: string[] = [];
|
|
98
|
-
const realNewlines: number[] = [];
|
|
99
|
-
for (let i = 0; i < lines.length; i++) {
|
|
100
|
-
const resultLines: string[] = [];
|
|
101
|
-
let result = '';
|
|
102
|
-
let spaceLeft = wordWrapWidth - indent;
|
|
103
|
-
const line = lines[i] ?? '';
|
|
104
|
-
const words = line.split(spaceRegex);
|
|
105
|
-
const spaces = line.match(spaceRegex) || [];
|
|
106
|
-
for (let j = 0; j < words.length; j++) {
|
|
107
|
-
const space = spaces[j - 1] || '';
|
|
108
|
-
const word = words[j] || '';
|
|
109
|
-
const wordWidth = measureText(context, word, letterSpacing);
|
|
110
|
-
const wordWidthWithSpace =
|
|
111
|
-
wordWidth + measureText(context, space, letterSpacing);
|
|
112
|
-
if (j === 0 || wordWidthWithSpace > spaceLeft) {
|
|
113
|
-
if (j > 0) {
|
|
114
|
-
resultLines.push(result);
|
|
115
|
-
result = '';
|
|
116
|
-
}
|
|
117
|
-
result += word;
|
|
118
|
-
spaceLeft = wordWrapWidth - wordWidth - (j === 0 ? indent : 0);
|
|
119
|
-
} else {
|
|
120
|
-
spaceLeft -= wordWidthWithSpace;
|
|
121
|
-
// Don't add ZWSP to the output since it's invisible
|
|
122
|
-
if (space !== '\u200B') {
|
|
123
|
-
result += space + word;
|
|
124
|
-
} else {
|
|
125
|
-
result += word;
|
|
126
|
-
}
|
|
127
|
-
}
|
|
128
|
-
}
|
|
129
|
-
resultLines.push(result);
|
|
130
|
-
result = '';
|
|
131
|
-
allLines = allLines.concat(resultLines);
|
|
132
|
-
if (i < lines.length - 1) {
|
|
133
|
-
realNewlines.push(allLines.length);
|
|
134
|
-
}
|
|
135
|
-
}
|
|
136
|
-
return { l: allLines, n: realNewlines };
|
|
137
|
-
};
|
|
138
|
-
|
|
139
|
-
export const isNormalizedFontMetrics = (
|
|
140
|
-
obj: unknown,
|
|
141
|
-
): obj is NormalizedFontMetrics => {
|
|
142
|
-
return (
|
|
143
|
-
typeof obj === 'object' &&
|
|
144
|
-
obj !== null &&
|
|
145
|
-
'ascender' in obj &&
|
|
146
|
-
typeof (obj as { ascender: unknown }).ascender === 'number' &&
|
|
147
|
-
'descender' in obj &&
|
|
148
|
-
typeof (obj as { descender: unknown }).descender === 'number' &&
|
|
149
|
-
'lineGap' in obj &&
|
|
150
|
-
typeof (obj as { lineGap: unknown }).lineGap === 'number'
|
|
151
|
-
);
|
|
152
|
-
};
|
|
153
|
-
|
|
154
|
-
/**
|
|
155
|
-
* Calculate height for the canvas
|
|
156
|
-
*
|
|
157
|
-
* @param textBaseline
|
|
158
|
-
* @param fontSize
|
|
159
|
-
* @param lineHeight
|
|
160
|
-
* @param numLines
|
|
161
|
-
* @param offsetY
|
|
162
|
-
* @returns
|
|
163
|
-
*/
|
|
164
|
-
export const calcHeight = (
|
|
165
|
-
textBaseline: TextBaseline,
|
|
166
|
-
fontSize: number,
|
|
167
|
-
lineHeight: number,
|
|
168
|
-
numLines: number,
|
|
169
|
-
offsetY: number,
|
|
170
|
-
) => {
|
|
171
|
-
const baselineOffset = textBaseline !== 'bottom' ? 0.5 * fontSize : 0;
|
|
172
|
-
return (
|
|
173
|
-
lineHeight * (numLines - 1) +
|
|
174
|
-
baselineOffset +
|
|
175
|
-
Math.max(lineHeight, fontSize) +
|
|
176
|
-
offsetY
|
|
177
|
-
);
|
|
178
|
-
};
|
|
@@ -1,299 +0,0 @@
|
|
|
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 { calculateFontMetrics } from '../Utils.js';
|
|
21
|
-
import { wrapText, wrapWord, measureText, calcHeight } from './Utils.js';
|
|
22
|
-
import { getFontMetrics, setFontMetrics } from '../CanvasFontHandler.js';
|
|
23
|
-
import type {
|
|
24
|
-
NormalizedFontMetrics,
|
|
25
|
-
TextBaseline,
|
|
26
|
-
TextVerticalAlign,
|
|
27
|
-
} from '../TextRenderer.js';
|
|
28
|
-
import type { TextAlign, TextOverflow } from './Settings.js';
|
|
29
|
-
|
|
30
|
-
export interface RenderInfo {
|
|
31
|
-
lines: string[];
|
|
32
|
-
precision: number;
|
|
33
|
-
remainingText: string;
|
|
34
|
-
moreTextLines: boolean;
|
|
35
|
-
width: number;
|
|
36
|
-
innerWidth: number;
|
|
37
|
-
height: number;
|
|
38
|
-
fontSize: number;
|
|
39
|
-
cutSx: number;
|
|
40
|
-
cutSy: number;
|
|
41
|
-
cutEx: number;
|
|
42
|
-
cutEy: number;
|
|
43
|
-
lineHeight: number | null;
|
|
44
|
-
defLineHeight: number;
|
|
45
|
-
lineWidths: number[];
|
|
46
|
-
offsetY: number;
|
|
47
|
-
paddingLeft: number;
|
|
48
|
-
paddingRight: number;
|
|
49
|
-
letterSpacing: number;
|
|
50
|
-
textIndent: number;
|
|
51
|
-
metrics: NormalizedFontMetrics;
|
|
52
|
-
text: string;
|
|
53
|
-
fontStyle: string;
|
|
54
|
-
fontBaselineRatio: number;
|
|
55
|
-
fontFamily: string | null;
|
|
56
|
-
wordWrap: boolean;
|
|
57
|
-
wordWrapWidth: number;
|
|
58
|
-
wordBreak: 'normal' | 'break-all' | 'break-word';
|
|
59
|
-
textOverflow: TextOverflow | null;
|
|
60
|
-
textBaseline: TextBaseline;
|
|
61
|
-
textAlign: TextAlign;
|
|
62
|
-
verticalAlign: TextVerticalAlign;
|
|
63
|
-
maxLines: number;
|
|
64
|
-
maxHeight: number | null;
|
|
65
|
-
overflowSuffix: string;
|
|
66
|
-
textColor: number;
|
|
67
|
-
shadow: boolean;
|
|
68
|
-
shadowColor: number;
|
|
69
|
-
shadowOffsetX: number;
|
|
70
|
-
shadowOffsetY: number;
|
|
71
|
-
shadowBlur: number;
|
|
72
|
-
highlight: boolean;
|
|
73
|
-
highlightHeight: number;
|
|
74
|
-
highlightColor: number;
|
|
75
|
-
highlightOffset: number;
|
|
76
|
-
highlightPaddingLeft: number;
|
|
77
|
-
highlightPaddingRight: number;
|
|
78
|
-
advancedRenderer: boolean;
|
|
79
|
-
|
|
80
|
-
// Normally stage options
|
|
81
|
-
textRenderIssueMargin: number;
|
|
82
|
-
}
|
|
83
|
-
|
|
84
|
-
export interface LineType {
|
|
85
|
-
text: string;
|
|
86
|
-
x: number;
|
|
87
|
-
y: number;
|
|
88
|
-
w: number;
|
|
89
|
-
}
|
|
90
|
-
|
|
91
|
-
export function calculateRenderInfo(
|
|
92
|
-
context: OffscreenCanvasRenderingContext2D | CanvasRenderingContext2D,
|
|
93
|
-
renderInfo: RenderInfo,
|
|
94
|
-
) {
|
|
95
|
-
const precision = renderInfo.precision;
|
|
96
|
-
const paddingLeft = renderInfo.paddingLeft * precision;
|
|
97
|
-
const paddingRight = renderInfo.paddingRight * precision;
|
|
98
|
-
const fontSize = renderInfo.fontSize * precision;
|
|
99
|
-
let offsetY =
|
|
100
|
-
renderInfo.offsetY === null ? null : renderInfo.offsetY * precision;
|
|
101
|
-
const w = renderInfo.width * precision;
|
|
102
|
-
const h = renderInfo.height * precision;
|
|
103
|
-
let wordWrapWidth = renderInfo.wordWrapWidth * precision;
|
|
104
|
-
const cutSx = renderInfo.cutSx * precision;
|
|
105
|
-
const cutEx = renderInfo.cutEx * precision;
|
|
106
|
-
const cutSy = renderInfo.cutSy * precision;
|
|
107
|
-
const cutEy = renderInfo.cutEy * precision;
|
|
108
|
-
const letterSpacing = (renderInfo.letterSpacing || 0) * precision;
|
|
109
|
-
const textIndent = renderInfo.textIndent * precision;
|
|
110
|
-
|
|
111
|
-
const fontFamily = renderInfo.fontFamily!;
|
|
112
|
-
|
|
113
|
-
// Set font properties
|
|
114
|
-
context.font = `${renderInfo.fontStyle} ${fontSize}px ${fontFamily}`;
|
|
115
|
-
context.textBaseline = renderInfo.textBaseline;
|
|
116
|
-
|
|
117
|
-
let metrics = getFontMetrics(fontFamily, fontSize);
|
|
118
|
-
|
|
119
|
-
if (metrics === null) {
|
|
120
|
-
metrics = calculateFontMetrics(context, fontFamily, fontSize);
|
|
121
|
-
setFontMetrics(fontFamily, metrics);
|
|
122
|
-
}
|
|
123
|
-
|
|
124
|
-
const defLineHeight =
|
|
125
|
-
fontSize *
|
|
126
|
-
(metrics.ascender - metrics.descender + metrics.lineGap) *
|
|
127
|
-
precision;
|
|
128
|
-
const lineHeight =
|
|
129
|
-
renderInfo.lineHeight !== null
|
|
130
|
-
? renderInfo.lineHeight * precision
|
|
131
|
-
: defLineHeight;
|
|
132
|
-
|
|
133
|
-
const maxHeight = renderInfo.maxHeight;
|
|
134
|
-
const containedMaxLines =
|
|
135
|
-
maxHeight !== null && lineHeight > 0
|
|
136
|
-
? Math.floor(maxHeight / lineHeight)
|
|
137
|
-
: 0;
|
|
138
|
-
const setMaxLines = renderInfo.maxLines;
|
|
139
|
-
const calcMaxLines =
|
|
140
|
-
containedMaxLines > 0 && setMaxLines > 0
|
|
141
|
-
? Math.min(containedMaxLines, setMaxLines)
|
|
142
|
-
: Math.max(containedMaxLines, setMaxLines);
|
|
143
|
-
|
|
144
|
-
const textOverflow = renderInfo.textOverflow;
|
|
145
|
-
const wordWrap = renderInfo.wordWrap;
|
|
146
|
-
|
|
147
|
-
// Total width
|
|
148
|
-
let width = w || 2048 / precision;
|
|
149
|
-
// Inner width
|
|
150
|
-
let innerWidth = width - paddingLeft;
|
|
151
|
-
if (innerWidth < 10) {
|
|
152
|
-
width += 10 - innerWidth;
|
|
153
|
-
innerWidth = 10;
|
|
154
|
-
}
|
|
155
|
-
if (wordWrapWidth === 0) {
|
|
156
|
-
wordWrapWidth = innerWidth;
|
|
157
|
-
}
|
|
158
|
-
|
|
159
|
-
// Text overflow
|
|
160
|
-
let text: string = renderInfo.text;
|
|
161
|
-
if (textOverflow !== null && wordWrap === false) {
|
|
162
|
-
let suffix: string;
|
|
163
|
-
switch (textOverflow) {
|
|
164
|
-
case 'clip':
|
|
165
|
-
suffix = '';
|
|
166
|
-
break;
|
|
167
|
-
case 'ellipsis':
|
|
168
|
-
suffix = renderInfo.overflowSuffix;
|
|
169
|
-
break;
|
|
170
|
-
default:
|
|
171
|
-
suffix = String(textOverflow);
|
|
172
|
-
}
|
|
173
|
-
text = wrapWord(
|
|
174
|
-
context,
|
|
175
|
-
text,
|
|
176
|
-
wordWrapWidth - textIndent,
|
|
177
|
-
suffix,
|
|
178
|
-
letterSpacing,
|
|
179
|
-
);
|
|
180
|
-
}
|
|
181
|
-
|
|
182
|
-
// Word wrap
|
|
183
|
-
let linesInfo: { n: number[]; l: string[] };
|
|
184
|
-
if (wordWrap) {
|
|
185
|
-
linesInfo = wrapText(
|
|
186
|
-
context,
|
|
187
|
-
text,
|
|
188
|
-
wordWrapWidth,
|
|
189
|
-
letterSpacing,
|
|
190
|
-
textIndent,
|
|
191
|
-
);
|
|
192
|
-
} else {
|
|
193
|
-
linesInfo = { l: text.split(/(?:\r\n|\r|\n)/), n: [] };
|
|
194
|
-
const n = linesInfo.l.length;
|
|
195
|
-
for (let i = 0; i < n - 1; i++) {
|
|
196
|
-
linesInfo.n.push(i);
|
|
197
|
-
}
|
|
198
|
-
}
|
|
199
|
-
let lines: string[] = linesInfo.l;
|
|
200
|
-
|
|
201
|
-
let remainingText = '';
|
|
202
|
-
let moreTextLines = false;
|
|
203
|
-
if (calcMaxLines > 0 && lines.length > calcMaxLines) {
|
|
204
|
-
const usedLines = lines.slice(0, calcMaxLines);
|
|
205
|
-
let otherLines: string[] = [];
|
|
206
|
-
const overflowSuffix = renderInfo.overflowSuffix;
|
|
207
|
-
|
|
208
|
-
if (overflowSuffix.length > 0) {
|
|
209
|
-
const w = measureText(context, overflowSuffix, letterSpacing);
|
|
210
|
-
const al = wrapText(
|
|
211
|
-
context,
|
|
212
|
-
usedLines[usedLines.length - 1]!,
|
|
213
|
-
wordWrapWidth - w,
|
|
214
|
-
letterSpacing,
|
|
215
|
-
textIndent,
|
|
216
|
-
);
|
|
217
|
-
usedLines[usedLines.length - 1] = `${al.l[0]!}${overflowSuffix}`;
|
|
218
|
-
otherLines = [al.l.length > 1 ? al.l[1]! : ''];
|
|
219
|
-
} else {
|
|
220
|
-
otherLines = [''];
|
|
221
|
-
}
|
|
222
|
-
// Re-assemble the remaining text
|
|
223
|
-
let i: number;
|
|
224
|
-
const n = lines.length;
|
|
225
|
-
let j = 0;
|
|
226
|
-
const m = linesInfo.n.length;
|
|
227
|
-
for (i = calcMaxLines; i < n; i++) {
|
|
228
|
-
otherLines[j] += `${otherLines[j] ? ' ' : ''}${lines[i] ?? ''}`;
|
|
229
|
-
if (i + 1 < m && linesInfo.n[i + 1] !== undefined) {
|
|
230
|
-
j++;
|
|
231
|
-
}
|
|
232
|
-
}
|
|
233
|
-
remainingText = otherLines.join('\n');
|
|
234
|
-
moreTextLines = true;
|
|
235
|
-
lines = usedLines;
|
|
236
|
-
}
|
|
237
|
-
|
|
238
|
-
// Calculate text width
|
|
239
|
-
let maxLineWidth = 0;
|
|
240
|
-
const lineWidths: number[] = [];
|
|
241
|
-
for (let i = 0; i < lines.length; i++) {
|
|
242
|
-
const lineWidth =
|
|
243
|
-
measureText(context, lines[i]!, letterSpacing) +
|
|
244
|
-
(i === 0 ? textIndent : 0);
|
|
245
|
-
lineWidths.push(lineWidth);
|
|
246
|
-
maxLineWidth = Math.max(maxLineWidth, lineWidth);
|
|
247
|
-
}
|
|
248
|
-
|
|
249
|
-
if (w === 0) {
|
|
250
|
-
width = maxLineWidth + paddingLeft + paddingRight;
|
|
251
|
-
innerWidth = maxLineWidth;
|
|
252
|
-
}
|
|
253
|
-
if (
|
|
254
|
-
wordWrap === true &&
|
|
255
|
-
w > maxLineWidth &&
|
|
256
|
-
renderInfo.textAlign === 'left' &&
|
|
257
|
-
lines.length === 1
|
|
258
|
-
) {
|
|
259
|
-
width = maxLineWidth + paddingLeft + paddingRight;
|
|
260
|
-
}
|
|
261
|
-
|
|
262
|
-
let height: number;
|
|
263
|
-
if (h > 0) {
|
|
264
|
-
height = h;
|
|
265
|
-
} else {
|
|
266
|
-
height = calcHeight(
|
|
267
|
-
renderInfo.textBaseline,
|
|
268
|
-
fontSize,
|
|
269
|
-
lineHeight,
|
|
270
|
-
lines.length,
|
|
271
|
-
offsetY as number,
|
|
272
|
-
);
|
|
273
|
-
}
|
|
274
|
-
if (offsetY === null) {
|
|
275
|
-
offsetY = fontSize;
|
|
276
|
-
}
|
|
277
|
-
|
|
278
|
-
renderInfo.width = width;
|
|
279
|
-
renderInfo.height = height;
|
|
280
|
-
renderInfo.lines = lines;
|
|
281
|
-
renderInfo.precision = precision;
|
|
282
|
-
renderInfo.remainingText = remainingText;
|
|
283
|
-
renderInfo.moreTextLines = moreTextLines;
|
|
284
|
-
renderInfo.innerWidth = innerWidth;
|
|
285
|
-
renderInfo.fontSize = fontSize;
|
|
286
|
-
renderInfo.cutSx = cutSx;
|
|
287
|
-
renderInfo.cutSy = cutSy;
|
|
288
|
-
renderInfo.cutEx = cutEx;
|
|
289
|
-
renderInfo.cutEy = cutEy;
|
|
290
|
-
renderInfo.lineHeight = lineHeight;
|
|
291
|
-
renderInfo.defLineHeight = defLineHeight;
|
|
292
|
-
renderInfo.lineWidths = lineWidths;
|
|
293
|
-
renderInfo.offsetY = offsetY;
|
|
294
|
-
renderInfo.paddingLeft = paddingLeft;
|
|
295
|
-
renderInfo.paddingRight = paddingRight;
|
|
296
|
-
renderInfo.letterSpacing = letterSpacing;
|
|
297
|
-
renderInfo.textIndent = textIndent;
|
|
298
|
-
renderInfo.metrics = metrics;
|
|
299
|
-
}
|