@solidtv/renderer 1.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 -0
- package/NOTICE +7 -0
- package/README.md +137 -0
- package/dist/exports/canvas-shaders.d.ts +10 -0
- package/dist/exports/canvas-shaders.js +11 -0
- package/dist/exports/canvas-shaders.js.map +1 -0
- package/dist/exports/canvas.d.ts +26 -0
- package/dist/exports/canvas.js +27 -0
- package/dist/exports/canvas.js.map +1 -0
- package/dist/exports/index.d.ts +50 -0
- package/dist/exports/index.js +40 -0
- package/dist/exports/index.js.map +1 -0
- package/dist/exports/inspector.d.ts +4 -0
- package/dist/exports/inspector.js +5 -0
- package/dist/exports/inspector.js.map +1 -0
- package/dist/exports/utils.d.ts +27 -0
- package/dist/exports/utils.js +28 -0
- package/dist/exports/utils.js.map +1 -0
- package/dist/exports/webgl-shaders.d.ts +11 -0
- package/dist/exports/webgl-shaders.js +12 -0
- package/dist/exports/webgl-shaders.js.map +1 -0
- package/dist/exports/webgl.d.ts +28 -0
- package/dist/exports/webgl.js +29 -0
- package/dist/exports/webgl.js.map +1 -0
- package/dist/src/common/CommonTypes.d.ts +110 -0
- package/dist/src/common/CommonTypes.js +2 -0
- package/dist/src/common/CommonTypes.js.map +1 -0
- package/dist/src/common/EventEmitter.d.ts +12 -0
- package/dist/src/common/EventEmitter.js +48 -0
- package/dist/src/common/EventEmitter.js.map +1 -0
- package/dist/src/common/IAnimationController.d.ts +58 -0
- package/dist/src/common/IAnimationController.js +2 -0
- package/dist/src/common/IAnimationController.js.map +1 -0
- package/dist/src/common/IEventEmitter.d.ts +8 -0
- package/dist/src/common/IEventEmitter.js +2 -0
- package/dist/src/common/IEventEmitter.js.map +1 -0
- package/dist/src/core/Autosizer.d.ts +35 -0
- package/dist/src/core/Autosizer.js +178 -0
- package/dist/src/core/Autosizer.js.map +1 -0
- package/dist/src/core/CoreNode.d.ts +908 -0
- package/dist/src/core/CoreNode.js +1837 -0
- package/dist/src/core/CoreNode.js.map +1 -0
- package/dist/src/core/CoreShaderManager.d.ts +38 -0
- package/dist/src/core/CoreShaderManager.js +123 -0
- package/dist/src/core/CoreShaderManager.js.map +1 -0
- package/dist/src/core/CoreTextNode.d.ts +91 -0
- package/dist/src/core/CoreTextNode.js +440 -0
- package/dist/src/core/CoreTextNode.js.map +1 -0
- package/dist/src/core/CoreTextureManager.d.ts +264 -0
- package/dist/src/core/CoreTextureManager.js +318 -0
- package/dist/src/core/CoreTextureManager.js.map +1 -0
- package/dist/src/core/Stage.d.ts +238 -0
- package/dist/src/core/Stage.js +804 -0
- package/dist/src/core/Stage.js.map +1 -0
- 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 +150 -0
- package/dist/src/core/TextureMemoryManager.js +239 -0
- package/dist/src/core/TextureMemoryManager.js.map +1 -0
- package/dist/src/core/animations/AnimationManager.d.ts +33 -0
- package/dist/src/core/animations/AnimationManager.js +137 -0
- package/dist/src/core/animations/AnimationManager.js.map +1 -0
- package/dist/src/core/animations/CoreAnimation.d.ts +12 -0
- package/dist/src/core/animations/CoreAnimation.js +107 -0
- package/dist/src/core/animations/CoreAnimation.js.map +1 -0
- package/dist/src/core/lib/ContextSpy.d.ts +12 -0
- package/dist/src/core/lib/ContextSpy.js +20 -0
- package/dist/src/core/lib/ContextSpy.js.map +1 -0
- package/dist/src/core/lib/ImageWorker.d.ts +16 -0
- package/dist/src/core/lib/ImageWorker.js +202 -0
- package/dist/src/core/lib/ImageWorker.js.map +1 -0
- package/dist/src/core/lib/Matrix3d.d.ts +74 -0
- package/dist/src/core/lib/Matrix3d.js +218 -0
- package/dist/src/core/lib/Matrix3d.js.map +1 -0
- package/dist/src/core/lib/RenderCoords.d.ts +12 -0
- package/dist/src/core/lib/RenderCoords.js +35 -0
- package/dist/src/core/lib/RenderCoords.js.map +1 -0
- package/dist/src/core/lib/WebGlContextWrapper.d.ts +782 -0
- package/dist/src/core/lib/WebGlContextWrapper.js +1143 -0
- package/dist/src/core/lib/WebGlContextWrapper.js.map +1 -0
- package/dist/src/core/lib/collectionUtils.d.ts +5 -0
- package/dist/src/core/lib/collectionUtils.js +82 -0
- package/dist/src/core/lib/collectionUtils.js.map +1 -0
- package/dist/src/core/lib/colorCache.d.ts +1 -0
- package/dist/src/core/lib/colorCache.js +19 -0
- package/dist/src/core/lib/colorCache.js.map +1 -0
- package/dist/src/core/lib/colorParser.d.ts +21 -0
- package/dist/src/core/lib/colorParser.js +54 -0
- package/dist/src/core/lib/colorParser.js.map +1 -0
- package/dist/src/core/lib/textureCompression.d.ts +28 -0
- package/dist/src/core/lib/textureCompression.js +363 -0
- package/dist/src/core/lib/textureCompression.js.map +1 -0
- package/dist/src/core/lib/textureSvg.d.ts +16 -0
- package/dist/src/core/lib/textureSvg.js +45 -0
- package/dist/src/core/lib/textureSvg.js.map +1 -0
- package/dist/src/core/lib/utils.d.ts +66 -0
- package/dist/src/core/lib/utils.js +268 -0
- package/dist/src/core/lib/utils.js.map +1 -0
- package/dist/src/core/lib/validateImageBitmap.d.ts +7 -0
- package/dist/src/core/lib/validateImageBitmap.js +68 -0
- package/dist/src/core/lib/validateImageBitmap.js.map +1 -0
- package/dist/src/core/platforms/Platform.d.ts +42 -0
- package/dist/src/core/platforms/Platform.js +4 -0
- package/dist/src/core/platforms/Platform.js.map +1 -0
- package/dist/src/core/platforms/web/WebPlatform.d.ts +10 -0
- package/dist/src/core/platforms/web/WebPlatform.js +90 -0
- package/dist/src/core/platforms/web/WebPlatform.js.map +1 -0
- package/dist/src/core/renderers/CoreContextTexture.d.ts +13 -0
- package/dist/src/core/renderers/CoreContextTexture.js +16 -0
- package/dist/src/core/renderers/CoreContextTexture.js.map +1 -0
- package/dist/src/core/renderers/CoreRenderOp.d.ts +3 -0
- package/dist/src/core/renderers/CoreRenderOp.js +3 -0
- package/dist/src/core/renderers/CoreRenderOp.js.map +1 -0
- package/dist/src/core/renderers/CoreRenderer.d.ts +81 -0
- package/dist/src/core/renderers/CoreRenderer.js +14 -0
- package/dist/src/core/renderers/CoreRenderer.js.map +1 -0
- package/dist/src/core/renderers/CoreShaderNode.d.ts +69 -0
- package/dist/src/core/renderers/CoreShaderNode.js +130 -0
- package/dist/src/core/renderers/CoreShaderNode.js.map +1 -0
- package/dist/src/core/renderers/CoreShaderProgram.d.ts +4 -0
- package/dist/src/core/renderers/CoreShaderProgram.js +2 -0
- package/dist/src/core/renderers/CoreShaderProgram.js.map +1 -0
- package/dist/src/core/renderers/canvas/CanvasRenderer.d.ts +36 -0
- package/dist/src/core/renderers/canvas/CanvasRenderer.js +221 -0
- package/dist/src/core/renderers/canvas/CanvasRenderer.js.map +1 -0
- package/dist/src/core/renderers/canvas/CanvasShaderNode.d.ts +21 -0
- package/dist/src/core/renderers/canvas/CanvasShaderNode.js +42 -0
- package/dist/src/core/renderers/canvas/CanvasShaderNode.js.map +1 -0
- package/dist/src/core/renderers/canvas/CanvasTexture.d.ts +17 -0
- package/dist/src/core/renderers/canvas/CanvasTexture.js +110 -0
- package/dist/src/core/renderers/canvas/CanvasTexture.js.map +1 -0
- package/dist/src/core/renderers/webgl/SdfRenderOp.d.ts +41 -0
- package/dist/src/core/renderers/webgl/SdfRenderOp.js +88 -0
- package/dist/src/core/renderers/webgl/SdfRenderOp.js.map +1 -0
- package/dist/src/core/renderers/webgl/WebGlCtxRenderTexture.d.ts +14 -0
- package/dist/src/core/renderers/webgl/WebGlCtxRenderTexture.js +45 -0
- package/dist/src/core/renderers/webgl/WebGlCtxRenderTexture.js.map +1 -0
- package/dist/src/core/renderers/webgl/WebGlCtxSubTexture.d.ts +22 -0
- package/dist/src/core/renderers/webgl/WebGlCtxSubTexture.js +49 -0
- package/dist/src/core/renderers/webgl/WebGlCtxSubTexture.js.map +1 -0
- package/dist/src/core/renderers/webgl/WebGlCtxTexture.d.ts +67 -0
- package/dist/src/core/renderers/webgl/WebGlCtxTexture.js +259 -0
- package/dist/src/core/renderers/webgl/WebGlCtxTexture.js.map +1 -0
- package/dist/src/core/renderers/webgl/WebGlRenderer.d.ts +221 -0
- package/dist/src/core/renderers/webgl/WebGlRenderer.js +1015 -0
- package/dist/src/core/renderers/webgl/WebGlRenderer.js.map +1 -0
- package/dist/src/core/renderers/webgl/WebGlShaderNode.d.ts +213 -0
- package/dist/src/core/renderers/webgl/WebGlShaderNode.js +331 -0
- package/dist/src/core/renderers/webgl/WebGlShaderNode.js.map +1 -0
- package/dist/src/core/renderers/webgl/WebGlShaderProgram.d.ts +37 -0
- package/dist/src/core/renderers/webgl/WebGlShaderProgram.js +240 -0
- package/dist/src/core/renderers/webgl/WebGlShaderProgram.js.map +1 -0
- package/dist/src/core/renderers/webgl/internal/BufferCollection.d.ts +28 -0
- package/dist/src/core/renderers/webgl/internal/BufferCollection.js +39 -0
- package/dist/src/core/renderers/webgl/internal/BufferCollection.js.map +1 -0
- package/dist/src/core/renderers/webgl/internal/RendererUtils.d.ts +55 -0
- package/dist/src/core/renderers/webgl/internal/RendererUtils.js +88 -0
- package/dist/src/core/renderers/webgl/internal/RendererUtils.js.map +1 -0
- package/dist/src/core/renderers/webgl/internal/ShaderUtils.d.ts +74 -0
- package/dist/src/core/renderers/webgl/internal/ShaderUtils.js +83 -0
- package/dist/src/core/renderers/webgl/internal/ShaderUtils.js.map +1 -0
- package/dist/src/core/renderers/webgl/internal/WebGlUtils.d.ts +10 -0
- package/dist/src/core/renderers/webgl/internal/WebGlUtils.js +13 -0
- package/dist/src/core/renderers/webgl/internal/WebGlUtils.js.map +1 -0
- package/dist/src/core/shaders/canvas/Border.d.ts +15 -0
- package/dist/src/core/shaders/canvas/Border.js +83 -0
- package/dist/src/core/shaders/canvas/Border.js.map +1 -0
- package/dist/src/core/shaders/canvas/HolePunch.d.ts +7 -0
- package/dist/src/core/shaders/canvas/HolePunch.js +22 -0
- package/dist/src/core/shaders/canvas/HolePunch.js.map +1 -0
- package/dist/src/core/shaders/canvas/LinearGradient.d.ts +10 -0
- package/dist/src/core/shaders/canvas/LinearGradient.js +32 -0
- package/dist/src/core/shaders/canvas/LinearGradient.js.map +1 -0
- package/dist/src/core/shaders/canvas/RadialGradient.d.ts +11 -0
- package/dist/src/core/shaders/canvas/RadialGradient.js +54 -0
- package/dist/src/core/shaders/canvas/RadialGradient.js.map +1 -0
- package/dist/src/core/shaders/canvas/Rounded.d.ts +7 -0
- package/dist/src/core/shaders/canvas/Rounded.js +17 -0
- package/dist/src/core/shaders/canvas/Rounded.js.map +1 -0
- package/dist/src/core/shaders/canvas/RoundedWithBorder.d.ts +10 -0
- package/dist/src/core/shaders/canvas/RoundedWithBorder.js +57 -0
- package/dist/src/core/shaders/canvas/RoundedWithBorder.js.map +1 -0
- package/dist/src/core/shaders/canvas/RoundedWithBorderAndShadow.d.ts +7 -0
- package/dist/src/core/shaders/canvas/RoundedWithBorderAndShadow.js +61 -0
- package/dist/src/core/shaders/canvas/RoundedWithBorderAndShadow.js.map +1 -0
- package/dist/src/core/shaders/canvas/RoundedWithShadow.d.ts +7 -0
- package/dist/src/core/shaders/canvas/RoundedWithShadow.js +26 -0
- package/dist/src/core/shaders/canvas/RoundedWithShadow.js.map +1 -0
- package/dist/src/core/shaders/canvas/Shadow.d.ts +8 -0
- package/dist/src/core/shaders/canvas/Shadow.js +15 -0
- package/dist/src/core/shaders/canvas/Shadow.js.map +1 -0
- package/dist/src/core/shaders/canvas/utils/render.d.ts +5 -0
- package/dist/src/core/shaders/canvas/utils/render.js +81 -0
- package/dist/src/core/shaders/canvas/utils/render.js.map +1 -0
- package/dist/src/core/shaders/templates/BorderTemplate.d.ts +47 -0
- package/dist/src/core/shaders/templates/BorderTemplate.js +77 -0
- package/dist/src/core/shaders/templates/BorderTemplate.js.map +1 -0
- package/dist/src/core/shaders/templates/HolePunchTemplate.d.ts +46 -0
- package/dist/src/core/shaders/templates/HolePunchTemplate.js +19 -0
- package/dist/src/core/shaders/templates/HolePunchTemplate.js.map +1 -0
- package/dist/src/core/shaders/templates/LinearGradientTemplate.d.ts +23 -0
- package/dist/src/core/shaders/templates/LinearGradientTemplate.js +31 -0
- package/dist/src/core/shaders/templates/LinearGradientTemplate.js.map +1 -0
- package/dist/src/core/shaders/templates/RadialGradientTemplate.d.ts +33 -0
- package/dist/src/core/shaders/templates/RadialGradientTemplate.js +33 -0
- package/dist/src/core/shaders/templates/RadialGradientTemplate.js.map +1 -0
- package/dist/src/core/shaders/templates/RoundedTemplate.d.ts +29 -0
- package/dist/src/core/shaders/templates/RoundedTemplate.js +51 -0
- package/dist/src/core/shaders/templates/RoundedTemplate.js.map +1 -0
- package/dist/src/core/shaders/templates/RoundedWithBorderAndShadowTemplate.d.ts +7 -0
- package/dist/src/core/shaders/templates/RoundedWithBorderAndShadowTemplate.js +8 -0
- package/dist/src/core/shaders/templates/RoundedWithBorderAndShadowTemplate.js.map +1 -0
- package/dist/src/core/shaders/templates/RoundedWithBorderTemplate.d.ts +8 -0
- package/dist/src/core/shaders/templates/RoundedWithBorderTemplate.js +9 -0
- package/dist/src/core/shaders/templates/RoundedWithBorderTemplate.js.map +1 -0
- package/dist/src/core/shaders/templates/RoundedWithShadowTemplate.d.ts +6 -0
- package/dist/src/core/shaders/templates/RoundedWithShadowTemplate.js +7 -0
- package/dist/src/core/shaders/templates/RoundedWithShadowTemplate.js.map +1 -0
- package/dist/src/core/shaders/templates/ShadowTemplate.d.ts +34 -0
- package/dist/src/core/shaders/templates/ShadowTemplate.js +50 -0
- package/dist/src/core/shaders/templates/ShadowTemplate.js.map +1 -0
- package/dist/src/core/shaders/utils.d.ts +5 -0
- package/dist/src/core/shaders/utils.js +25 -0
- package/dist/src/core/shaders/utils.js.map +1 -0
- package/dist/src/core/shaders/webgl/Border.d.ts +3 -0
- package/dist/src/core/shaders/webgl/Border.js +153 -0
- package/dist/src/core/shaders/webgl/Border.js.map +1 -0
- package/dist/src/core/shaders/webgl/Default.d.ts +2 -0
- package/dist/src/core/shaders/webgl/Default.js +51 -0
- package/dist/src/core/shaders/webgl/Default.js.map +1 -0
- package/dist/src/core/shaders/webgl/HolePunch.d.ts +3 -0
- package/dist/src/core/shaders/webgl/HolePunch.js +49 -0
- package/dist/src/core/shaders/webgl/HolePunch.js.map +1 -0
- package/dist/src/core/shaders/webgl/LinearGradient.d.ts +3 -0
- package/dist/src/core/shaders/webgl/LinearGradient.js +114 -0
- package/dist/src/core/shaders/webgl/LinearGradient.js.map +1 -0
- package/dist/src/core/shaders/webgl/RadialGradient.d.ts +3 -0
- package/dist/src/core/shaders/webgl/RadialGradient.js +81 -0
- package/dist/src/core/shaders/webgl/RadialGradient.js.map +1 -0
- package/dist/src/core/shaders/webgl/Rounded.d.ts +7 -0
- package/dist/src/core/shaders/webgl/Rounded.js +88 -0
- package/dist/src/core/shaders/webgl/Rounded.js.map +1 -0
- package/dist/src/core/shaders/webgl/RoundedWithBorder.d.ts +3 -0
- package/dist/src/core/shaders/webgl/RoundedWithBorder.js +202 -0
- package/dist/src/core/shaders/webgl/RoundedWithBorder.js.map +1 -0
- package/dist/src/core/shaders/webgl/RoundedWithBorderAndShadow.d.ts +3 -0
- package/dist/src/core/shaders/webgl/RoundedWithBorderAndShadow.js +223 -0
- package/dist/src/core/shaders/webgl/RoundedWithBorderAndShadow.js.map +1 -0
- package/dist/src/core/shaders/webgl/RoundedWithShadow.d.ts +3 -0
- package/dist/src/core/shaders/webgl/RoundedWithShadow.js +123 -0
- package/dist/src/core/shaders/webgl/RoundedWithShadow.js.map +1 -0
- package/dist/src/core/shaders/webgl/SdfShader.d.ts +13 -0
- package/dist/src/core/shaders/webgl/SdfShader.js +72 -0
- package/dist/src/core/shaders/webgl/SdfShader.js.map +1 -0
- package/dist/src/core/shaders/webgl/Shadow.d.ts +3 -0
- package/dist/src/core/shaders/webgl/Shadow.js +115 -0
- package/dist/src/core/shaders/webgl/Shadow.js.map +1 -0
- package/dist/src/core/text-rendering/CanvasFontHandler.d.ts +59 -0
- package/dist/src/core/text-rendering/CanvasFontHandler.js +206 -0
- package/dist/src/core/text-rendering/CanvasFontHandler.js.map +1 -0
- package/dist/src/core/text-rendering/CanvasTextRenderer.d.ts +17 -0
- package/dist/src/core/text-rendering/CanvasTextRenderer.js +139 -0
- package/dist/src/core/text-rendering/CanvasTextRenderer.js.map +1 -0
- package/dist/src/core/text-rendering/SdfFontHandler.d.ts +167 -0
- package/dist/src/core/text-rendering/SdfFontHandler.js +371 -0
- package/dist/src/core/text-rendering/SdfFontHandler.js.map +1 -0
- package/dist/src/core/text-rendering/SdfTextRenderer.d.ts +17 -0
- package/dist/src/core/text-rendering/SdfTextRenderer.js +249 -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 +406 -0
- package/dist/src/core/text-rendering/TextRenderer.js +2 -0
- package/dist/src/core/text-rendering/TextRenderer.js.map +1 -0
- package/dist/src/core/text-rendering/Utils.d.ts +30 -0
- package/dist/src/core/text-rendering/Utils.js +66 -0
- package/dist/src/core/text-rendering/Utils.js.map +1 -0
- package/dist/src/core/textures/ColorTexture.d.ts +36 -0
- package/dist/src/core/textures/ColorTexture.js +57 -0
- package/dist/src/core/textures/ColorTexture.js.map +1 -0
- package/dist/src/core/textures/ImageTexture.d.ts +131 -0
- package/dist/src/core/textures/ImageTexture.js +211 -0
- package/dist/src/core/textures/ImageTexture.js.map +1 -0
- package/dist/src/core/textures/NoiseTexture.d.ts +43 -0
- package/dist/src/core/textures/NoiseTexture.js +50 -0
- package/dist/src/core/textures/NoiseTexture.js.map +1 -0
- package/dist/src/core/textures/RenderTexture.d.ts +29 -0
- package/dist/src/core/textures/RenderTexture.js +36 -0
- package/dist/src/core/textures/RenderTexture.js.map +1 -0
- package/dist/src/core/textures/SubTexture.d.ts +61 -0
- package/dist/src/core/textures/SubTexture.js +99 -0
- package/dist/src/core/textures/SubTexture.js.map +1 -0
- package/dist/src/core/textures/Texture.d.ts +275 -0
- package/dist/src/core/textures/Texture.js +326 -0
- package/dist/src/core/textures/Texture.js.map +1 -0
- package/dist/src/core/utils.d.ts +23 -0
- package/dist/src/core/utils.js +155 -0
- package/dist/src/core/utils.js.map +1 -0
- package/dist/src/main-api/INode.d.ts +65 -0
- package/dist/src/main-api/INode.js +2 -0
- package/dist/src/main-api/INode.js.map +1 -0
- package/dist/src/main-api/Inspector.d.ts +154 -0
- package/dist/src/main-api/Inspector.js +844 -0
- package/dist/src/main-api/Inspector.js.map +1 -0
- package/dist/src/main-api/Renderer.d.ts +629 -0
- package/dist/src/main-api/Renderer.js +471 -0
- package/dist/src/main-api/Renderer.js.map +1 -0
- package/dist/src/main-api/utils.d.ts +2 -0
- package/dist/src/main-api/utils.js +34 -0
- package/dist/src/main-api/utils.js.map +1 -0
- package/dist/src/utils.d.ts +123 -0
- package/dist/src/utils.js +234 -0
- package/dist/src/utils.js.map +1 -0
- package/dist/tsconfig.dist.tsbuildinfo +1 -0
- package/exports/canvas-shaders.ts +11 -0
- package/exports/canvas.ts +27 -0
- package/exports/index.ts +69 -0
- package/exports/inspector.ts +5 -0
- package/exports/utils.ts +32 -0
- package/exports/webgl-shaders.ts +12 -0
- package/exports/webgl.ts +33 -0
- package/package.json +99 -0
- package/src/common/CommonTypes.ts +145 -0
- package/src/common/EventEmitter.ts +58 -0
- package/src/common/IAnimationController.ts +65 -0
- package/src/common/IEventEmitter.ts +11 -0
- package/src/core/Autosizer.ts +205 -0
- package/src/core/CoreNode.test.ts +535 -0
- package/src/core/CoreNode.ts +2883 -0
- package/src/core/CoreShaderManager.ts +170 -0
- package/src/core/CoreTextNode.ts +573 -0
- package/src/core/CoreTextureManager.ts +552 -0
- package/src/core/Stage.ts +1037 -0
- package/src/core/TextureError.ts +46 -0
- package/src/core/TextureMemoryManager.ts +378 -0
- package/src/core/animations/AnimationManager.ts +178 -0
- package/src/core/animations/CoreAnimation.ts +138 -0
- package/src/core/lib/ContextSpy.ts +22 -0
- package/src/core/lib/ImageWorker.ts +292 -0
- package/src/core/lib/Matrix3d.ts +231 -0
- package/src/core/lib/RenderCoords.ts +55 -0
- package/src/core/lib/WebGlContextWrapper.ts +1448 -0
- package/src/core/lib/collectionUtils.ts +99 -0
- package/src/core/lib/colorCache.ts +20 -0
- package/src/core/lib/colorParser.ts +66 -0
- package/src/core/lib/textureCompression.ts +492 -0
- package/src/core/lib/textureSvg.ts +59 -0
- package/src/core/lib/utils.ts +400 -0
- package/src/core/lib/validateImageBitmap.ts +87 -0
- package/src/core/platforms/Platform.ts +64 -0
- package/src/core/platforms/web/WebPlatform.ts +132 -0
- package/src/core/renderers/CoreContextTexture.ts +25 -0
- package/src/core/renderers/CoreRenderOp.ts +3 -0
- package/src/core/renderers/CoreRenderer.ts +101 -0
- package/src/core/renderers/CoreShaderNode.ts +202 -0
- package/src/core/renderers/CoreShaderProgram.ts +4 -0
- package/src/core/renderers/canvas/CanvasRenderer.ts +274 -0
- package/src/core/renderers/canvas/CanvasShaderNode.ts +79 -0
- package/src/core/renderers/canvas/CanvasTexture.ts +141 -0
- package/src/core/renderers/webgl/SdfRenderOp.ts +103 -0
- package/src/core/renderers/webgl/WebGlCtxRenderTexture.ts +70 -0
- package/src/core/renderers/webgl/WebGlCtxSubTexture.ts +76 -0
- package/src/core/renderers/webgl/WebGlCtxTexture.ts +332 -0
- package/src/core/renderers/webgl/WebGlRenderer.ts +1323 -0
- package/src/core/renderers/webgl/WebGlShaderNode.ts +423 -0
- package/src/core/renderers/webgl/WebGlShaderProgram.ts +346 -0
- package/src/core/renderers/webgl/internal/BufferCollection.ts +46 -0
- package/src/core/renderers/webgl/internal/RendererUtils.ts +136 -0
- package/src/core/renderers/webgl/internal/ShaderUtils.ts +262 -0
- package/src/core/renderers/webgl/internal/WebGlUtils.ts +16 -0
- package/src/core/shaders/canvas/Border.ts +119 -0
- package/src/core/shaders/canvas/HolePunch.ts +38 -0
- package/src/core/shaders/canvas/LinearGradient.ts +54 -0
- package/src/core/shaders/canvas/RadialGradient.ts +82 -0
- package/src/core/shaders/canvas/Rounded.ts +38 -0
- package/src/core/shaders/canvas/RoundedWithBorder.ts +105 -0
- package/src/core/shaders/canvas/RoundedWithBorderAndShadow.ts +118 -0
- package/src/core/shaders/canvas/RoundedWithShadow.ts +56 -0
- package/src/core/shaders/canvas/Shadow.ts +35 -0
- package/src/core/shaders/canvas/utils/render.ts +143 -0
- package/src/core/shaders/templates/BorderTemplate.ts +128 -0
- package/src/core/shaders/templates/HolePunchTemplate.ts +65 -0
- package/src/core/shaders/templates/LinearGradientTemplate.ts +54 -0
- package/src/core/shaders/templates/RadialGradientTemplate.ts +66 -0
- package/src/core/shaders/templates/RoundedTemplate.ts +81 -0
- package/src/core/shaders/templates/RoundedWithBorderAndShadowTemplate.ts +21 -0
- package/src/core/shaders/templates/RoundedWithBorderTemplate.ts +23 -0
- package/src/core/shaders/templates/RoundedWithShadowTemplate.ts +18 -0
- package/src/core/shaders/templates/ShadowTemplate.ts +89 -0
- package/src/core/shaders/utils.ts +30 -0
- package/src/core/shaders/webgl/Border.ts +158 -0
- package/src/core/shaders/webgl/Default.ts +52 -0
- package/src/core/shaders/webgl/HolePunch.ts +58 -0
- package/src/core/shaders/webgl/LinearGradient.ts +119 -0
- package/src/core/shaders/webgl/RadialGradient.ts +91 -0
- package/src/core/shaders/webgl/Rounded.ts +97 -0
- package/src/core/shaders/webgl/RoundedWithBorder.ts +212 -0
- package/src/core/shaders/webgl/RoundedWithBorderAndShadow.ts +235 -0
- package/src/core/shaders/webgl/RoundedWithShadow.ts +132 -0
- package/src/core/shaders/webgl/SdfShader.ts +73 -0
- package/src/core/shaders/webgl/Shadow.ts +119 -0
- package/src/core/text-rendering/CanvasFontHandler.ts +285 -0
- package/src/core/text-rendering/CanvasTextRenderer.ts +236 -0
- package/src/core/text-rendering/SdfFontHandler.ts +566 -0
- package/src/core/text-rendering/SdfTextRenderer.ts +352 -0
- package/src/core/text-rendering/TextLayoutEngine.ts +672 -0
- package/src/core/text-rendering/TextRenderer.ts +449 -0
- package/src/core/text-rendering/Utils.ts +80 -0
- package/src/core/text-rendering/tests/TextLayoutEngine.test.ts +434 -0
- package/src/core/textures/ColorTexture.ts +85 -0
- package/src/core/textures/ImageTexture.ts +394 -0
- package/src/core/textures/NoiseTexture.ts +87 -0
- package/src/core/textures/RenderTexture.ts +68 -0
- package/src/core/textures/SubTexture.ts +165 -0
- package/src/core/textures/Texture.ts +505 -0
- package/src/core/utils.ts +210 -0
- package/src/env.d.ts +7 -0
- package/src/main-api/INode.ts +92 -0
- package/src/main-api/Inspector.ts +1267 -0
- package/src/main-api/Renderer.ts +1011 -0
- package/src/main-api/utils.ts +45 -0
- package/src/utils.ts +302 -0
package/package.json
ADDED
|
@@ -0,0 +1,99 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@solidtv/renderer",
|
|
3
|
+
"version": "1.0.0",
|
|
4
|
+
"description": "SolidTV Renderer",
|
|
5
|
+
"type": "module",
|
|
6
|
+
"main": "./dist/exports/index.js",
|
|
7
|
+
"exports": {
|
|
8
|
+
".": "./dist/exports/index.js",
|
|
9
|
+
"./utils": "./dist/exports/utils.js",
|
|
10
|
+
"./canvas": "./dist/exports/canvas.js",
|
|
11
|
+
"./canvas/shaders": "./dist/exports/canvas-shaders.js",
|
|
12
|
+
"./webgl": "./dist/exports/webgl.js",
|
|
13
|
+
"./webgl/shaders": "./dist/exports/webgl-shaders.js",
|
|
14
|
+
"./inspector": "./dist/exports/inspector.js"
|
|
15
|
+
},
|
|
16
|
+
"scripts": {
|
|
17
|
+
"start": "cd examples && pnpm start",
|
|
18
|
+
"start:prod": "cd examples && pnpm start:prod",
|
|
19
|
+
"build": "tsc --build",
|
|
20
|
+
"build:docker": "cd visual-regression && pnpm build:docker",
|
|
21
|
+
"watch": "tsc --build --watch",
|
|
22
|
+
"test": "vitest",
|
|
23
|
+
"coverage": "vitest run --coverage",
|
|
24
|
+
"test:visual": "cd visual-regression && pnpm test:visual",
|
|
25
|
+
"test:visual:update": "cd visual-regression && pnpm test:visual:update",
|
|
26
|
+
"test:visual:update-ci": "cd visual-regression && pnpm test:visual:update-ci",
|
|
27
|
+
"lint": "pnpm run lint:prettier && pnpm run lint:eslint",
|
|
28
|
+
"lint:fix": "pnpm run lint:fix:prettier && pnpm run lint:fix:eslint",
|
|
29
|
+
"lint:prettier": "prettier --check \"**/*.{ts,js,cjs,md}\"",
|
|
30
|
+
"lint:fix:prettier": "prettier --write \"**/*.{ts,js,cjs,md}\"",
|
|
31
|
+
"lint:eslint": "eslint .",
|
|
32
|
+
"lint:fix:eslint": "eslint --fix .",
|
|
33
|
+
"typedoc": "typedoc",
|
|
34
|
+
"prepare": "husky install",
|
|
35
|
+
"prepack": "pnpm run build",
|
|
36
|
+
"node-version": "node --version",
|
|
37
|
+
"release": "release-it"
|
|
38
|
+
},
|
|
39
|
+
"repository": {
|
|
40
|
+
"type": "git",
|
|
41
|
+
"url": "git+https://github.com/solid-tv/renderer.git"
|
|
42
|
+
},
|
|
43
|
+
"sideEffects": false,
|
|
44
|
+
"keywords": [
|
|
45
|
+
"SolidTV",
|
|
46
|
+
"SolidJS",
|
|
47
|
+
"WebGL",
|
|
48
|
+
"JS",
|
|
49
|
+
"WPE"
|
|
50
|
+
],
|
|
51
|
+
"author": "Chris Lorenzo",
|
|
52
|
+
"license": "Apache-2.0",
|
|
53
|
+
"bugs": {
|
|
54
|
+
"url": "https://github.com/solid-tv/renderer/issues"
|
|
55
|
+
},
|
|
56
|
+
"homepage": "https://github.com/solid-tv/renderer#readme",
|
|
57
|
+
"devDependencies": {
|
|
58
|
+
"@types/node": "^20.19.17",
|
|
59
|
+
"@typescript-eslint/eslint-plugin": "^8.44.0",
|
|
60
|
+
"@typescript-eslint/parser": "^8.44.0",
|
|
61
|
+
"@vitest/coverage-v8": "^2.1.9",
|
|
62
|
+
"concurrently": "^8.2.2",
|
|
63
|
+
"eslint": "^9.36.0",
|
|
64
|
+
"eslint-config-prettier": "^8.10.2",
|
|
65
|
+
"husky": "^8.0.3",
|
|
66
|
+
"lint-staged": "^13.3.0",
|
|
67
|
+
"prettier": "^2.8.8",
|
|
68
|
+
"release-it": "^17.10.0",
|
|
69
|
+
"typedoc": "^0.28.13",
|
|
70
|
+
"typescript": "~5.9.2",
|
|
71
|
+
"vitest": "^2.1.9",
|
|
72
|
+
"vitest-mock-extended": "^2.0.2"
|
|
73
|
+
},
|
|
74
|
+
"lint-staged": {
|
|
75
|
+
"*.ts": [
|
|
76
|
+
"prettier --write",
|
|
77
|
+
"eslint --fix"
|
|
78
|
+
],
|
|
79
|
+
"*.{js,cjs,md}": "prettier --write"
|
|
80
|
+
},
|
|
81
|
+
"files": [
|
|
82
|
+
"dist",
|
|
83
|
+
"src",
|
|
84
|
+
"exports",
|
|
85
|
+
"LICENSE",
|
|
86
|
+
"NOTICE",
|
|
87
|
+
"README.md",
|
|
88
|
+
"scripts"
|
|
89
|
+
],
|
|
90
|
+
"packageManager": "pnpm@10.17.0",
|
|
91
|
+
"engines": {
|
|
92
|
+
"npm": ">= 10.0.0",
|
|
93
|
+
"pnpm": ">= 10.17.0",
|
|
94
|
+
"node": ">= 18.0.0"
|
|
95
|
+
},
|
|
96
|
+
"publishConfig": {
|
|
97
|
+
"access": "public"
|
|
98
|
+
}
|
|
99
|
+
}
|
|
@@ -0,0 +1,145 @@
|
|
|
1
|
+
import type { CoreNodeRenderState } from '../core/CoreNode.js';
|
|
2
|
+
import type { TextureError } from '../core/TextureError.js';
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* Types shared between Main Space and Core Space
|
|
6
|
+
*
|
|
7
|
+
* @remarks
|
|
8
|
+
*
|
|
9
|
+
* @module
|
|
10
|
+
*/
|
|
11
|
+
|
|
12
|
+
/**
|
|
13
|
+
* Represents a width and height.
|
|
14
|
+
*/
|
|
15
|
+
export interface Dimensions {
|
|
16
|
+
w: number;
|
|
17
|
+
h: number;
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
/**
|
|
21
|
+
* Payload for when text is loaded
|
|
22
|
+
*/
|
|
23
|
+
export type NodeTextLoadedPayload = {
|
|
24
|
+
type: 'text';
|
|
25
|
+
dimensions: Dimensions;
|
|
26
|
+
};
|
|
27
|
+
|
|
28
|
+
/**
|
|
29
|
+
* Payload for when texture is loaded
|
|
30
|
+
*/
|
|
31
|
+
export type NodeTextureLoadedPayload = {
|
|
32
|
+
type: 'texture';
|
|
33
|
+
dimensions: Dimensions;
|
|
34
|
+
};
|
|
35
|
+
|
|
36
|
+
/**
|
|
37
|
+
* Combined type for all loaded payloads
|
|
38
|
+
*/
|
|
39
|
+
export type NodeLoadedPayload =
|
|
40
|
+
| NodeTextLoadedPayload
|
|
41
|
+
| NodeTextureLoadedPayload;
|
|
42
|
+
|
|
43
|
+
/**
|
|
44
|
+
* Payload for when text failed to load
|
|
45
|
+
*/
|
|
46
|
+
export type NodeTextFailedPayload = {
|
|
47
|
+
type: 'text';
|
|
48
|
+
error: Error;
|
|
49
|
+
};
|
|
50
|
+
|
|
51
|
+
/**
|
|
52
|
+
* Payload for when texture failed to load
|
|
53
|
+
*/
|
|
54
|
+
export type NodeTextureFailedPayload = {
|
|
55
|
+
type: 'texture';
|
|
56
|
+
error: TextureError;
|
|
57
|
+
};
|
|
58
|
+
|
|
59
|
+
/**
|
|
60
|
+
* Payload for when texture failed to load
|
|
61
|
+
*/
|
|
62
|
+
export type NodeTextureFreedPayload = {
|
|
63
|
+
type: 'texture';
|
|
64
|
+
};
|
|
65
|
+
|
|
66
|
+
/**
|
|
67
|
+
* Payload for when node renderable status changes
|
|
68
|
+
*/
|
|
69
|
+
export type NodeRenderablePayload = {
|
|
70
|
+
type: 'renderable';
|
|
71
|
+
isRenderable: boolean;
|
|
72
|
+
};
|
|
73
|
+
|
|
74
|
+
/**
|
|
75
|
+
* Combined type for all failed payloads
|
|
76
|
+
*/
|
|
77
|
+
export type NodeFailedPayload =
|
|
78
|
+
| NodeTextFailedPayload
|
|
79
|
+
| NodeTextureFailedPayload;
|
|
80
|
+
|
|
81
|
+
/**
|
|
82
|
+
* Event handler for when the texture/text of a node has loaded
|
|
83
|
+
*/
|
|
84
|
+
export type NodeLoadedEventHandler = (
|
|
85
|
+
target: any,
|
|
86
|
+
payload: NodeLoadedPayload,
|
|
87
|
+
) => void;
|
|
88
|
+
|
|
89
|
+
/**
|
|
90
|
+
* Event handler for when the texture/text of a node has failed to load
|
|
91
|
+
*/
|
|
92
|
+
export type NodeFailedEventHandler = (
|
|
93
|
+
target: any,
|
|
94
|
+
payload: NodeFailedPayload,
|
|
95
|
+
) => void;
|
|
96
|
+
|
|
97
|
+
/**
|
|
98
|
+
* Event handler for when the renderable status of a node changes
|
|
99
|
+
*/
|
|
100
|
+
export type NodeRenderableEventHandler = (
|
|
101
|
+
target: any,
|
|
102
|
+
payload: NodeRenderablePayload,
|
|
103
|
+
) => void;
|
|
104
|
+
|
|
105
|
+
export type NodeRenderStatePayload = {
|
|
106
|
+
type: 'renderState';
|
|
107
|
+
payload: CoreNodeRenderState;
|
|
108
|
+
};
|
|
109
|
+
|
|
110
|
+
export type NodeRenderStateEventHandler = (
|
|
111
|
+
target: any,
|
|
112
|
+
payload: NodeRenderStatePayload,
|
|
113
|
+
) => void;
|
|
114
|
+
|
|
115
|
+
/**
|
|
116
|
+
* Event payload for when an FpsUpdate event is emitted by either the Stage or
|
|
117
|
+
* MainRenderer
|
|
118
|
+
*/
|
|
119
|
+
export interface FpsUpdatePayload {
|
|
120
|
+
fps: number;
|
|
121
|
+
contextSpyData: Record<string, number> | null;
|
|
122
|
+
}
|
|
123
|
+
|
|
124
|
+
/**
|
|
125
|
+
* Event payload for when a frame tick event is emitted by the Stage
|
|
126
|
+
*/
|
|
127
|
+
export interface FrameTickPayload {
|
|
128
|
+
time: number;
|
|
129
|
+
delta: number;
|
|
130
|
+
}
|
|
131
|
+
|
|
132
|
+
/**
|
|
133
|
+
* Event payload for when a an animtion tick event is emitted
|
|
134
|
+
*/
|
|
135
|
+
export interface AnimationTickPayload {
|
|
136
|
+
progress: number;
|
|
137
|
+
}
|
|
138
|
+
|
|
139
|
+
/**
|
|
140
|
+
* Event payload for when an RenderUpdate event is emitted by the Stage
|
|
141
|
+
*/
|
|
142
|
+
export interface RenderUpdatePayload {
|
|
143
|
+
quads: number;
|
|
144
|
+
renderOps: number;
|
|
145
|
+
}
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
/* eslint-disable @typescript-eslint/no-unsafe-member-access */
|
|
2
|
+
/* eslint-disable @typescript-eslint/no-unsafe-assignment */
|
|
3
|
+
/* eslint-disable @typescript-eslint/no-unsafe-call */
|
|
4
|
+
/* eslint-disable @typescript-eslint/no-explicit-any */
|
|
5
|
+
import type { IEventEmitter } from './IEventEmitter.js';
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
* EventEmitter base class
|
|
9
|
+
*/
|
|
10
|
+
export class EventEmitter implements IEventEmitter {
|
|
11
|
+
private eventListeners: { [eventName: string]: any } = {};
|
|
12
|
+
|
|
13
|
+
on(event: string, listener: (target: any, data: any) => void): void {
|
|
14
|
+
let listeners = this.eventListeners[event];
|
|
15
|
+
if (!listeners) {
|
|
16
|
+
listeners = [];
|
|
17
|
+
}
|
|
18
|
+
listeners.push(listener);
|
|
19
|
+
this.eventListeners[event] = listeners;
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
off(event: string, listener?: (target: any, data: any) => void): void {
|
|
23
|
+
const listeners = this.eventListeners[event];
|
|
24
|
+
if (!listeners) {
|
|
25
|
+
return;
|
|
26
|
+
}
|
|
27
|
+
if (!listener) {
|
|
28
|
+
delete this.eventListeners[event];
|
|
29
|
+
return;
|
|
30
|
+
}
|
|
31
|
+
const index = listeners.indexOf(listener);
|
|
32
|
+
if (index >= 0) {
|
|
33
|
+
listeners.splice(index, 1);
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
once(event: string, listener: (target: any, data: any) => void): void {
|
|
38
|
+
const onceListener = (target: any, data: any) => {
|
|
39
|
+
this.off(event, onceListener);
|
|
40
|
+
listener(target, data);
|
|
41
|
+
};
|
|
42
|
+
this.on(event, onceListener);
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
emit(event: string, data?: any): void {
|
|
46
|
+
const listeners = this.eventListeners[event];
|
|
47
|
+
if (!listeners) {
|
|
48
|
+
return;
|
|
49
|
+
}
|
|
50
|
+
[...listeners].forEach((listener) => {
|
|
51
|
+
listener(this, data);
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
removeAllListeners() {
|
|
56
|
+
this.eventListeners = {};
|
|
57
|
+
}
|
|
58
|
+
}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
export type AnimationControllerState =
|
|
2
|
+
| 'scheduled'
|
|
3
|
+
| 'running'
|
|
4
|
+
| 'paused'
|
|
5
|
+
| 'stopped';
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
* Animation Controller interface
|
|
9
|
+
*
|
|
10
|
+
* @remarks
|
|
11
|
+
* This interface is used to control animations. It provides methods to start,
|
|
12
|
+
* stop, pause, and restore animations. It also provides a way to wait for the
|
|
13
|
+
* animation to stop.
|
|
14
|
+
*/
|
|
15
|
+
export interface IAnimationController {
|
|
16
|
+
/**
|
|
17
|
+
* Start the animation
|
|
18
|
+
*
|
|
19
|
+
* @remarks
|
|
20
|
+
* If the animation is paused this method will resume the animation.
|
|
21
|
+
*/
|
|
22
|
+
start(): IAnimationController;
|
|
23
|
+
/**
|
|
24
|
+
* Stop the animation
|
|
25
|
+
*
|
|
26
|
+
* @remarks
|
|
27
|
+
* Resets the animation to the start state
|
|
28
|
+
*/
|
|
29
|
+
stop(): IAnimationController;
|
|
30
|
+
/**
|
|
31
|
+
* Pause the animation
|
|
32
|
+
*/
|
|
33
|
+
pause(): IAnimationController;
|
|
34
|
+
/**
|
|
35
|
+
* Restore the animation to the original values
|
|
36
|
+
*/
|
|
37
|
+
restore(): IAnimationController;
|
|
38
|
+
|
|
39
|
+
/**
|
|
40
|
+
* Promise that resolves when the last active animation is stopped (including
|
|
41
|
+
* when the animation finishes naturally).
|
|
42
|
+
*
|
|
43
|
+
* @remarks
|
|
44
|
+
* The Promise returned by this method is reset every time the animation
|
|
45
|
+
* enters a new start/stop cycle. This means you must call `start()` before
|
|
46
|
+
* calling this method if you want to wait for the animation to stop.
|
|
47
|
+
*
|
|
48
|
+
* This method always returns a resolved promise if the animation is currently
|
|
49
|
+
* in a stopped state.
|
|
50
|
+
*
|
|
51
|
+
* @returns
|
|
52
|
+
*/
|
|
53
|
+
waitUntilStopped(): Promise<void>;
|
|
54
|
+
|
|
55
|
+
/**
|
|
56
|
+
* Current state of the animation
|
|
57
|
+
*
|
|
58
|
+
* @remarks
|
|
59
|
+
* - `stopped` - The animation is currently stopped (at the beggining or end
|
|
60
|
+
* of the animation)
|
|
61
|
+
* - `running` - The animation is currently running
|
|
62
|
+
* - `paused` - The animation is currently paused
|
|
63
|
+
*/
|
|
64
|
+
readonly state: AnimationControllerState;
|
|
65
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export interface IEventEmitter<
|
|
2
|
+
T extends object = { [s: string]: (target: any, data: any) => void },
|
|
3
|
+
> {
|
|
4
|
+
on<K extends keyof T>(event: Extract<K, string>, listener: T[K]): void;
|
|
5
|
+
once<K extends keyof T>(event: Extract<K, string>, listener: T[K]): void;
|
|
6
|
+
off<K extends keyof T>(event: Extract<K, string>, listener: T[K]): void;
|
|
7
|
+
emit<K extends keyof T>(
|
|
8
|
+
event: Extract<K, string>,
|
|
9
|
+
data: Parameters<any>[1],
|
|
10
|
+
): void;
|
|
11
|
+
}
|
|
@@ -0,0 +1,205 @@
|
|
|
1
|
+
import { UpdateType, type CoreNode } from './CoreNode.js';
|
|
2
|
+
import type { Coord } from './lib/utils.js';
|
|
3
|
+
|
|
4
|
+
export enum AutosizeMode {
|
|
5
|
+
Children = 0,
|
|
6
|
+
Texture = 1,
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
export enum AutosizeUpdateType {
|
|
10
|
+
None = 0,
|
|
11
|
+
Filtered = 1,
|
|
12
|
+
All = 2,
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
const applyDimensions = (node: CoreNode, w: number, h: number) => {
|
|
16
|
+
node.props.w = w;
|
|
17
|
+
node.props.h = h;
|
|
18
|
+
node.setUpdateType(UpdateType.Local);
|
|
19
|
+
};
|
|
20
|
+
|
|
21
|
+
const getFilteredChildren = (
|
|
22
|
+
children: number[],
|
|
23
|
+
childMap: Map<number, CoreNode>,
|
|
24
|
+
) => {
|
|
25
|
+
const filtered: CoreNode[] = [];
|
|
26
|
+
while (children.length > 0) {
|
|
27
|
+
const id = children.pop()!;
|
|
28
|
+
const child = childMap.get(id)!;
|
|
29
|
+
filtered.push(child);
|
|
30
|
+
}
|
|
31
|
+
return filtered;
|
|
32
|
+
};
|
|
33
|
+
|
|
34
|
+
let autosizerId = 0;
|
|
35
|
+
|
|
36
|
+
export class Autosizer {
|
|
37
|
+
public id = autosizerId++;
|
|
38
|
+
mode: AutosizeMode = AutosizeMode.Children;
|
|
39
|
+
updateType: AutosizeUpdateType = AutosizeUpdateType.All;
|
|
40
|
+
lastWidth: number = 0;
|
|
41
|
+
lastHeight: number = 0;
|
|
42
|
+
lastHasChanged: boolean = false;
|
|
43
|
+
|
|
44
|
+
flaggedChildren: number[] = [];
|
|
45
|
+
childMap: Map<number, CoreNode> = new Map();
|
|
46
|
+
|
|
47
|
+
minX = Infinity;
|
|
48
|
+
minY = Infinity;
|
|
49
|
+
maxX = -Infinity;
|
|
50
|
+
maxY = -Infinity;
|
|
51
|
+
|
|
52
|
+
corners: [Coord, Coord, Coord, Coord] = [
|
|
53
|
+
{ x: 0, y: 0 },
|
|
54
|
+
{ x: 0, y: 0 },
|
|
55
|
+
{ x: 0, y: 0 },
|
|
56
|
+
{ x: 0, y: 0 },
|
|
57
|
+
];
|
|
58
|
+
|
|
59
|
+
constructor(public node: CoreNode) {
|
|
60
|
+
if (node.texture !== null) {
|
|
61
|
+
this.mode = AutosizeMode.Texture;
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
attach(node: CoreNode) {
|
|
66
|
+
this.childMap.set(node.id, node);
|
|
67
|
+
node.parentAutosizer = this;
|
|
68
|
+
|
|
69
|
+
//bubble down to attach to grandchildren
|
|
70
|
+
if (node.children.length > 0 && node.autosizer === null) {
|
|
71
|
+
const children = node.children;
|
|
72
|
+
for (let i = 0; i < children.length; i++) {
|
|
73
|
+
this.attach(children[i]!);
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
detach(node: CoreNode) {
|
|
79
|
+
if (this.childMap.delete(node.id) === true) {
|
|
80
|
+
node.parentAutosizer = null;
|
|
81
|
+
if (node.children.length > 0 && node.autosizer === null) {
|
|
82
|
+
const children = node.children;
|
|
83
|
+
for (let i = 0; i < children.length; i++) {
|
|
84
|
+
this.detach(children[i]!);
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
//detached a child, need full update
|
|
88
|
+
this.setUpdateType(AutosizeUpdateType.All);
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
patch(id: number) {
|
|
93
|
+
const entry = this.childMap.get(id);
|
|
94
|
+
if (entry === undefined) {
|
|
95
|
+
return;
|
|
96
|
+
}
|
|
97
|
+
this.flaggedChildren.push(id);
|
|
98
|
+
this.setUpdateType(AutosizeUpdateType.Filtered);
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
setUpdateType(updateType: AutosizeUpdateType) {
|
|
102
|
+
this.updateType |= updateType;
|
|
103
|
+
this.node.setUpdateType(UpdateType.Autosize);
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
setMode(mode: AutosizeMode) {
|
|
107
|
+
this.mode = mode;
|
|
108
|
+
this.setUpdateType(AutosizeUpdateType.All);
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
update() {
|
|
112
|
+
const node = this.node;
|
|
113
|
+
|
|
114
|
+
if (
|
|
115
|
+
this.mode === AutosizeMode.Texture &&
|
|
116
|
+
node.texture !== null &&
|
|
117
|
+
node.texture.dimensions !== null
|
|
118
|
+
) {
|
|
119
|
+
const { w, h } = node.texture.dimensions;
|
|
120
|
+
if (w !== node.w || h !== node.h) {
|
|
121
|
+
applyDimensions(node, w, h);
|
|
122
|
+
}
|
|
123
|
+
this.lastWidth = w;
|
|
124
|
+
this.lastHeight = h;
|
|
125
|
+
this.updateType = AutosizeUpdateType.None;
|
|
126
|
+
return;
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
let filtered: CoreNode[] =
|
|
130
|
+
this.updateType === AutosizeUpdateType.Filtered
|
|
131
|
+
? getFilteredChildren(this.flaggedChildren, this.childMap)
|
|
132
|
+
: Array.from(this.childMap.values());
|
|
133
|
+
|
|
134
|
+
if (filtered.length === 0) {
|
|
135
|
+
return;
|
|
136
|
+
}
|
|
137
|
+
|
|
138
|
+
const corners = this.corners;
|
|
139
|
+
let minX = this.minX;
|
|
140
|
+
let minY = this.minY;
|
|
141
|
+
let maxX = this.maxX;
|
|
142
|
+
let maxY = this.maxY;
|
|
143
|
+
|
|
144
|
+
for (let i = 0; i < filtered.length; i++) {
|
|
145
|
+
const child = filtered[i]!;
|
|
146
|
+
if (child.isRenderable === false || child.localTransform === undefined) {
|
|
147
|
+
continue;
|
|
148
|
+
}
|
|
149
|
+
|
|
150
|
+
const { tx, ty, ta, tb, tc, td } = child.localTransform;
|
|
151
|
+
const w = child.props.w;
|
|
152
|
+
const h = child.props.h;
|
|
153
|
+
|
|
154
|
+
const childMinX = tx;
|
|
155
|
+
const childMaxX = tx + w * ta;
|
|
156
|
+
const childMinY = ty;
|
|
157
|
+
const childMaxY = ty + h * td;
|
|
158
|
+
|
|
159
|
+
corners[0].x = childMinX;
|
|
160
|
+
corners[0].y = childMinY;
|
|
161
|
+
corners[1].x = childMaxX;
|
|
162
|
+
|
|
163
|
+
//no rotation/scale
|
|
164
|
+
if (tb === 0 && tc === 0) {
|
|
165
|
+
corners[1].y = childMinY;
|
|
166
|
+
corners[2].x = childMaxX;
|
|
167
|
+
corners[2].y = childMaxY;
|
|
168
|
+
corners[3].x = childMinX;
|
|
169
|
+
corners[3].y = childMaxY;
|
|
170
|
+
} else {
|
|
171
|
+
corners[1].y = tx + w * tc;
|
|
172
|
+
corners[2].x = tx + w * ta + h * tb;
|
|
173
|
+
corners[2].y = ty + w * tc + h * td;
|
|
174
|
+
corners[3].x = tx + h * tb;
|
|
175
|
+
corners[3].y = ty + h * td;
|
|
176
|
+
}
|
|
177
|
+
|
|
178
|
+
for (let j = 0; j < 4; j++) {
|
|
179
|
+
const corner = corners[j]!;
|
|
180
|
+
if (corner.x < minX) minX = corner.x;
|
|
181
|
+
if (corner.y < minY) minY = corner.y;
|
|
182
|
+
if (corner.x > maxX) maxX = corner.x;
|
|
183
|
+
if (corner.y > maxY) maxY = corner.y;
|
|
184
|
+
}
|
|
185
|
+
}
|
|
186
|
+
this.updateType = AutosizeUpdateType.None;
|
|
187
|
+
|
|
188
|
+
const newWidth = maxX > 0 ? maxX : 0;
|
|
189
|
+
const newHeight = maxY > 0 ? maxY : 0;
|
|
190
|
+
|
|
191
|
+
applyDimensions(node, newWidth, newHeight);
|
|
192
|
+
this.lastWidth = newWidth;
|
|
193
|
+
this.lastHeight = newHeight;
|
|
194
|
+
}
|
|
195
|
+
|
|
196
|
+
destroy() {
|
|
197
|
+
if (this.childMap.size > 0) {
|
|
198
|
+
for (const child of this.childMap.values()) {
|
|
199
|
+
child.parentAutosizer = null;
|
|
200
|
+
}
|
|
201
|
+
}
|
|
202
|
+
this.childMap.clear();
|
|
203
|
+
this.flaggedChildren.length = 0;
|
|
204
|
+
}
|
|
205
|
+
}
|