@lightningjs/renderer 3.0.0-beta8 → 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 +530 -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 +23 -26
- package/dist/src/core/CoreTextureManager.js +60 -166
- 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 +3 -5
- package/dist/src/core/TextureMemoryManager.js +84 -94
- 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 +8 -5
- 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 +41 -3
- package/dist/src/core/lib/WebGlContextWrapper.js +105 -28
- 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 +11 -9
- package/dist/src/core/renderers/webgl/WebGlShaderProgram.js +83 -46
- 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 -11
- package/dist/src/core/textures/Texture.js +136 -18
- 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 -2483
- 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 -608
- package/src/core/Stage.ts +927 -800
- package/src/core/TextureError.ts +46 -0
- package/src/core/TextureMemoryManager.ts +418 -435
- package/src/core/animations/AnimationManager.ts +38 -38
- package/src/core/animations/CoreAnimation.ts +290 -291
- package/src/core/animations/CoreAnimationController.ts +169 -164
- 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 -1374
- 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 -318
- 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 -372
- 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,391 @@
|
|
|
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
|
+
import { type CompressedData } from '../../../textures/Texture.js';
|
|
20
|
+
import type { ImageResponse } from '../../../textures/ImageTexture.js';
|
|
21
|
+
import type { WebGlContextWrapper } from '../WebGlContextWrapper.js';
|
|
22
|
+
|
|
23
|
+
export type UploadCompressedTextureFunction = (
|
|
24
|
+
glw: WebGlContextWrapper,
|
|
25
|
+
texture: WebGLTexture,
|
|
26
|
+
data: CompressedData,
|
|
27
|
+
) => void;
|
|
28
|
+
|
|
29
|
+
const PVR_MAGIC = 0x03525650; // 'PVR3' in little-endian
|
|
30
|
+
const PVR_TO_GL_INTERNAL_FORMAT: Record<string, number> = {
|
|
31
|
+
0: 0x8c01,
|
|
32
|
+
1: 0x8c03,
|
|
33
|
+
2: 0x8c00,
|
|
34
|
+
3: 0x8c02, // PVRTC1
|
|
35
|
+
6: 0x8d64, // ETC1
|
|
36
|
+
7: 0x83f0,
|
|
37
|
+
8: 0x83f2,
|
|
38
|
+
9: 0x83f2,
|
|
39
|
+
10: 0x83f3,
|
|
40
|
+
11: 0x83f3, // DXT variants
|
|
41
|
+
};
|
|
42
|
+
const ASTC_MAGIC = 0x5ca1ab13;
|
|
43
|
+
|
|
44
|
+
const ASTC_TO_GL_INTERNAL_FORMAT: Record<string, number> = {
|
|
45
|
+
'4x4': 0x93b0, // COMPRESSED_RGBA_ASTC_4x4_KHR
|
|
46
|
+
'5x5': 0x93b1, // COMPRESSED_RGBA_ASTC_5x5_KHR
|
|
47
|
+
'6x6': 0x93b2, // COMPRESSED_RGBA_ASTC_6x6_KHR
|
|
48
|
+
'8x8': 0x93b3, // COMPRESSED_RGBA_ASTC_8x8_KHR
|
|
49
|
+
'10x10': 0x93b4, // COMPRESSED_RGBA_ASTC_10x10_KHR
|
|
50
|
+
'12x12': 0x93b5, // COMPRESSED_RGBA_ASTC_12x12_KHR
|
|
51
|
+
};
|
|
52
|
+
|
|
53
|
+
// KTX file identifier
|
|
54
|
+
const KTX_IDENTIFIER = [
|
|
55
|
+
0xab, 0x4b, 0x54, 0x58, 0x20, 0x31, 0x31, 0xbb, 0x0d, 0x0a, 0x1a, 0x0a,
|
|
56
|
+
];
|
|
57
|
+
/**
|
|
58
|
+
* Loads a compressed texture container
|
|
59
|
+
* @param url
|
|
60
|
+
* @returns
|
|
61
|
+
*/
|
|
62
|
+
export const loadCompressedTexture = async (
|
|
63
|
+
url: string,
|
|
64
|
+
): Promise<ImageResponse> => {
|
|
65
|
+
try {
|
|
66
|
+
const response = await fetch(url);
|
|
67
|
+
if (!response.ok) {
|
|
68
|
+
throw new Error(
|
|
69
|
+
`Failed to fetch compressed texture: ${response.status} ${response.statusText}`,
|
|
70
|
+
);
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
const arrayBuffer = await response.arrayBuffer();
|
|
74
|
+
|
|
75
|
+
// Ensure we have enough data to check magic numbers
|
|
76
|
+
if (arrayBuffer.byteLength < 16) {
|
|
77
|
+
throw new Error(
|
|
78
|
+
`File too small to be a valid compressed texture (${arrayBuffer.byteLength} bytes). Expected at least 16 bytes for header inspection.`,
|
|
79
|
+
);
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
const view = new DataView(arrayBuffer);
|
|
83
|
+
const magic = view.getUint32(0, true);
|
|
84
|
+
|
|
85
|
+
if (magic === PVR_MAGIC) {
|
|
86
|
+
return loadPVR(view);
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
if (magic === ASTC_MAGIC) {
|
|
90
|
+
return loadASTC(view);
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
let isKTX = true;
|
|
94
|
+
|
|
95
|
+
for (let i = 0; i < KTX_IDENTIFIER.length; i++) {
|
|
96
|
+
if (view.getUint8(i) !== KTX_IDENTIFIER[i]) {
|
|
97
|
+
isKTX = false;
|
|
98
|
+
break;
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
if (isKTX === true) {
|
|
103
|
+
return loadKTX(view);
|
|
104
|
+
} else {
|
|
105
|
+
throw new Error('Unrecognized compressed texture format');
|
|
106
|
+
}
|
|
107
|
+
} catch (error) {
|
|
108
|
+
throw new Error(`Failed to load compressed texture from ${url}: ${error}`);
|
|
109
|
+
}
|
|
110
|
+
};
|
|
111
|
+
|
|
112
|
+
function readUint24(view: DataView, offset: number) {
|
|
113
|
+
return (
|
|
114
|
+
view.getUint8(offset) +
|
|
115
|
+
(view.getUint8(offset + 1) << 8) +
|
|
116
|
+
(view.getUint8(offset + 2) << 16)
|
|
117
|
+
);
|
|
118
|
+
}
|
|
119
|
+
|
|
120
|
+
/**
|
|
121
|
+
* Loads an ASTC texture container and returns the texture data
|
|
122
|
+
* @param view
|
|
123
|
+
* @returns
|
|
124
|
+
*/
|
|
125
|
+
const loadASTC = async function (view: DataView): Promise<ImageResponse> {
|
|
126
|
+
const blockX = view.getUint8(4);
|
|
127
|
+
const blockY = view.getUint8(5);
|
|
128
|
+
const sizeX = readUint24(view, 7);
|
|
129
|
+
const sizeY = readUint24(view, 10);
|
|
130
|
+
|
|
131
|
+
if (sizeX === 0 || sizeY === 0) {
|
|
132
|
+
throw new Error(`Invalid ASTC texture dimensions: ${sizeX}x${sizeY}`);
|
|
133
|
+
}
|
|
134
|
+
const expected = Math.ceil(sizeX / blockX) * Math.ceil(sizeY / blockY) * 16;
|
|
135
|
+
const dataSize = view.byteLength - 16;
|
|
136
|
+
if (expected !== dataSize) {
|
|
137
|
+
throw new Error(
|
|
138
|
+
`Invalid ASTC texture data size: expected ${expected}, got ${dataSize}`,
|
|
139
|
+
);
|
|
140
|
+
}
|
|
141
|
+
|
|
142
|
+
const internalFormat = ASTC_TO_GL_INTERNAL_FORMAT[`${blockX}x${blockY}`];
|
|
143
|
+
if (internalFormat === undefined) {
|
|
144
|
+
throw new Error(`Unsupported ASTC block size: ${blockX}x${blockY}`);
|
|
145
|
+
}
|
|
146
|
+
|
|
147
|
+
const buffer = view.buffer as ArrayBuffer;
|
|
148
|
+
|
|
149
|
+
const mipmaps: ArrayBuffer[] = [];
|
|
150
|
+
mipmaps.push(buffer.slice(16));
|
|
151
|
+
|
|
152
|
+
return {
|
|
153
|
+
data: {
|
|
154
|
+
blockInfo: blockInfoMap[internalFormat]!,
|
|
155
|
+
glInternalFormat: internalFormat,
|
|
156
|
+
mipmaps,
|
|
157
|
+
w: sizeX,
|
|
158
|
+
h: sizeY,
|
|
159
|
+
type: 'ASTC',
|
|
160
|
+
},
|
|
161
|
+
premultiplyAlpha: false,
|
|
162
|
+
};
|
|
163
|
+
};
|
|
164
|
+
|
|
165
|
+
/**
|
|
166
|
+
* Loads a KTX texture container and returns the texture data
|
|
167
|
+
* @param view
|
|
168
|
+
* @returns
|
|
169
|
+
*/
|
|
170
|
+
const loadKTX = async function (view: DataView): Promise<ImageResponse> {
|
|
171
|
+
const endianness = view.getUint32(12, true);
|
|
172
|
+
const littleEndian = endianness === 0x04030201;
|
|
173
|
+
if (littleEndian === false && endianness !== 0x01020304) {
|
|
174
|
+
throw new Error('Invalid KTX endianness value');
|
|
175
|
+
}
|
|
176
|
+
|
|
177
|
+
const glType = view.getUint32(16, littleEndian);
|
|
178
|
+
const glFormat = view.getUint32(24, littleEndian);
|
|
179
|
+
if (glType !== 0 || glFormat !== 0) {
|
|
180
|
+
throw new Error(
|
|
181
|
+
`KTX texture is not compressed (glType: ${glType}, glFormat: ${glFormat})`,
|
|
182
|
+
);
|
|
183
|
+
}
|
|
184
|
+
|
|
185
|
+
const glInternalFormat = view.getUint32(28, littleEndian);
|
|
186
|
+
if (blockInfoMap[glInternalFormat] === undefined) {
|
|
187
|
+
throw new Error(
|
|
188
|
+
`Unsupported KTX compressed texture format: 0x${glInternalFormat.toString(
|
|
189
|
+
16,
|
|
190
|
+
)}`,
|
|
191
|
+
);
|
|
192
|
+
}
|
|
193
|
+
|
|
194
|
+
const width = view.getUint32(36, littleEndian);
|
|
195
|
+
const height = view.getUint32(40, littleEndian);
|
|
196
|
+
if (width === 0 || height === 0) {
|
|
197
|
+
throw new Error(`Invalid KTX texture dimensions: ${width}x${height}`);
|
|
198
|
+
}
|
|
199
|
+
|
|
200
|
+
const mipmapLevels = view.getUint32(56, littleEndian);
|
|
201
|
+
if (mipmapLevels === 0) {
|
|
202
|
+
throw new Error('KTX texture has no mipmap levels');
|
|
203
|
+
}
|
|
204
|
+
|
|
205
|
+
const bytesOfKeyValueData = view.getUint32(60, littleEndian);
|
|
206
|
+
const mipmaps: ArrayBuffer[] = [];
|
|
207
|
+
const buffer = view.buffer as ArrayBuffer;
|
|
208
|
+
let offset = 64 + bytesOfKeyValueData;
|
|
209
|
+
|
|
210
|
+
if (offset > view.byteLength) {
|
|
211
|
+
throw new Error('Invalid KTX file: key/value data exceeds file size');
|
|
212
|
+
}
|
|
213
|
+
|
|
214
|
+
for (let i = 0; i < mipmapLevels; i++) {
|
|
215
|
+
const imageSize = view.getUint32(offset, littleEndian);
|
|
216
|
+
offset += 4;
|
|
217
|
+
|
|
218
|
+
const end = offset + imageSize;
|
|
219
|
+
|
|
220
|
+
mipmaps.push(buffer.slice(offset, end));
|
|
221
|
+
offset = end;
|
|
222
|
+
if (offset % 4 !== 0) {
|
|
223
|
+
offset += 4 - (offset % 4);
|
|
224
|
+
}
|
|
225
|
+
}
|
|
226
|
+
|
|
227
|
+
return {
|
|
228
|
+
data: {
|
|
229
|
+
blockInfo: blockInfoMap[glInternalFormat]!,
|
|
230
|
+
glInternalFormat: glInternalFormat,
|
|
231
|
+
mipmaps,
|
|
232
|
+
w: width,
|
|
233
|
+
h: height,
|
|
234
|
+
type: 'KTX',
|
|
235
|
+
},
|
|
236
|
+
premultiplyAlpha: false,
|
|
237
|
+
};
|
|
238
|
+
};
|
|
239
|
+
|
|
240
|
+
function pvrtcMipSize(width: number, height: number, bpp: 2 | 4) {
|
|
241
|
+
const minW = bpp === 2 ? 16 : 8;
|
|
242
|
+
const minH = 8;
|
|
243
|
+
const w = Math.max(width, minW);
|
|
244
|
+
const h = Math.max(height, minH);
|
|
245
|
+
return (w * h * bpp) / 8;
|
|
246
|
+
}
|
|
247
|
+
|
|
248
|
+
const loadPVR = async function (view: DataView): Promise<ImageResponse> {
|
|
249
|
+
const pixelFormatLow = view.getUint32(8, true);
|
|
250
|
+
const internalFormat = PVR_TO_GL_INTERNAL_FORMAT[pixelFormatLow];
|
|
251
|
+
|
|
252
|
+
if (internalFormat === undefined) {
|
|
253
|
+
throw new Error(
|
|
254
|
+
`Unsupported PVR pixel format: 0x${pixelFormatLow.toString(16)}`,
|
|
255
|
+
);
|
|
256
|
+
}
|
|
257
|
+
|
|
258
|
+
const height = view.getInt32(24, true);
|
|
259
|
+
const width = view.getInt32(28, true);
|
|
260
|
+
|
|
261
|
+
// validate dimensions
|
|
262
|
+
if (width === 0 || height === 0) {
|
|
263
|
+
throw new Error(`Invalid PVR texture dimensions: ${width}x${height}`);
|
|
264
|
+
}
|
|
265
|
+
const mipmapLevels = view.getInt32(44, true);
|
|
266
|
+
const metadataSize = view.getUint32(48, true);
|
|
267
|
+
const buffer = view.buffer as ArrayBuffer;
|
|
268
|
+
|
|
269
|
+
let offset = 52 + metadataSize;
|
|
270
|
+
if (offset > buffer.byteLength) {
|
|
271
|
+
throw new Error('Invalid PVR file: metadata exceeds file size');
|
|
272
|
+
}
|
|
273
|
+
|
|
274
|
+
const mipmaps: ArrayBuffer[] = [];
|
|
275
|
+
|
|
276
|
+
const block = blockInfoMap[internalFormat]!;
|
|
277
|
+
|
|
278
|
+
for (let i = 0; i < mipmapLevels; i++) {
|
|
279
|
+
const declaredSize = view.getUint32(offset, true);
|
|
280
|
+
const max = buffer.byteLength - (offset + 4);
|
|
281
|
+
|
|
282
|
+
if (declaredSize > 0 && declaredSize <= max) {
|
|
283
|
+
offset += 4;
|
|
284
|
+
const start = offset;
|
|
285
|
+
const end = offset + declaredSize;
|
|
286
|
+
|
|
287
|
+
mipmaps.push(buffer.slice(start, end));
|
|
288
|
+
offset = end;
|
|
289
|
+
offset = (offset + 3) & ~3; // align to 4 bytes
|
|
290
|
+
continue;
|
|
291
|
+
}
|
|
292
|
+
|
|
293
|
+
if (
|
|
294
|
+
pixelFormatLow === 0 ||
|
|
295
|
+
pixelFormatLow === 1 ||
|
|
296
|
+
pixelFormatLow === 2 ||
|
|
297
|
+
pixelFormatLow === 3
|
|
298
|
+
) {
|
|
299
|
+
const bpp = pixelFormatLow === 0 || pixelFormatLow === 1 ? 2 : 4;
|
|
300
|
+
const computed = pvrtcMipSize(width >> i, height >> i, bpp);
|
|
301
|
+
|
|
302
|
+
mipmaps.push(buffer.slice(offset, offset + computed));
|
|
303
|
+
offset += computed;
|
|
304
|
+
offset = (offset + 3) & ~3; // align to 4 bytes
|
|
305
|
+
continue;
|
|
306
|
+
}
|
|
307
|
+
|
|
308
|
+
if (block !== undefined) {
|
|
309
|
+
const blockW = Math.ceil((width >> i) / block.width);
|
|
310
|
+
const blockH = Math.ceil((height >> i) / block.height);
|
|
311
|
+
const computed = blockW * blockH * block.bytes;
|
|
312
|
+
|
|
313
|
+
mipmaps.push(buffer.slice(offset, offset + computed));
|
|
314
|
+
offset += computed;
|
|
315
|
+
offset = (offset + 3) & ~3;
|
|
316
|
+
}
|
|
317
|
+
}
|
|
318
|
+
|
|
319
|
+
return {
|
|
320
|
+
data: {
|
|
321
|
+
blockInfo: blockInfoMap[internalFormat]!,
|
|
322
|
+
glInternalFormat: internalFormat,
|
|
323
|
+
mipmaps,
|
|
324
|
+
w: width,
|
|
325
|
+
h: height,
|
|
326
|
+
type: 'PVR',
|
|
327
|
+
},
|
|
328
|
+
premultiplyAlpha: false,
|
|
329
|
+
};
|
|
330
|
+
};
|
|
331
|
+
|
|
332
|
+
export interface CompressedImageData {
|
|
333
|
+
blockInfo: BlockInfo;
|
|
334
|
+
glInternalFormat: number;
|
|
335
|
+
mipmaps: ArrayBuffer[];
|
|
336
|
+
w: number;
|
|
337
|
+
h: number;
|
|
338
|
+
type: 'PVR' | 'KTX' | 'ASTC';
|
|
339
|
+
}
|
|
340
|
+
|
|
341
|
+
export type BlockInfo = {
|
|
342
|
+
width: number;
|
|
343
|
+
height: number;
|
|
344
|
+
bytes: number;
|
|
345
|
+
};
|
|
346
|
+
|
|
347
|
+
// Predefined block info for common compressed texture formats
|
|
348
|
+
const BLOCK_4x4x8: BlockInfo = { width: 4, height: 4, bytes: 8 };
|
|
349
|
+
const BLOCK_4x4x16: BlockInfo = { width: 4, height: 4, bytes: 16 };
|
|
350
|
+
const BLOCK_5x5x16: BlockInfo = { width: 5, height: 5, bytes: 16 };
|
|
351
|
+
const BLOCK_6x6x16: BlockInfo = { width: 6, height: 6, bytes: 16 };
|
|
352
|
+
const BLOCK_8x4x8: BlockInfo = { width: 8, height: 4, bytes: 8 };
|
|
353
|
+
const BLOCK_8x8x16: BlockInfo = { width: 8, height: 8, bytes: 16 };
|
|
354
|
+
const BLOCK_10x10x16: BlockInfo = { width: 10, height: 10, bytes: 16 };
|
|
355
|
+
const BLOCK_12x12x16: BlockInfo = { width: 12, height: 12, bytes: 16 };
|
|
356
|
+
|
|
357
|
+
// Map of GL internal formats to their corresponding block info
|
|
358
|
+
export const blockInfoMap: { [key: number]: BlockInfo } = {
|
|
359
|
+
// S3TC / DXTn (WEBGL_compressed_texture_s3tc, sRGB variants)
|
|
360
|
+
0x83f0: BLOCK_4x4x8, // COMPRESSED_RGB_S3TC_DXT1_EXT
|
|
361
|
+
0x83f1: BLOCK_4x4x8, // COMPRESSED_RGBA_S3TC_DXT1_EXT
|
|
362
|
+
0x83f2: BLOCK_4x4x16, // COMPRESSED_RGBA_S3TC_DXT3_EXT
|
|
363
|
+
0x83f3: BLOCK_4x4x16, // COMPRESSED_RGBA_S3TC_DXT5_EXT
|
|
364
|
+
|
|
365
|
+
// ETC1 / ETC2 / EAC
|
|
366
|
+
0x8d64: BLOCK_4x4x8, // COMPRESSED_RGB_ETC1_WEBGL
|
|
367
|
+
0x9274: BLOCK_4x4x8, // COMPRESSED_RGB8_ETC2
|
|
368
|
+
0x9275: BLOCK_4x4x8, // COMPRESSED_SRGB8_ETC2
|
|
369
|
+
0x9278: BLOCK_4x4x16, // COMPRESSED_RGBA8_ETC2_EAC
|
|
370
|
+
0x9279: BLOCK_4x4x16, // COMPRESSED_SRGB8_ALPHA8_ETC2_EAC
|
|
371
|
+
|
|
372
|
+
// PVRTC (WEBGL_compressed_texture_pvrtc)
|
|
373
|
+
0x8c00: BLOCK_4x4x8, // COMPRESSED_RGB_PVRTC_4BPPV1_IMG
|
|
374
|
+
0x8c02: BLOCK_4x4x8, // COMPRESSED_RGBA_PVRTC_4BPPV1_IMG
|
|
375
|
+
0x8c01: BLOCK_8x4x8, // COMPRESSED_RGB_PVRTC_2BPPV1_IMG
|
|
376
|
+
0x8c03: BLOCK_8x4x8,
|
|
377
|
+
|
|
378
|
+
// ASTC (WEBGL_compressed_texture_astc)
|
|
379
|
+
0x93b0: BLOCK_4x4x16, // COMPRESSED_RGBA_ASTC_4x4_KHR
|
|
380
|
+
0x93d0: BLOCK_4x4x16, // COMPRESSED_SRGB8_ALPHA8_ASTC_4x4_KHR
|
|
381
|
+
0x93b1: BLOCK_5x5x16, // 5x5
|
|
382
|
+
0x93d1: BLOCK_5x5x16,
|
|
383
|
+
0x93b2: BLOCK_6x6x16, // 6x6
|
|
384
|
+
0x93d2: BLOCK_6x6x16,
|
|
385
|
+
0x93b3: BLOCK_8x8x16, // 8x8
|
|
386
|
+
0x93d3: BLOCK_8x8x16,
|
|
387
|
+
0x93b4: BLOCK_10x10x16, // 10x10
|
|
388
|
+
0x93d4: BLOCK_10x10x16,
|
|
389
|
+
0x93b5: BLOCK_12x12x16, // 12x12
|
|
390
|
+
0x93d5: BLOCK_12x12x16,
|
|
391
|
+
};
|
|
@@ -1,78 +1,66 @@
|
|
|
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 { assertTruthy } from '
|
|
21
|
-
import {
|
|
22
|
-
|
|
23
|
-
/**
|
|
24
|
-
*
|
|
25
|
-
* @param url
|
|
26
|
-
* @
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
data: ctx.getImageData(x, y, sw ?? w, sh ?? h),
|
|
68
|
-
premultiplyAlpha: false,
|
|
69
|
-
});
|
|
70
|
-
};
|
|
71
|
-
|
|
72
|
-
img.onerror = (err) => {
|
|
73
|
-
reject(err);
|
|
74
|
-
};
|
|
75
|
-
|
|
76
|
-
img.src = url;
|
|
77
|
-
});
|
|
78
|
-
};
|
|
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 { assertTruthy } from '../../../../utils.js';
|
|
21
|
+
import type { ImageResponse } from '../../../textures/ImageTexture.js';
|
|
22
|
+
|
|
23
|
+
/**
|
|
24
|
+
* Loads a SVG image
|
|
25
|
+
* @param url
|
|
26
|
+
* @returns
|
|
27
|
+
*/
|
|
28
|
+
export const loadSvg = (
|
|
29
|
+
url: string,
|
|
30
|
+
width: number | null,
|
|
31
|
+
height: number | null,
|
|
32
|
+
sx: number | null,
|
|
33
|
+
sy: number | null,
|
|
34
|
+
sw: number | null,
|
|
35
|
+
sh: number | null,
|
|
36
|
+
): Promise<ImageResponse> => {
|
|
37
|
+
return new Promise((resolve, reject) => {
|
|
38
|
+
const canvas = document.createElement('canvas');
|
|
39
|
+
const ctx = canvas.getContext('2d');
|
|
40
|
+
assertTruthy(ctx);
|
|
41
|
+
|
|
42
|
+
ctx.imageSmoothingEnabled = true;
|
|
43
|
+
const img = new Image();
|
|
44
|
+
img.onload = () => {
|
|
45
|
+
const x = sx ?? 0;
|
|
46
|
+
const y = sy ?? 0;
|
|
47
|
+
const w = width || img.width;
|
|
48
|
+
const h = height || img.height;
|
|
49
|
+
|
|
50
|
+
canvas.width = w;
|
|
51
|
+
canvas.height = h;
|
|
52
|
+
ctx.drawImage(img, 0, 0, w, h);
|
|
53
|
+
|
|
54
|
+
resolve({
|
|
55
|
+
data: ctx.getImageData(x, y, sw ?? w, sh ?? h),
|
|
56
|
+
premultiplyAlpha: false,
|
|
57
|
+
});
|
|
58
|
+
};
|
|
59
|
+
|
|
60
|
+
img.onerror = (err) => {
|
|
61
|
+
reject(err);
|
|
62
|
+
};
|
|
63
|
+
|
|
64
|
+
img.src = url;
|
|
65
|
+
});
|
|
66
|
+
};
|
|
@@ -0,0 +1,105 @@
|
|
|
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 2026 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
|
+
export const PROTOCOL_REGEX = /^(data|ftps?|https?):/;
|
|
21
|
+
|
|
22
|
+
export function isBase64Image(src: string) {
|
|
23
|
+
return src.startsWith('data:') === true;
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
export function dataURIToBlob(dataURI: string): Blob {
|
|
27
|
+
dataURI = dataURI.replace(/^data:/, '');
|
|
28
|
+
|
|
29
|
+
const type = dataURI.match(/image\/[^;]+/)?.[0] || '';
|
|
30
|
+
const base64 = dataURI.replace(/^[^,]+,/, '');
|
|
31
|
+
|
|
32
|
+
const sliceSize = 1024;
|
|
33
|
+
const byteCharacters = atob(base64);
|
|
34
|
+
const bytesLength = byteCharacters.length;
|
|
35
|
+
const slicesCount = Math.ceil(bytesLength / sliceSize);
|
|
36
|
+
const byteArrays = new Array(slicesCount);
|
|
37
|
+
|
|
38
|
+
for (let sliceIndex = 0; sliceIndex < slicesCount; ++sliceIndex) {
|
|
39
|
+
const begin = sliceIndex * sliceSize;
|
|
40
|
+
const end = Math.min(begin + sliceSize, bytesLength);
|
|
41
|
+
|
|
42
|
+
const bytes = new Array(end - begin);
|
|
43
|
+
for (let offset = begin, i = 0; offset < end; ++i, ++offset) {
|
|
44
|
+
bytes[i] = byteCharacters[offset]?.charCodeAt(0);
|
|
45
|
+
}
|
|
46
|
+
byteArrays[sliceIndex] = new Uint8Array(bytes);
|
|
47
|
+
}
|
|
48
|
+
return new Blob(byteArrays, { type });
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
export function convertUrlToAbsolute(url: string): string {
|
|
52
|
+
// handle local file imports if the url isn't remote resource or data blob
|
|
53
|
+
if (self.location.protocol === 'file:' && !PROTOCOL_REGEX.test(url)) {
|
|
54
|
+
const path = self.location.pathname.split('/');
|
|
55
|
+
path.pop();
|
|
56
|
+
const basePath = path.join('/');
|
|
57
|
+
const baseUrl = self.location.protocol + '//' + basePath;
|
|
58
|
+
|
|
59
|
+
// check if url has a leading dot
|
|
60
|
+
if (url.charAt(0) === '.') {
|
|
61
|
+
url = url.slice(1);
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
// check if url has a leading slash
|
|
65
|
+
if (url.charAt(0) === '/') {
|
|
66
|
+
url = url.slice(1);
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
return baseUrl + '/' + url;
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
const absoluteUrl = new URL(url, self.location.href);
|
|
73
|
+
return absoluteUrl.href;
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
export function createWebGLContext(
|
|
77
|
+
canvas: HTMLCanvasElement | OffscreenCanvas,
|
|
78
|
+
forceWebGL2 = false,
|
|
79
|
+
): WebGLRenderingContext {
|
|
80
|
+
const config: WebGLContextAttributes = {
|
|
81
|
+
alpha: true,
|
|
82
|
+
antialias: false,
|
|
83
|
+
depth: false,
|
|
84
|
+
stencil: true,
|
|
85
|
+
desynchronized: false,
|
|
86
|
+
// Disabled because it prevents Visual Regression Tests from working
|
|
87
|
+
// failIfMajorPerformanceCaveat: true,
|
|
88
|
+
powerPreference: 'high-performance',
|
|
89
|
+
premultipliedAlpha: true,
|
|
90
|
+
preserveDrawingBuffer: false,
|
|
91
|
+
};
|
|
92
|
+
const gl =
|
|
93
|
+
// TODO: Remove this assertion once this issue is fixed in TypeScript
|
|
94
|
+
// https://github.com/microsoft/TypeScript/issues/53614
|
|
95
|
+
(canvas.getContext(forceWebGL2 ? 'webgl2' : 'webgl', config) ||
|
|
96
|
+
canvas.getContext(
|
|
97
|
+
'experimental-webgl' as 'webgl',
|
|
98
|
+
config,
|
|
99
|
+
)) as unknown as WebGLRenderingContext | null;
|
|
100
|
+
if (!gl) {
|
|
101
|
+
throw new Error('Unable to create WebGL context');
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
return gl;
|
|
105
|
+
}
|