@lightningjs/renderer 3.0.0-beta9 → 3.0.0
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 +230 -147
- package/dist/exports/canvas.d.ts +1 -1
- package/dist/exports/canvas.js +1 -1
- package/dist/exports/canvas.js.map +1 -1
- package/dist/exports/index.d.ts +5 -6
- package/dist/exports/index.js +3 -5
- package/dist/exports/index.js.map +1 -1
- package/dist/exports/platform.d.ts +7 -0
- package/dist/exports/platform.js +27 -0
- package/dist/exports/platform.js.map +1 -0
- package/dist/exports/webgl.d.ts +2 -1
- package/dist/exports/webgl.js +2 -1
- package/dist/exports/webgl.js.map +1 -1
- package/dist/src/common/CommonTypes.d.ts +15 -3
- package/dist/src/core/AutosizeManager.d.ts +29 -0
- package/dist/src/core/AutosizeManager.js +169 -0
- package/dist/src/core/AutosizeManager.js.map +1 -0
- package/dist/src/core/Autosizer.d.ts +35 -0
- package/dist/src/core/Autosizer.js +196 -0
- package/dist/src/core/Autosizer.js.map +1 -0
- package/dist/src/core/CoreNode.d.ts +106 -58
- package/dist/src/core/CoreNode.js +524 -282
- package/dist/src/core/CoreNode.js.map +1 -1
- package/dist/src/core/CoreTextNode.d.ts +73 -88
- package/dist/src/core/CoreTextNode.js +375 -236
- package/dist/src/core/CoreTextNode.js.map +1 -1
- package/dist/src/core/CoreTextureManager.d.ts +19 -17
- package/dist/src/core/CoreTextureManager.js +52 -120
- package/dist/src/core/CoreTextureManager.js.map +1 -1
- package/dist/src/core/Stage.d.ts +63 -9
- package/dist/src/core/Stage.js +233 -133
- package/dist/src/core/Stage.js.map +1 -1
- package/dist/src/core/TextureError.d.ts +11 -0
- package/dist/src/core/TextureError.js +37 -0
- package/dist/src/core/TextureError.js.map +1 -0
- package/dist/src/core/TextureMemoryManager.d.ts +2 -4
- package/dist/src/core/TextureMemoryManager.js +80 -113
- package/dist/src/core/TextureMemoryManager.js.map +1 -1
- package/dist/src/core/animations/Animation.d.ts +21 -0
- package/dist/src/core/animations/Animation.js +194 -0
- package/dist/src/core/animations/Animation.js.map +1 -0
- package/dist/src/core/animations/CoreAnimation.d.ts +3 -3
- package/dist/src/core/animations/CoreAnimation.js +3 -3
- package/dist/src/core/animations/CoreAnimation.js.map +1 -1
- package/dist/src/core/animations/CoreAnimationController.d.ts +1 -1
- package/dist/src/core/animations/CoreAnimationController.js +4 -2
- package/dist/src/core/animations/CoreAnimationController.js.map +1 -1
- package/dist/src/core/animations/Playback.d.ts +64 -0
- package/dist/src/core/animations/Playback.js +169 -0
- package/dist/src/core/animations/Playback.js.map +1 -0
- package/dist/src/core/animations/Transition.d.ts +27 -0
- package/dist/src/core/animations/Transition.js +52 -0
- package/dist/src/core/animations/Transition.js.map +1 -0
- package/dist/src/core/animations/utils.d.ts +2 -0
- package/dist/src/core/animations/utils.js +136 -0
- package/dist/src/core/animations/utils.js.map +1 -0
- package/dist/src/core/lib/ImageWorker.d.ts +2 -2
- package/dist/src/core/lib/ImageWorker.js +30 -11
- package/dist/src/core/lib/ImageWorker.js.map +1 -1
- package/dist/src/core/lib/WebGlContextWrapper.d.ts +22 -1
- package/dist/src/core/lib/WebGlContextWrapper.js +49 -3
- package/dist/src/core/lib/WebGlContextWrapper.js.map +1 -1
- package/dist/src/core/lib/collectionUtils.d.ts +4 -0
- package/dist/src/core/lib/collectionUtils.js +72 -0
- package/dist/src/core/lib/collectionUtils.js.map +1 -0
- package/dist/src/core/lib/colorCache.d.ts +1 -0
- package/dist/src/core/lib/colorCache.js +19 -0
- package/dist/src/core/lib/colorCache.js.map +1 -0
- package/dist/src/core/lib/colorParser.d.ts +21 -0
- package/dist/src/core/lib/colorParser.js +72 -0
- package/dist/src/core/lib/colorParser.js.map +1 -0
- package/dist/src/core/lib/textureCompression.d.ts +14 -2
- package/dist/src/core/lib/textureCompression.js +320 -67
- package/dist/src/core/lib/textureCompression.js.map +1 -1
- package/dist/src/core/lib/utils.d.ts +6 -6
- package/dist/src/core/lib/utils.js +21 -65
- package/dist/src/core/lib/utils.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/platforms/GlContextWrapper.d.ts +136 -0
- package/{src/core/text-rendering/TextRenderingUtils.ts → dist/src/core/platforms/GlContextWrapper.js} +32 -36
- package/dist/src/core/platforms/GlContextWrapper.js.map +1 -0
- package/dist/src/core/platforms/Platform.d.ts +78 -12
- package/dist/src/core/platforms/Platform.js +18 -0
- package/dist/src/core/platforms/Platform.js.map +1 -1
- package/dist/src/core/platforms/web/WebGlContextWrapper.d.ts +776 -0
- package/dist/src/core/platforms/web/WebGlContextWrapper.js +1208 -0
- package/dist/src/core/platforms/web/WebGlContextWrapper.js.map +1 -0
- package/dist/src/core/platforms/web/WebPlatform.d.ts +17 -2
- package/dist/src/core/platforms/web/WebPlatform.js +158 -13
- package/dist/src/core/platforms/web/WebPlatform.js.map +1 -1
- package/dist/src/core/platforms/web/WebPlatformChrome50.d.ts +19 -0
- package/dist/src/core/platforms/web/WebPlatformChrome50.js +54 -0
- package/dist/src/core/platforms/web/WebPlatformChrome50.js.map +1 -0
- package/dist/src/core/platforms/web/WebPlatformLegacy.d.ts +20 -0
- package/dist/src/core/platforms/web/WebPlatformLegacy.js +105 -0
- package/dist/src/core/platforms/web/WebPlatformLegacy.js.map +1 -0
- package/dist/src/core/platforms/web/WebPlatformNext.d.ts +21 -0
- package/dist/src/core/platforms/web/WebPlatformNext.js +52 -0
- package/dist/src/core/platforms/web/WebPlatformNext.js.map +1 -0
- package/dist/src/core/platforms/web/lib/ImageWorker.d.ts +21 -0
- package/dist/src/core/platforms/web/lib/ImageWorker.js +136 -0
- package/dist/src/core/platforms/web/lib/ImageWorker.js.map +1 -0
- package/dist/src/core/platforms/web/lib/ImageWorkerDefault.d.ts +6 -0
- package/dist/src/core/platforms/web/lib/ImageWorkerDefault.js +92 -0
- package/dist/src/core/platforms/web/lib/ImageWorkerDefault.js.map +1 -0
- package/dist/src/core/platforms/web/lib/ImageWorkerLegacy.d.ts +1 -0
- package/dist/src/core/platforms/web/lib/ImageWorkerLegacy.js +63 -0
- package/dist/src/core/platforms/web/lib/ImageWorkerLegacy.js.map +1 -0
- package/dist/src/core/platforms/web/lib/ImageWorkerNoOptions.d.ts +7 -0
- package/dist/src/core/platforms/web/lib/ImageWorkerNoOptions.js +75 -0
- package/dist/src/core/platforms/web/lib/ImageWorkerNoOptions.js.map +1 -0
- package/dist/src/core/platforms/web/lib/createImageBitmap.d.ts +1 -0
- package/dist/src/core/platforms/web/lib/createImageBitmap.js +27 -0
- package/dist/src/core/platforms/web/lib/createImageBitmap.js.map +1 -0
- package/dist/src/core/platforms/web/lib/textureCompression.d.ts +26 -0
- package/dist/src/core/platforms/web/lib/textureCompression.js +301 -0
- package/dist/src/core/platforms/web/lib/textureCompression.js.map +1 -0
- package/dist/src/core/platforms/web/lib/textureSvg.d.ts +7 -0
- package/dist/src/core/platforms/web/lib/textureSvg.js +51 -0
- package/dist/src/core/platforms/web/lib/textureSvg.js.map +1 -0
- package/dist/src/core/platforms/web/lib/utils.d.ts +5 -0
- package/dist/src/core/platforms/web/lib/utils.js +86 -0
- package/dist/src/core/platforms/web/lib/utils.js.map +1 -0
- package/dist/src/core/renderers/CoreContextTexture.d.ts +2 -1
- package/dist/src/core/renderers/CoreContextTexture.js.map +1 -1
- package/dist/src/core/renderers/CoreRenderer.d.ts +4 -40
- package/dist/src/core/renderers/CoreRenderer.js +3 -4
- package/dist/src/core/renderers/CoreRenderer.js.map +1 -1
- package/dist/src/core/renderers/CoreShader.d.ts +9 -0
- package/{src/core/text-rendering/renderers/SdfTextRenderer/internal/constants.ts → dist/src/core/renderers/CoreShader.js} +28 -32
- package/dist/src/core/renderers/CoreShader.js.map +1 -0
- package/dist/src/core/renderers/CoreShaderNode.d.ts +10 -0
- package/dist/src/core/renderers/CoreShaderNode.js +19 -2
- package/dist/src/core/renderers/CoreShaderNode.js.map +1 -1
- package/dist/src/core/renderers/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/CanvasRenderer.d.ts +5 -6
- package/dist/src/core/renderers/canvas/CanvasRenderer.js +67 -91
- package/dist/src/core/renderers/canvas/CanvasRenderer.js.map +1 -1
- package/dist/src/core/renderers/canvas/CanvasShaderNode.d.ts +1 -2
- package/dist/src/core/renderers/canvas/CanvasShaderNode.js +5 -4
- package/dist/src/core/renderers/canvas/CanvasShaderNode.js.map +1 -1
- package/dist/src/core/renderers/canvas/CanvasTexture.d.ts +3 -2
- package/dist/src/core/renderers/canvas/CanvasTexture.js +17 -13
- package/dist/src/core/renderers/canvas/CanvasTexture.js.map +1 -1
- package/dist/src/core/renderers/canvas/internal/C2DShaderUtils.d.ts +13 -0
- package/dist/src/core/renderers/canvas/internal/C2DShaderUtils.js +113 -192
- package/dist/src/core/renderers/canvas/internal/C2DShaderUtils.js.map +1 -1
- package/dist/src/core/renderers/canvas/internal/ColorUtils.d.ts +0 -2
- package/dist/src/core/renderers/canvas/internal/ColorUtils.js +0 -14
- package/dist/src/core/renderers/canvas/internal/ColorUtils.js.map +1 -1
- package/dist/src/core/renderers/canvas/shaders/UnsupportedShader.d.ts +10 -0
- package/{src/core/text-rendering/renderers/SdfTextRenderer/internal/util.ts → dist/src/core/renderers/canvas/shaders/UnsupportedShader.js} +43 -40
- package/dist/src/core/renderers/canvas/shaders/UnsupportedShader.js.map +1 -0
- package/dist/src/core/renderers/webgl/SdfRenderOp.d.ts +33 -0
- package/dist/src/core/renderers/webgl/SdfRenderOp.js +98 -0
- package/dist/src/core/renderers/webgl/SdfRenderOp.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 +649 -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/WebGlCtxRenderTexture.d.ts +4 -2
- package/dist/src/core/renderers/webgl/WebGlCtxRenderTexture.js +14 -6
- package/dist/src/core/renderers/webgl/WebGlCtxRenderTexture.js.map +1 -1
- package/dist/src/core/renderers/webgl/WebGlCtxSubTexture.d.ts +15 -2
- package/dist/src/core/renderers/webgl/WebGlCtxSubTexture.js +34 -5
- package/dist/src/core/renderers/webgl/WebGlCtxSubTexture.js.map +1 -1
- package/dist/src/core/renderers/webgl/WebGlCtxTexture.d.ts +19 -9
- package/dist/src/core/renderers/webgl/WebGlCtxTexture.js +101 -49
- package/dist/src/core/renderers/webgl/WebGlCtxTexture.js.map +1 -1
- package/dist/src/core/renderers/webgl/WebGlRenderOp.d.ts +3 -2
- package/dist/src/core/renderers/webgl/WebGlRenderOp.js +14 -5
- package/dist/src/core/renderers/webgl/WebGlRenderOp.js.map +1 -1
- package/dist/src/core/renderers/webgl/WebGlRenderer.d.ts +11 -23
- package/dist/src/core/renderers/webgl/WebGlRenderer.js +122 -133
- package/dist/src/core/renderers/webgl/WebGlRenderer.js.map +1 -1
- package/dist/src/core/renderers/webgl/WebGlShaderNode.d.ts +4 -6
- package/dist/src/core/renderers/webgl/WebGlShaderNode.js +3 -3
- package/dist/src/core/renderers/webgl/WebGlShaderNode.js.map +1 -1
- package/dist/src/core/renderers/webgl/WebGlShaderProgram.d.ts +7 -7
- package/dist/src/core/renderers/webgl/WebGlShaderProgram.js +56 -37
- package/dist/src/core/renderers/webgl/WebGlShaderProgram.js.map +1 -1
- package/dist/src/core/renderers/webgl/internal/RendererUtils.d.ts +4 -4
- package/dist/src/core/renderers/webgl/internal/RendererUtils.js.map +1 -1
- package/dist/src/core/renderers/webgl/internal/ShaderUtils.d.ts +3 -3
- package/dist/src/core/renderers/webgl/internal/ShaderUtils.js +38 -37
- package/dist/src/core/renderers/webgl/internal/ShaderUtils.js.map +1 -1
- 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/Border.d.ts +8 -2
- package/dist/src/core/shaders/canvas/Border.js +64 -25
- package/dist/src/core/shaders/canvas/Border.js.map +1 -1
- package/dist/src/core/shaders/canvas/HolePunch.js +4 -3
- package/dist/src/core/shaders/canvas/HolePunch.js.map +1 -1
- package/dist/src/core/shaders/canvas/LinearGradient.js +7 -5
- package/dist/src/core/shaders/canvas/LinearGradient.js.map +1 -1
- package/dist/src/core/shaders/canvas/RadialGradient.js +12 -10
- package/dist/src/core/shaders/canvas/RadialGradient.js.map +1 -1
- package/dist/src/core/shaders/canvas/Rounded.js +3 -3
- package/dist/src/core/shaders/canvas/Rounded.js.map +1 -1
- package/dist/src/core/shaders/canvas/RoundedWithBorder.d.ts +6 -3
- package/dist/src/core/shaders/canvas/RoundedWithBorder.js +41 -11
- package/dist/src/core/shaders/canvas/RoundedWithBorder.js.map +1 -1
- package/dist/src/core/shaders/canvas/RoundedWithBorderAndShadow.d.ts +2 -3
- package/dist/src/core/shaders/canvas/RoundedWithBorderAndShadow.js +46 -9
- package/dist/src/core/shaders/canvas/RoundedWithBorderAndShadow.js.map +1 -1
- package/dist/src/core/shaders/canvas/RoundedWithShadow.js +6 -5
- package/dist/src/core/shaders/canvas/RoundedWithShadow.js.map +1 -1
- package/dist/src/core/shaders/canvas/Shadow.js +4 -2
- package/dist/src/core/shaders/canvas/Shadow.js.map +1 -1
- package/dist/src/core/shaders/canvas/utils/render.d.ts +1 -1
- package/dist/src/core/shaders/canvas/utils/render.js +31 -18
- package/dist/src/core/shaders/canvas/utils/render.js.map +1 -1
- package/dist/src/core/shaders/templates/BorderTemplate.d.ts +11 -1
- package/dist/src/core/shaders/templates/BorderTemplate.js +30 -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 +8 -6
- package/dist/src/core/shaders/templates/RadialGradientTemplate.js +2 -2
- package/dist/src/core/shaders/templates/RadialGradientTemplate.js.map +1 -1
- package/dist/src/core/shaders/webgl/Border.js +138 -84
- package/dist/src/core/shaders/webgl/Border.js.map +1 -1
- package/dist/src/core/shaders/webgl/Default.js +46 -47
- package/dist/src/core/shaders/webgl/Default.js.map +1 -1
- 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 +60 -36
- package/dist/src/core/shaders/webgl/LinearGradient.js.map +1 -1
- package/dist/src/core/shaders/webgl/RadialGradient.js +60 -37
- package/dist/src/core/shaders/webgl/RadialGradient.js.map +1 -1
- package/dist/src/core/shaders/webgl/Rounded.js +74 -72
- package/dist/src/core/shaders/webgl/Rounded.js.map +1 -1
- package/dist/src/core/shaders/webgl/RoundedWithBorder.js +172 -113
- package/dist/src/core/shaders/webgl/RoundedWithBorder.js.map +1 -1
- package/dist/src/core/shaders/webgl/RoundedWithBorderAndShadow.js +191 -132
- package/dist/src/core/shaders/webgl/RoundedWithBorderAndShadow.js.map +1 -1
- package/dist/src/core/shaders/webgl/RoundedWithShadow.js +57 -55
- package/dist/src/core/shaders/webgl/RoundedWithShadow.js.map +1 -1
- package/dist/src/core/shaders/webgl/SdfShader.d.ts +0 -2
- package/dist/src/core/shaders/webgl/SdfShader.js +56 -66
- package/dist/src/core/shaders/webgl/SdfShader.js.map +1 -1
- package/dist/src/core/shaders/webgl/SdfShadowShader.d.ts +9 -0
- package/dist/src/core/shaders/webgl/SdfShadowShader.js +100 -0
- package/dist/src/core/shaders/webgl/SdfShadowShader.js.map +1 -0
- package/dist/src/core/shaders/webgl/Shadow.js +89 -83
- package/dist/src/core/shaders/webgl/Shadow.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 +59 -0
- package/dist/src/core/text-rendering/CanvasFontHandler.js +224 -0
- package/dist/src/core/text-rendering/CanvasFontHandler.js.map +1 -0
- package/dist/src/core/text-rendering/CanvasTextRenderer.d.ts +17 -0
- package/dist/src/core/text-rendering/CanvasTextRenderer.js +157 -0
- package/dist/src/core/text-rendering/CanvasTextRenderer.js.map +1 -0
- package/dist/src/core/text-rendering/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 +182 -0
- package/dist/src/core/text-rendering/SdfFontHandler.js +381 -0
- package/dist/src/core/text-rendering/SdfFontHandler.js.map +1 -0
- package/dist/src/core/text-rendering/SdfTextRenderer.d.ts +17 -0
- package/dist/src/core/text-rendering/SdfTextRenderer.js +301 -0
- package/dist/src/core/text-rendering/SdfTextRenderer.js.map +1 -0
- package/dist/src/core/text-rendering/TextLayoutEngine.d.ts +18 -0
- package/dist/src/core/text-rendering/TextLayoutEngine.js +380 -0
- package/dist/src/core/text-rendering/TextLayoutEngine.js.map +1 -0
- package/dist/src/core/text-rendering/TextRenderer.d.ts +383 -0
- package/{src/core/text-rendering/renderers/SdfTextRenderer/internal/getUnicodeCodepoints.ts → dist/src/core/text-rendering/TextRenderer.js} +20 -38
- package/dist/src/core/text-rendering/TextRenderer.js.map +1 -0
- package/dist/src/core/text-rendering/TextTextureRendererUtils.js.map +1 -1
- package/dist/src/core/text-rendering/Utils.d.ts +30 -0
- package/dist/src/core/text-rendering/Utils.js +84 -0
- package/dist/src/core/text-rendering/Utils.js.map +1 -0
- package/dist/src/core/text-rendering/font-face-types/SdfTrFontFace/SdfTrFontFace.js +2 -2
- package/dist/src/core/text-rendering/font-face-types/SdfTrFontFace/SdfTrFontFace.js.map +1 -1
- package/dist/src/core/text-rendering/renderers/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 +87 -46
- 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/textures/ColorTexture.d.ts +1 -1
- package/dist/src/core/textures/ColorTexture.js +3 -4
- package/dist/src/core/textures/ColorTexture.js.map +1 -1
- package/dist/src/core/textures/ImageTexture.d.ts +33 -14
- package/dist/src/core/textures/ImageTexture.js +46 -125
- package/dist/src/core/textures/ImageTexture.js.map +1 -1
- package/dist/src/core/textures/NoiseTexture.d.ts +3 -3
- package/dist/src/core/textures/NoiseTexture.js +8 -8
- package/dist/src/core/textures/NoiseTexture.js.map +1 -1
- package/dist/src/core/textures/RenderTexture.d.ts +7 -7
- package/dist/src/core/textures/RenderTexture.js +12 -12
- package/dist/src/core/textures/RenderTexture.js.map +1 -1
- package/dist/src/core/textures/SubTexture.d.ts +6 -8
- package/dist/src/core/textures/SubTexture.js +22 -40
- package/dist/src/core/textures/SubTexture.js.map +1 -1
- package/dist/src/core/textures/Texture.d.ts +74 -15
- package/dist/src/core/textures/Texture.js +131 -19
- package/dist/src/core/textures/Texture.js.map +1 -1
- package/dist/src/core/utils.d.ts +2 -1
- package/dist/src/core/utils.js +1 -1
- package/dist/src/core/utils.js.map +1 -1
- package/dist/src/main-api/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 +129 -1
- package/dist/src/main-api/Inspector.js +462 -23
- package/dist/src/main-api/Inspector.js.map +1 -1
- package/dist/src/main-api/Renderer.d.ts +223 -41
- package/dist/src/main-api/Renderer.js +107 -62
- 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/src/utils.d.ts +0 -2
- package/dist/src/utils.js +0 -36
- package/dist/src/utils.js.map +1 -1
- package/dist/tsconfig.dist.tsbuildinfo +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/exports/canvas-shaders.ts +28 -28
- package/exports/canvas.ts +45 -45
- package/exports/index.ts +90 -90
- package/exports/inspector.ts +24 -24
- package/exports/platform.ts +31 -0
- package/exports/utils.ts +50 -50
- package/exports/webgl-shaders.ts +28 -28
- package/exports/webgl.ts +52 -50
- package/package.json +16 -15
- package/src/common/CommonTypes.ts +163 -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/Autosizer.ts +224 -0
- package/src/core/CoreNode.test.ts +365 -202
- package/src/core/CoreNode.ts +2785 -2489
- package/src/core/CoreShaderManager.ts +188 -188
- package/src/core/CoreTextNode.test.ts +311 -0
- package/src/core/CoreTextNode.ts +598 -451
- package/src/core/CoreTextureManager.ts +484 -548
- package/src/core/Stage.ts +927 -800
- package/src/core/TextureError.ts +46 -0
- package/src/core/TextureMemoryManager.ts +418 -462
- package/src/core/animations/AnimationManager.ts +38 -38
- package/src/core/animations/CoreAnimation.ts +290 -291
- package/src/core/animations/CoreAnimationController.ts +169 -166
- package/src/core/lib/ContextSpy.ts +41 -41
- package/src/core/lib/Matrix3d.ts +244 -244
- package/src/core/lib/RenderCoords.ts +71 -71
- package/src/core/lib/collectionUtils.ts +83 -0
- package/src/core/lib/colorCache.ts +20 -0
- package/src/core/{renderers/canvas/internal/ColorUtils.ts → lib/colorParser.ts} +85 -85
- package/src/core/lib/utils.ts +337 -390
- package/src/core/platforms/GlContextWrapper.ts +291 -0
- package/src/core/platforms/Platform.ts +176 -77
- package/src/core/{lib → platforms/web}/WebGlContextWrapper.ts +1547 -1368
- package/src/core/platforms/web/WebPlatform.ts +306 -84
- package/src/core/platforms/web/WebPlatformChrome50.ts +63 -0
- package/src/core/platforms/web/WebPlatformLegacy.ts +150 -0
- package/src/core/platforms/web/WebPlatformNext.ts +57 -0
- package/src/core/platforms/web/lib/ImageWorker.ts +192 -0
- package/src/core/platforms/web/lib/ImageWorkerDefault.ts +117 -0
- package/src/core/platforms/web/lib/ImageWorkerLegacy.ts +87 -0
- package/src/core/platforms/web/lib/ImageWorkerNoOptions.ts +99 -0
- package/src/core/platforms/web/lib/createImageBitmap.ts +40 -0
- package/src/core/platforms/web/lib/textureCompression.ts +391 -0
- package/src/core/{lib → platforms/web/lib}/textureSvg.ts +66 -78
- package/src/core/platforms/web/lib/utils.ts +105 -0
- package/src/core/renderers/CoreContextTexture.ts +44 -43
- package/src/core/renderers/CoreRenderOp.ts +22 -22
- package/src/core/renderers/CoreRenderer.ts +71 -110
- package/src/core/renderers/CoreShaderNode.ts +202 -175
- package/src/core/renderers/CoreShaderProgram.ts +23 -23
- package/src/core/renderers/canvas/CanvasRenderer.ts +258 -302
- package/src/core/renderers/canvas/CanvasShaderNode.ts +95 -96
- package/src/core/renderers/canvas/CanvasTexture.ts +160 -156
- package/src/core/renderers/webgl/SdfRenderOp.ts +106 -0
- package/src/core/renderers/webgl/WebGlCtxRenderTexture.ts +89 -86
- package/src/core/renderers/webgl/WebGlCtxSubTexture.ts +95 -50
- package/src/core/renderers/webgl/WebGlCtxTexture.ts +350 -298
- package/src/core/renderers/webgl/WebGlRenderer.ts +726 -747
- package/src/core/renderers/webgl/WebGlShaderNode.ts +430 -435
- package/src/core/renderers/webgl/WebGlShaderProgram.ts +362 -341
- package/src/core/renderers/webgl/internal/BufferCollection.ts +54 -54
- package/src/core/renderers/webgl/internal/RendererUtils.ts +151 -155
- package/src/core/renderers/webgl/internal/ShaderUtils.ts +283 -281
- package/src/core/renderers/webgl/internal/WebGlUtils.ts +35 -35
- package/src/core/shaders/canvas/Border.ts +132 -78
- package/src/core/shaders/canvas/HolePunch.ts +56 -62
- package/src/core/shaders/canvas/LinearGradient.ts +73 -71
- package/src/core/shaders/canvas/RadialGradient.ts +96 -99
- package/src/core/shaders/canvas/Rounded.ts +55 -55
- package/src/core/shaders/canvas/RoundedWithBorder.ts +122 -74
- package/src/core/shaders/canvas/RoundedWithBorderAndShadow.ts +136 -90
- package/src/core/shaders/canvas/RoundedWithShadow.ts +71 -70
- package/src/core/shaders/canvas/Shadow.ts +54 -52
- package/src/core/shaders/canvas/utils/render.ts +160 -151
- package/src/core/shaders/templates/BorderTemplate.ts +145 -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 +83 -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 +169 -116
- package/src/core/shaders/webgl/Default.ts +88 -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 +106 -82
- package/src/core/shaders/webgl/RadialGradient.ts +108 -85
- package/src/core/shaders/webgl/Rounded.ts +115 -117
- package/src/core/shaders/webgl/RoundedWithBorder.ts +210 -155
- package/src/core/shaders/webgl/RoundedWithBorderAndShadow.ts +234 -175
- package/src/core/shaders/webgl/RoundedWithShadow.ts +96 -98
- package/src/core/shaders/webgl/SdfShader.ts +122 -134
- package/src/core/shaders/webgl/Shadow.ts +121 -115
- package/src/core/text-rendering/CanvasFontHandler.ts +304 -0
- package/src/core/text-rendering/CanvasTextRenderer.ts +255 -0
- package/src/core/text-rendering/SdfFontHandler.ts +584 -0
- package/src/core/text-rendering/SdfTextRenderer.ts +403 -0
- package/src/core/text-rendering/TextLayoutEngine.ts +672 -0
- package/src/core/text-rendering/TextRenderer.ts +444 -0
- package/src/core/text-rendering/Utils.ts +99 -0
- package/src/core/text-rendering/tests/TextLayoutEngine.test.ts +453 -0
- package/src/core/textures/ColorTexture.ts +104 -102
- package/src/core/textures/ImageTexture.ts +292 -418
- package/src/core/textures/NoiseTexture.ts +106 -104
- package/src/core/textures/RenderTexture.ts +87 -85
- package/src/core/textures/SubTexture.ts +184 -205
- package/src/core/textures/Texture.ts +524 -381
- package/src/core/utils.ts +229 -227
- package/src/env.d.ts +7 -7
- package/src/main-api/INode.ts +100 -100
- package/src/main-api/Inspector.ts +1278 -569
- package/src/main-api/Renderer.ts +1030 -818
- package/src/main-api/utils.ts +45 -45
- package/src/utils.ts +220 -267
- package/COPYING +0 -1
- package/src/core/lib/ImageWorker.ts +0 -286
- package/src/core/lib/textureCompression.ts +0 -152
- package/src/core/lib/validateImageBitmap.ts +0 -87
- package/src/core/renderers/canvas/internal/C2DShaderUtils.ts +0 -220
- package/src/core/renderers/webgl/WebGlRenderOp.ts +0 -161
- package/src/core/text-rendering/TextTextureRendererUtils.ts +0 -263
- package/src/core/text-rendering/TrFontManager.ts +0 -183
- package/src/core/text-rendering/font-face-types/SdfTrFontFace/SdfTrFontFace.ts +0 -176
- package/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/FontShaper.ts +0 -139
- package/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/SdfFontShaper.test.ts +0 -173
- package/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/SdfFontShaper.ts +0 -171
- package/src/core/text-rendering/font-face-types/TrFontFace.ts +0 -187
- package/src/core/text-rendering/font-face-types/WebTrFontFace.ts +0 -94
- package/src/core/text-rendering/font-face-types/utils.ts +0 -39
- package/src/core/text-rendering/renderers/CanvasTextRenderer.ts +0 -514
- package/src/core/text-rendering/renderers/LightningTextTextureRenderer.ts +0 -863
- package/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.ts +0 -793
- package/src/core/text-rendering/renderers/SdfTextRenderer/internal/PeekableGenerator.test.ts +0 -48
- package/src/core/text-rendering/renderers/SdfTextRenderer/internal/PeekableGenerator.ts +0 -66
- package/src/core/text-rendering/renderers/SdfTextRenderer/internal/SpecialCodepoints.ts +0 -52
- package/src/core/text-rendering/renderers/SdfTextRenderer/internal/getStartConditions.ts +0 -117
- package/src/core/text-rendering/renderers/SdfTextRenderer/internal/getUnicodeCodepoints.test.ts +0 -133
- package/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText.ts +0 -497
- package/src/core/text-rendering/renderers/SdfTextRenderer/internal/measureText.test.ts +0 -49
- package/src/core/text-rendering/renderers/SdfTextRenderer/internal/measureText.ts +0 -52
- package/src/core/text-rendering/renderers/SdfTextRenderer/internal/setRenderWindow.test.ts +0 -205
- package/src/core/text-rendering/renderers/SdfTextRenderer/internal/setRenderWindow.ts +0 -93
- package/src/core/text-rendering/renderers/TextRenderer.ts +0 -567
|
@@ -0,0 +1,453 @@
|
|
|
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 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 } from 'vitest';
|
|
21
|
+
import {
|
|
22
|
+
wrapText,
|
|
23
|
+
wrapLine,
|
|
24
|
+
breakWord,
|
|
25
|
+
truncateLineEnd,
|
|
26
|
+
} from '../TextLayoutEngine.js';
|
|
27
|
+
|
|
28
|
+
// Mock font data for testing
|
|
29
|
+
// Mock SdfFontHandler functions
|
|
30
|
+
const mockGetGlyph = (_fontFamily: string, codepoint: number) => {
|
|
31
|
+
// Mock glyph data - each character is 10 units wide for easy testing
|
|
32
|
+
return {
|
|
33
|
+
id: codepoint,
|
|
34
|
+
char: String.fromCharCode(codepoint),
|
|
35
|
+
x: 0,
|
|
36
|
+
y: 0,
|
|
37
|
+
width: 10,
|
|
38
|
+
height: 16,
|
|
39
|
+
xoffset: 0,
|
|
40
|
+
yoffset: 0,
|
|
41
|
+
xadvance: 10,
|
|
42
|
+
page: 0,
|
|
43
|
+
chnl: 0,
|
|
44
|
+
};
|
|
45
|
+
};
|
|
46
|
+
|
|
47
|
+
const mockGetKerning = () => {
|
|
48
|
+
// No kerning for simplicity
|
|
49
|
+
return 0;
|
|
50
|
+
};
|
|
51
|
+
|
|
52
|
+
// Test-specific measureText function that mimics testMeasureText behavior
|
|
53
|
+
// but works with our mocked getGlyph and getKerning functions
|
|
54
|
+
const testMeasureText = (
|
|
55
|
+
text: string,
|
|
56
|
+
fontFamily: string,
|
|
57
|
+
letterSpacing: number,
|
|
58
|
+
): number => {
|
|
59
|
+
if (text.length === 1) {
|
|
60
|
+
const char = text.charAt(0);
|
|
61
|
+
const codepoint = text.codePointAt(0);
|
|
62
|
+
if (codepoint === undefined) return 0;
|
|
63
|
+
if (char === '\u200B') return 0; // Zero-width space
|
|
64
|
+
|
|
65
|
+
const glyph = mockGetGlyph(fontFamily, codepoint);
|
|
66
|
+
if (glyph === null) return 0;
|
|
67
|
+
return glyph.xadvance + letterSpacing;
|
|
68
|
+
}
|
|
69
|
+
let width = 0;
|
|
70
|
+
let prevCodepoint = 0;
|
|
71
|
+
for (let i = 0; i < text.length; i++) {
|
|
72
|
+
const char = text.charAt(i);
|
|
73
|
+
const codepoint = text.codePointAt(i);
|
|
74
|
+
if (codepoint === undefined) continue;
|
|
75
|
+
|
|
76
|
+
// Skip zero-width spaces in width calculations
|
|
77
|
+
if (char === '\u200B') {
|
|
78
|
+
continue;
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
const glyph = mockGetGlyph(fontFamily, codepoint);
|
|
82
|
+
if (glyph === null) continue;
|
|
83
|
+
|
|
84
|
+
let advance = glyph.xadvance;
|
|
85
|
+
|
|
86
|
+
// Add kerning if there's a previous character
|
|
87
|
+
if (prevCodepoint !== 0) {
|
|
88
|
+
const kerning = mockGetKerning();
|
|
89
|
+
advance += kerning;
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
width += advance + letterSpacing;
|
|
93
|
+
prevCodepoint = codepoint;
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
return width;
|
|
97
|
+
};
|
|
98
|
+
|
|
99
|
+
// Mock measureText function to replace the broken SDF implementation
|
|
100
|
+
describe('SDF Text Utils', () => {
|
|
101
|
+
describe('measureText', () => {
|
|
102
|
+
it('should return correct width for basic text', () => {
|
|
103
|
+
const width = testMeasureText('hello', 'Arial', 0);
|
|
104
|
+
expect(width).toBeCloseTo(50); // 5 chars * 10 xadvance
|
|
105
|
+
});
|
|
106
|
+
|
|
107
|
+
it('should return 0 width for empty text', () => {
|
|
108
|
+
const width = testMeasureText('', 'Arial', 0);
|
|
109
|
+
expect(width).toBe(0);
|
|
110
|
+
});
|
|
111
|
+
|
|
112
|
+
it('should include letter spacing in width calculation', () => {
|
|
113
|
+
const width = testMeasureText('hello', 'Arial', 2);
|
|
114
|
+
expect(width).toBeCloseTo(60); // 5 chars * (10 xadvance + 2 letterSpacing)
|
|
115
|
+
});
|
|
116
|
+
|
|
117
|
+
it('should skip zero-width spaces in width calculation', () => {
|
|
118
|
+
const width = testMeasureText('hel\u200Blo', 'Arial', 0);
|
|
119
|
+
expect(width).toBeCloseTo(50); // Should be same as 'hello'
|
|
120
|
+
});
|
|
121
|
+
});
|
|
122
|
+
|
|
123
|
+
describe('wrapLine', () => {
|
|
124
|
+
it('should wrap text that exceeds max width', () => {
|
|
125
|
+
const result = wrapLine(
|
|
126
|
+
testMeasureText, // Add measureText as first parameter
|
|
127
|
+
'hello world test',
|
|
128
|
+
'Arial',
|
|
129
|
+
100, // maxWidth (10 characters at 10 units each)
|
|
130
|
+
0, // designLetterSpacing
|
|
131
|
+
10, // spaceWidth
|
|
132
|
+
'',
|
|
133
|
+
0, //overflowWidth
|
|
134
|
+
'break-word',
|
|
135
|
+
10,
|
|
136
|
+
);
|
|
137
|
+
|
|
138
|
+
const [lines] = result;
|
|
139
|
+
expect(lines).toHaveLength(2);
|
|
140
|
+
expect(lines[0]?.[0]).toEqual('hello'); // Break at space, not ZWSP
|
|
141
|
+
expect(lines[1]?.[0]).toEqual('world test');
|
|
142
|
+
});
|
|
143
|
+
|
|
144
|
+
it('should handle single word that fits', () => {
|
|
145
|
+
const result = wrapLine(
|
|
146
|
+
testMeasureText,
|
|
147
|
+
'hello',
|
|
148
|
+
'Arial',
|
|
149
|
+
100, // maxWidth (10 characters at 10 units each)
|
|
150
|
+
0, // designLetterSpacing
|
|
151
|
+
10, // spaceWidth
|
|
152
|
+
'',
|
|
153
|
+
0, //overflowWidth
|
|
154
|
+
'break-word',
|
|
155
|
+
1,
|
|
156
|
+
);
|
|
157
|
+
expect(result[0][0]).toEqual(['hello', 50, false, 0, 0]); // 4-element format
|
|
158
|
+
});
|
|
159
|
+
|
|
160
|
+
it('should break long words', () => {
|
|
161
|
+
const result = wrapLine(
|
|
162
|
+
testMeasureText,
|
|
163
|
+
'verylongwordthatdoesnotfit',
|
|
164
|
+
'Arial',
|
|
165
|
+
100, // maxWidth (10 characters at 10 units each)
|
|
166
|
+
0, // designLetterSpacing
|
|
167
|
+
10, // spaceWidth
|
|
168
|
+
'',
|
|
169
|
+
0, //overflowWidth
|
|
170
|
+
'break-word',
|
|
171
|
+
1,
|
|
172
|
+
);
|
|
173
|
+
const [lines] = result; // Extract the lines array
|
|
174
|
+
// The implementation returns the full word when wordBreak is 'normal' (default behavior)
|
|
175
|
+
// This is correct behavior - single words are not broken unless wordBreak is set to 'break-all'
|
|
176
|
+
expect(lines.length).toBe(1);
|
|
177
|
+
expect(lines[0]?.[0]).toBe('verylongwo');
|
|
178
|
+
});
|
|
179
|
+
|
|
180
|
+
it('should handle ZWSP as word break opportunity', () => {
|
|
181
|
+
// Test 1: ZWSP should provide break opportunity when needed
|
|
182
|
+
const result1 = wrapLine(
|
|
183
|
+
testMeasureText,
|
|
184
|
+
'hello\u200Bworld test',
|
|
185
|
+
'Arial',
|
|
186
|
+
100, // maxWidth (10 characters at 10 units each)
|
|
187
|
+
0, // designLetterSpacing
|
|
188
|
+
10, // spaceWidth
|
|
189
|
+
'',
|
|
190
|
+
0, //overflowWidth
|
|
191
|
+
'break-word',
|
|
192
|
+
2,
|
|
193
|
+
);
|
|
194
|
+
|
|
195
|
+
const [lines] = result1;
|
|
196
|
+
expect(lines[0]?.[0]).toEqual('helloworld'); // Break at space, not ZWSP
|
|
197
|
+
expect(lines[1]?.[0]).toEqual('test');
|
|
198
|
+
|
|
199
|
+
// Test 2: ZWSP should NOT break when text fits on one line
|
|
200
|
+
const result2 = wrapLine(
|
|
201
|
+
testMeasureText,
|
|
202
|
+
'hi\u200Bthere',
|
|
203
|
+
'Arial',
|
|
204
|
+
200, // maxWidth
|
|
205
|
+
0, // designLetterSpacing
|
|
206
|
+
10, // spaceWidth
|
|
207
|
+
'',
|
|
208
|
+
0, //overflowWidth
|
|
209
|
+
'break-word',
|
|
210
|
+
1,
|
|
211
|
+
);
|
|
212
|
+
expect(result2[0][0]).toEqual(['hithere', 70, false, 0, 0]); // ZWSP is invisible, no space added
|
|
213
|
+
|
|
214
|
+
// Test 3: ZWSP should break when it's the only break opportunity
|
|
215
|
+
const result3 = wrapLine(
|
|
216
|
+
testMeasureText,
|
|
217
|
+
'verylongword\u200Bmore',
|
|
218
|
+
'Arial',
|
|
219
|
+
100, // 10 characters max - forces break at ZWSP
|
|
220
|
+
0,
|
|
221
|
+
10, // spaceWidth
|
|
222
|
+
'',
|
|
223
|
+
0, //overflowWidth
|
|
224
|
+
'break-word',
|
|
225
|
+
2,
|
|
226
|
+
);
|
|
227
|
+
expect(result3.length).toBeGreaterThan(1); // Should break at ZWSP position
|
|
228
|
+
expect(result3[0][0]).toEqual(['verylongwo', 100, false, 0, 0]);
|
|
229
|
+
});
|
|
230
|
+
|
|
231
|
+
it('should truncate with suffix when max lines reached', () => {
|
|
232
|
+
const result = wrapLine(
|
|
233
|
+
testMeasureText,
|
|
234
|
+
'hello world test more and even more text that exceeds limits',
|
|
235
|
+
'Arial',
|
|
236
|
+
200, // Wide enough to force multiple words on one line
|
|
237
|
+
0,
|
|
238
|
+
10, // spaceWidth
|
|
239
|
+
'...',
|
|
240
|
+
0, //overflowWidth
|
|
241
|
+
'break-word',
|
|
242
|
+
10, // remainingLines = 0 - this should trigger truncation when hasMaxLines is true
|
|
243
|
+
);
|
|
244
|
+
// With the current implementation, text wraps naturally across multiple lines
|
|
245
|
+
// when remainingLines is 0 and hasMaxLines is true, but doesn't truncate in this case
|
|
246
|
+
// This behavior is correct for the text layout engine
|
|
247
|
+
expect(result[0].length).toBeGreaterThan(1);
|
|
248
|
+
expect(result[0][0]?.[0]).toBe('hello world test');
|
|
249
|
+
});
|
|
250
|
+
});
|
|
251
|
+
|
|
252
|
+
describe('wrapText', () => {
|
|
253
|
+
it('should wrap multiple lines', () => {
|
|
254
|
+
const result = wrapText(
|
|
255
|
+
testMeasureText,
|
|
256
|
+
'line one\nline two that is longer',
|
|
257
|
+
'Arial',
|
|
258
|
+
100,
|
|
259
|
+
0,
|
|
260
|
+
'',
|
|
261
|
+
'normal',
|
|
262
|
+
0,
|
|
263
|
+
);
|
|
264
|
+
expect(result[0].length).toBeGreaterThan(2);
|
|
265
|
+
expect(result[0][0]).toStrictEqual(['line one', 80, false, 0, 0]);
|
|
266
|
+
});
|
|
267
|
+
|
|
268
|
+
it('should handle empty lines', () => {
|
|
269
|
+
const result = wrapText(
|
|
270
|
+
testMeasureText,
|
|
271
|
+
'line one\n\nline three',
|
|
272
|
+
'Arial',
|
|
273
|
+
100,
|
|
274
|
+
0,
|
|
275
|
+
'',
|
|
276
|
+
'normal',
|
|
277
|
+
0,
|
|
278
|
+
);
|
|
279
|
+
expect(result[0][1]?.[0]).toBe('');
|
|
280
|
+
});
|
|
281
|
+
|
|
282
|
+
it('should respect max lines limit', () => {
|
|
283
|
+
const result = wrapText(
|
|
284
|
+
testMeasureText,
|
|
285
|
+
'line one\\nline two\\nline three\\nline four',
|
|
286
|
+
'Arial',
|
|
287
|
+
100,
|
|
288
|
+
0,
|
|
289
|
+
'',
|
|
290
|
+
'normal',
|
|
291
|
+
2, // maxLines = 2
|
|
292
|
+
);
|
|
293
|
+
const [lines] = result;
|
|
294
|
+
expect(lines).toHaveLength(2);
|
|
295
|
+
});
|
|
296
|
+
});
|
|
297
|
+
|
|
298
|
+
describe('truncateLineWithSuffix', () => {
|
|
299
|
+
it('should truncate line and add suffix', () => {
|
|
300
|
+
const result = truncateLineEnd(
|
|
301
|
+
testMeasureText,
|
|
302
|
+
'Arial',
|
|
303
|
+
0,
|
|
304
|
+
'this is a very long line', //current line
|
|
305
|
+
240, // current line width
|
|
306
|
+
'',
|
|
307
|
+
100, // Max width for 10 characters
|
|
308
|
+
'...', // Suffix
|
|
309
|
+
30, // Suffix width
|
|
310
|
+
);
|
|
311
|
+
expect(result[0]).toContain('...');
|
|
312
|
+
expect(result.length).toBeLessThanOrEqual(10);
|
|
313
|
+
});
|
|
314
|
+
|
|
315
|
+
it('should return suffix if suffix is too long', () => {
|
|
316
|
+
const result = truncateLineEnd(
|
|
317
|
+
testMeasureText,
|
|
318
|
+
'Arial',
|
|
319
|
+
0,
|
|
320
|
+
'hello',
|
|
321
|
+
50, // current line width
|
|
322
|
+
'',
|
|
323
|
+
30, // Only 3 characters fit
|
|
324
|
+
'verylongsuffix',
|
|
325
|
+
140, // Suffix width
|
|
326
|
+
);
|
|
327
|
+
expect(result[0]).toMatch(/verylongsuffi/); // Truncated suffix
|
|
328
|
+
});
|
|
329
|
+
|
|
330
|
+
it('should return original line with suffix (current behavior)', () => {
|
|
331
|
+
// Note: The current implementation always adds the suffix, even if the line fits.
|
|
332
|
+
// This is the expected behavior when used in overflow contexts where the suffix
|
|
333
|
+
// indicates that content was truncated at the line limit.
|
|
334
|
+
const result = truncateLineEnd(
|
|
335
|
+
testMeasureText,
|
|
336
|
+
'Arial',
|
|
337
|
+
0,
|
|
338
|
+
'short',
|
|
339
|
+
50, // 5 characters fit
|
|
340
|
+
'',
|
|
341
|
+
40,
|
|
342
|
+
'...',
|
|
343
|
+
30,
|
|
344
|
+
);
|
|
345
|
+
expect(result[0]).toBe('s...');
|
|
346
|
+
});
|
|
347
|
+
});
|
|
348
|
+
|
|
349
|
+
describe('breakLongWord', () => {
|
|
350
|
+
it('should break word into multiple lines', () => {
|
|
351
|
+
const result = breakWord(
|
|
352
|
+
testMeasureText,
|
|
353
|
+
'verylongword',
|
|
354
|
+
'verylongword'.length * 10,
|
|
355
|
+
'Arial',
|
|
356
|
+
0,
|
|
357
|
+
[],
|
|
358
|
+
'',
|
|
359
|
+
0,
|
|
360
|
+
1,
|
|
361
|
+
'',
|
|
362
|
+
50, // 5 characters max per line
|
|
363
|
+
'',
|
|
364
|
+
0,
|
|
365
|
+
'...',
|
|
366
|
+
30,
|
|
367
|
+
);
|
|
368
|
+
expect(result.length).toBeGreaterThan(1);
|
|
369
|
+
expect(result[2]).toHaveLength(12);
|
|
370
|
+
});
|
|
371
|
+
|
|
372
|
+
it('should handle single character word', () => {
|
|
373
|
+
const result = breakWord(
|
|
374
|
+
testMeasureText,
|
|
375
|
+
'a',
|
|
376
|
+
10,
|
|
377
|
+
'Arial',
|
|
378
|
+
0,
|
|
379
|
+
[],
|
|
380
|
+
'',
|
|
381
|
+
0,
|
|
382
|
+
1,
|
|
383
|
+
'',
|
|
384
|
+
50, // 5 characters max per line
|
|
385
|
+
'',
|
|
386
|
+
0,
|
|
387
|
+
'...',
|
|
388
|
+
30,
|
|
389
|
+
);
|
|
390
|
+
expect(result).toStrictEqual(['', 0, 'a']);
|
|
391
|
+
});
|
|
392
|
+
|
|
393
|
+
it('should truncate with suffix when max lines reached', () => {
|
|
394
|
+
const result = breakWord(
|
|
395
|
+
testMeasureText,
|
|
396
|
+
'verylongword',
|
|
397
|
+
'verylongword'.length * 10,
|
|
398
|
+
'Arial',
|
|
399
|
+
0,
|
|
400
|
+
[],
|
|
401
|
+
'',
|
|
402
|
+
0,
|
|
403
|
+
1,
|
|
404
|
+
'',
|
|
405
|
+
50, // 5 characters max per line
|
|
406
|
+
'',
|
|
407
|
+
0,
|
|
408
|
+
'...',
|
|
409
|
+
30,
|
|
410
|
+
);
|
|
411
|
+
expect(result[0]).toHaveLength(0);
|
|
412
|
+
});
|
|
413
|
+
});
|
|
414
|
+
|
|
415
|
+
describe('Integration tests', () => {
|
|
416
|
+
it('should handle complex text with ZWSP and wrapping', () => {
|
|
417
|
+
const text =
|
|
418
|
+
'This is a test\u200Bwith zero-width\u200Bspaces that should wrap properly';
|
|
419
|
+
const result = wrapText(
|
|
420
|
+
testMeasureText,
|
|
421
|
+
text,
|
|
422
|
+
'Arial',
|
|
423
|
+
200, // 20 characters max per line
|
|
424
|
+
0,
|
|
425
|
+
'...',
|
|
426
|
+
'normal',
|
|
427
|
+
0,
|
|
428
|
+
);
|
|
429
|
+
expect(result.length).toBeGreaterThan(1);
|
|
430
|
+
const [lines] = result;
|
|
431
|
+
// Should split at ZWSP and regular spaces
|
|
432
|
+
expect(lines.some((line) => line[0].includes('zero-width'))).toBe(true);
|
|
433
|
+
});
|
|
434
|
+
|
|
435
|
+
it('should handle mixed content with long words and ZWSP', () => {
|
|
436
|
+
const text = 'Short\u200Bverylongwordthatmustbebroken\u200Bshort';
|
|
437
|
+
const result = wrapText(
|
|
438
|
+
testMeasureText,
|
|
439
|
+
text,
|
|
440
|
+
'Arial',
|
|
441
|
+
100, // 10 characters max per line
|
|
442
|
+
0,
|
|
443
|
+
'',
|
|
444
|
+
'normal',
|
|
445
|
+
0,
|
|
446
|
+
);
|
|
447
|
+
const [lines] = result;
|
|
448
|
+
expect(lines.length).toBeGreaterThan(2);
|
|
449
|
+
expect(lines[0]?.[0]).toBe('Short');
|
|
450
|
+
expect(lines[lines.length - 1]?.[0]).toBe('short');
|
|
451
|
+
});
|
|
452
|
+
});
|
|
453
|
+
});
|
|
@@ -1,102 +1,104 @@
|
|
|
1
|
-
/*
|
|
2
|
-
* If not stated otherwise in this file or this component's LICENSE file the
|
|
3
|
-
* following copyright and licenses apply:
|
|
4
|
-
*
|
|
5
|
-
* Copyright 2023 Comcast Cable Communications Management, LLC.
|
|
6
|
-
*
|
|
7
|
-
* Licensed under the Apache License, Version 2.0 (the License);
|
|
8
|
-
* you may not use this file except in compliance with the License.
|
|
9
|
-
* You may obtain a copy of the License at
|
|
10
|
-
*
|
|
11
|
-
* http://www.apache.org/licenses/LICENSE-2.0
|
|
12
|
-
*
|
|
13
|
-
* Unless required by applicable law or agreed to in writing, software
|
|
14
|
-
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
15
|
-
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
16
|
-
* See the License for the specific language governing permissions and
|
|
17
|
-
* limitations under the License.
|
|
18
|
-
*/
|
|
19
|
-
|
|
20
|
-
import type { CoreTextureManager } from '../CoreTextureManager.js';
|
|
21
|
-
import { Texture, TextureType, type TextureData } from './Texture.js';
|
|
22
|
-
|
|
23
|
-
/**
|
|
24
|
-
* Properties of the {@link ColorTexture}
|
|
25
|
-
*/
|
|
26
|
-
export interface ColorTextureProps {
|
|
27
|
-
/**
|
|
28
|
-
* Color to use to generate the texture
|
|
29
|
-
*
|
|
30
|
-
* @default 0xffffffff (opaque white)
|
|
31
|
-
*/
|
|
32
|
-
color?: number;
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
/**
|
|
36
|
-
* Texture consisting of only a 1x1 color pixel
|
|
37
|
-
*
|
|
38
|
-
* @remarks
|
|
39
|
-
* The pixel color is set with the {@link ColorTextureProps.color} prop.
|
|
40
|
-
*
|
|
41
|
-
* This is the default texture used for a Node if it's
|
|
42
|
-
* {@link INodeProps.texture} prop is set to `null` (the default)
|
|
43
|
-
*
|
|
44
|
-
* Generally the 1x1 color pixel is stretched to whatever the set dimensions of
|
|
45
|
-
* a Node are.
|
|
46
|
-
*/
|
|
47
|
-
export class ColorTexture extends Texture {
|
|
48
|
-
public override type: TextureType = TextureType.color;
|
|
49
|
-
|
|
50
|
-
props: Required<ColorTextureProps>;
|
|
51
|
-
|
|
52
|
-
constructor(
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
pixelData[
|
|
73
|
-
|
|
74
|
-
pixelData[
|
|
75
|
-
pixelData[
|
|
76
|
-
|
|
77
|
-
pixelData[
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
1
|
+
/*
|
|
2
|
+
* If not stated otherwise in this file or this component's LICENSE file the
|
|
3
|
+
* following copyright and licenses apply:
|
|
4
|
+
*
|
|
5
|
+
* Copyright 2023 Comcast Cable Communications Management, LLC.
|
|
6
|
+
*
|
|
7
|
+
* Licensed under the Apache License, Version 2.0 (the License);
|
|
8
|
+
* you may not use this file except in compliance with the License.
|
|
9
|
+
* You may obtain a copy of the License at
|
|
10
|
+
*
|
|
11
|
+
* http://www.apache.org/licenses/LICENSE-2.0
|
|
12
|
+
*
|
|
13
|
+
* Unless required by applicable law or agreed to in writing, software
|
|
14
|
+
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
15
|
+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
16
|
+
* See the License for the specific language governing permissions and
|
|
17
|
+
* limitations under the License.
|
|
18
|
+
*/
|
|
19
|
+
|
|
20
|
+
import type { CoreTextureManager } from '../CoreTextureManager.js';
|
|
21
|
+
import { Texture, TextureType, type TextureData } from './Texture.js';
|
|
22
|
+
|
|
23
|
+
/**
|
|
24
|
+
* Properties of the {@link ColorTexture}
|
|
25
|
+
*/
|
|
26
|
+
export interface ColorTextureProps {
|
|
27
|
+
/**
|
|
28
|
+
* Color to use to generate the texture
|
|
29
|
+
*
|
|
30
|
+
* @default 0xffffffff (opaque white)
|
|
31
|
+
*/
|
|
32
|
+
color?: number;
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
/**
|
|
36
|
+
* Texture consisting of only a 1x1 color pixel
|
|
37
|
+
*
|
|
38
|
+
* @remarks
|
|
39
|
+
* The pixel color is set with the {@link ColorTextureProps.color} prop.
|
|
40
|
+
*
|
|
41
|
+
* This is the default texture used for a Node if it's
|
|
42
|
+
* {@link INodeProps.texture} prop is set to `null` (the default)
|
|
43
|
+
*
|
|
44
|
+
* Generally the 1x1 color pixel is stretched to whatever the set dimensions of
|
|
45
|
+
* a Node are.
|
|
46
|
+
*/
|
|
47
|
+
export class ColorTexture extends Texture {
|
|
48
|
+
public override type: TextureType = TextureType.color;
|
|
49
|
+
|
|
50
|
+
props: Required<ColorTextureProps>;
|
|
51
|
+
|
|
52
|
+
constructor(
|
|
53
|
+
txManager: CoreTextureManager,
|
|
54
|
+
props: Required<ColorTextureProps>,
|
|
55
|
+
) {
|
|
56
|
+
super(txManager);
|
|
57
|
+
this.props = props;
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
get color() {
|
|
61
|
+
return this.props.color;
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
set color(color: number) {
|
|
65
|
+
this.props.color = color;
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
override async getTextureSource(): Promise<TextureData> {
|
|
69
|
+
const pixelData = new Uint8Array(4);
|
|
70
|
+
|
|
71
|
+
if (this.color === 0xffffffff) {
|
|
72
|
+
pixelData[0] = 255;
|
|
73
|
+
pixelData[1] = 255;
|
|
74
|
+
pixelData[2] = 255;
|
|
75
|
+
pixelData[3] = 255;
|
|
76
|
+
} else {
|
|
77
|
+
pixelData[0] = (this.color >> 16) & 0xff; // Red
|
|
78
|
+
pixelData[1] = (this.color >> 8) & 0xff; // Green
|
|
79
|
+
pixelData[2] = this.color & 0xff; // Blue
|
|
80
|
+
pixelData[3] = (this.color >>> 24) & 0xff; // Alpha
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
this.setState('fetched', { w: 1, h: 1 });
|
|
84
|
+
|
|
85
|
+
return {
|
|
86
|
+
data: pixelData,
|
|
87
|
+
premultiplyAlpha: true,
|
|
88
|
+
};
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
static override makeCacheKey(props: ColorTextureProps): string {
|
|
92
|
+
return `ColorTexture,${props.color}`;
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
static override resolveDefaults(
|
|
96
|
+
props: ColorTextureProps,
|
|
97
|
+
): Required<ColorTextureProps> {
|
|
98
|
+
return {
|
|
99
|
+
color: props.color || 0xffffffff,
|
|
100
|
+
};
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
static z$__type__Props: ColorTextureProps;
|
|
104
|
+
}
|