@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
|
@@ -0,0 +1,132 @@
|
|
|
1
|
+
import { Platform } from '../Platform.js';
|
|
2
|
+
import type { Stage } from '../../Stage.js';
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* make fontface add not show errors
|
|
6
|
+
*/
|
|
7
|
+
interface FontFaceSetWithAdd extends FontFaceSet {
|
|
8
|
+
add(font: FontFace): void;
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
export class WebPlatform extends Platform {
|
|
12
|
+
////////////////////////
|
|
13
|
+
// Platform-specific methods
|
|
14
|
+
////////////////////////
|
|
15
|
+
|
|
16
|
+
override createCanvas(): HTMLCanvasElement {
|
|
17
|
+
const canvas = document.createElement('canvas');
|
|
18
|
+
return canvas;
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
override getElementById(id: string): HTMLElement | null {
|
|
22
|
+
return document.getElementById(id);
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
////////////////////////
|
|
26
|
+
// Update loop
|
|
27
|
+
////////////////////////
|
|
28
|
+
|
|
29
|
+
override startLoop(stage: Stage): void {
|
|
30
|
+
let isIdle = false;
|
|
31
|
+
let lastFrameTime = 0;
|
|
32
|
+
const buffer = 4;
|
|
33
|
+
|
|
34
|
+
const runLoop = (currentTime: number = 0) => {
|
|
35
|
+
const targetFrameTime = stage.targetFrameTime;
|
|
36
|
+
|
|
37
|
+
// Frame Limiting logic
|
|
38
|
+
if (targetFrameTime > 0) {
|
|
39
|
+
// Calculate elapsed time since the last frame
|
|
40
|
+
const elapsed = currentTime - lastFrameTime;
|
|
41
|
+
|
|
42
|
+
// If not enough time has passed, skip this frame
|
|
43
|
+
if (elapsed < targetFrameTime) {
|
|
44
|
+
const wait = targetFrameTime - elapsed;
|
|
45
|
+
|
|
46
|
+
if (wait > buffer) {
|
|
47
|
+
setTimeout(requestLoop, wait - buffer);
|
|
48
|
+
} else {
|
|
49
|
+
requestAnimationFrame(runLoop);
|
|
50
|
+
}
|
|
51
|
+
return;
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
// Adjust lastFrameTime to maintain the target FPS
|
|
55
|
+
lastFrameTime = currentTime - (elapsed % targetFrameTime);
|
|
56
|
+
} else {
|
|
57
|
+
lastFrameTime = currentTime;
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
stage.updateFrameTime();
|
|
61
|
+
const hasActiveAnimations = stage.updateAnimations();
|
|
62
|
+
|
|
63
|
+
if (!stage.hasSceneUpdates()) {
|
|
64
|
+
// We still need to calculate the fps else it looks like the app is frozen
|
|
65
|
+
stage.calculateFps();
|
|
66
|
+
|
|
67
|
+
// We use 15ms instead of 16.6ms to provide a safety buffer.
|
|
68
|
+
// This ensures we wake up slightly before the next frame to check for updates,
|
|
69
|
+
// preventing us from missing a frame due to timer variances.
|
|
70
|
+
setTimeout(requestLoop, Math.max(targetFrameTime, 15));
|
|
71
|
+
|
|
72
|
+
if (isIdle === false) {
|
|
73
|
+
stage.shManager.cleanup();
|
|
74
|
+
stage.eventBus.emit('idle');
|
|
75
|
+
isIdle = true;
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
if (stage.txMemManager.checkCleanup() === true) {
|
|
79
|
+
stage.txMemManager.cleanup();
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
stage.flushFrameEvents();
|
|
83
|
+
return;
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
isIdle = false;
|
|
87
|
+
stage.drawFrame(hasActiveAnimations);
|
|
88
|
+
stage.flushFrameEvents();
|
|
89
|
+
|
|
90
|
+
// Schedule next frame
|
|
91
|
+
requestAnimationFrame(runLoop);
|
|
92
|
+
};
|
|
93
|
+
|
|
94
|
+
const requestLoop = () => requestAnimationFrame(runLoop);
|
|
95
|
+
|
|
96
|
+
requestAnimationFrame(runLoop);
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
////////////////////////
|
|
100
|
+
// ImageBitmap
|
|
101
|
+
////////////////////////
|
|
102
|
+
|
|
103
|
+
override createImageBitmap(
|
|
104
|
+
blob: ImageBitmapSource,
|
|
105
|
+
sxOrOptions?: number | ImageBitmapOptions,
|
|
106
|
+
sy?: number,
|
|
107
|
+
sw?: number,
|
|
108
|
+
sh?: number,
|
|
109
|
+
options?: ImageBitmapOptions,
|
|
110
|
+
): Promise<ImageBitmap> {
|
|
111
|
+
if (typeof sxOrOptions === 'number') {
|
|
112
|
+
return createImageBitmap(
|
|
113
|
+
blob,
|
|
114
|
+
sxOrOptions,
|
|
115
|
+
sy ?? 0,
|
|
116
|
+
sw ?? 0,
|
|
117
|
+
sh ?? 0,
|
|
118
|
+
options,
|
|
119
|
+
);
|
|
120
|
+
} else {
|
|
121
|
+
return createImageBitmap(blob, sxOrOptions);
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
|
|
125
|
+
getTimeStamp(): number {
|
|
126
|
+
return Date.now();
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
override addFont(font: FontFace): void {
|
|
130
|
+
(document.fonts as FontFaceSetWithAdd).add(font);
|
|
131
|
+
}
|
|
132
|
+
}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import type { TextureMemoryManager } from '../TextureMemoryManager.js';
|
|
2
|
+
import type { Texture } from '../textures/Texture.js';
|
|
3
|
+
|
|
4
|
+
export abstract class CoreContextTexture {
|
|
5
|
+
readonly textureSource: Texture;
|
|
6
|
+
private memManager: TextureMemoryManager;
|
|
7
|
+
public state: 'freed' | 'loading' | 'loaded' | 'failed' = 'freed';
|
|
8
|
+
|
|
9
|
+
constructor(memManager: TextureMemoryManager, textureSource: Texture) {
|
|
10
|
+
this.memManager = memManager;
|
|
11
|
+
this.textureSource = textureSource;
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
protected setTextureMemUse(byteSize: number): void {
|
|
15
|
+
this.memManager.setTextureMemUse(this.textureSource, byteSize);
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
abstract load(): Promise<void>;
|
|
19
|
+
abstract release(): void;
|
|
20
|
+
abstract free(): void;
|
|
21
|
+
|
|
22
|
+
get renderable(): boolean {
|
|
23
|
+
return this.textureSource.renderable;
|
|
24
|
+
}
|
|
25
|
+
}
|
|
@@ -0,0 +1,101 @@
|
|
|
1
|
+
import type { Dimensions } from '../../common/CommonTypes.js';
|
|
2
|
+
import type { CoreNode } from '../CoreNode.js';
|
|
3
|
+
import type { TextureOptions } from '../CoreTextureManager.js';
|
|
4
|
+
import type { Stage } from '../Stage.js';
|
|
5
|
+
import type { ContextSpy } from '../lib/ContextSpy.js';
|
|
6
|
+
import type { RenderCoords } from '../lib/RenderCoords.js';
|
|
7
|
+
import type { RectWithValid } from '../lib/utils.js';
|
|
8
|
+
import type { CoreShaderProgram } from './CoreShaderProgram.js';
|
|
9
|
+
import type { Texture, TextureCoords } from '../textures/Texture.js';
|
|
10
|
+
import { CoreContextTexture } from './CoreContextTexture.js';
|
|
11
|
+
import type { CoreShaderType, CoreShaderNode } from './CoreShaderNode.js';
|
|
12
|
+
|
|
13
|
+
export interface QuadOptions {
|
|
14
|
+
width: number;
|
|
15
|
+
height: number;
|
|
16
|
+
colorTl: number;
|
|
17
|
+
colorTr: number;
|
|
18
|
+
colorBl: number;
|
|
19
|
+
colorBr: number;
|
|
20
|
+
texture: Texture | null;
|
|
21
|
+
textureOptions: TextureOptions | null;
|
|
22
|
+
textureCoords: TextureCoords | undefined;
|
|
23
|
+
zIndex: number;
|
|
24
|
+
shader: CoreShaderNode | null;
|
|
25
|
+
alpha: number;
|
|
26
|
+
clippingRect: RectWithValid;
|
|
27
|
+
tx: number;
|
|
28
|
+
ty: number;
|
|
29
|
+
ta: number;
|
|
30
|
+
tb: number;
|
|
31
|
+
tc: number;
|
|
32
|
+
td: number;
|
|
33
|
+
renderCoords?: RenderCoords;
|
|
34
|
+
rtt: boolean;
|
|
35
|
+
parentHasRenderTexture: boolean;
|
|
36
|
+
framebufferDimensions: Dimensions | null;
|
|
37
|
+
time?: number | null;
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
export interface CoreRendererOptions {
|
|
41
|
+
stage: Stage;
|
|
42
|
+
canvas: HTMLCanvasElement | OffscreenCanvas;
|
|
43
|
+
contextSpy: ContextSpy | null;
|
|
44
|
+
forceWebGL2: boolean;
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
export interface BufferInfo {
|
|
48
|
+
totalUsed: number;
|
|
49
|
+
totalAvailable: number;
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
export abstract class CoreRenderer {
|
|
53
|
+
public options: CoreRendererOptions;
|
|
54
|
+
public mode: 'webgl' | 'canvas' | undefined;
|
|
55
|
+
defaultTextureCoords: TextureCoords | undefined = undefined;
|
|
56
|
+
readonly stage: Stage;
|
|
57
|
+
|
|
58
|
+
//// Core Managers
|
|
59
|
+
rttNodes: CoreNode[] = [];
|
|
60
|
+
|
|
61
|
+
constructor(options: CoreRendererOptions) {
|
|
62
|
+
this.options = options;
|
|
63
|
+
this.stage = options.stage;
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
abstract reset(): void;
|
|
67
|
+
abstract render(surface?: 'screen' | CoreContextTexture): void;
|
|
68
|
+
abstract addQuad(node: CoreNode): void;
|
|
69
|
+
abstract createCtxTexture(textureSource: Texture): CoreContextTexture;
|
|
70
|
+
abstract createShaderProgram(
|
|
71
|
+
shaderConfig: Readonly<CoreShaderType>,
|
|
72
|
+
props?: Record<string, unknown>,
|
|
73
|
+
): CoreShaderProgram | null;
|
|
74
|
+
abstract createShaderNode(
|
|
75
|
+
shaderKey: string,
|
|
76
|
+
shaderType: Readonly<CoreShaderType>,
|
|
77
|
+
props?: Record<string, unknown>,
|
|
78
|
+
program?: CoreShaderProgram,
|
|
79
|
+
): CoreShaderNode;
|
|
80
|
+
abstract supportsShaderType(shaderType: Readonly<CoreShaderType>): boolean;
|
|
81
|
+
abstract getDefaultShaderNode(): CoreShaderNode | null;
|
|
82
|
+
abstract get renderToTextureActive(): boolean;
|
|
83
|
+
abstract get activeRttNode(): CoreNode | null;
|
|
84
|
+
abstract renderRTTNodes(): void;
|
|
85
|
+
abstract removeRTTNode(node: CoreNode): void;
|
|
86
|
+
abstract renderToTexture(node: CoreNode): void;
|
|
87
|
+
abstract getBufferInfo(): BufferInfo | null;
|
|
88
|
+
abstract getQuadCount(): number | null;
|
|
89
|
+
abstract getRenderOpCount(): number | null;
|
|
90
|
+
abstract updateViewport(): void;
|
|
91
|
+
abstract updateClearColor(color: number): void;
|
|
92
|
+
getTextureCoords?(node: CoreNode): TextureCoords | undefined;
|
|
93
|
+
|
|
94
|
+
/**
|
|
95
|
+
* Optional hook called when the render list changes structurally
|
|
96
|
+
* (node added / removed / reordered). Implementations may use this to
|
|
97
|
+
* invalidate any cached GPU buffer layouts and force a full re-upload
|
|
98
|
+
* on the next render call.
|
|
99
|
+
*/
|
|
100
|
+
invalidateQuadBuffer?(): void;
|
|
101
|
+
}
|
|
@@ -0,0 +1,202 @@
|
|
|
1
|
+
import { deepClone } from '../../utils.js';
|
|
2
|
+
import { UpdateType, type CoreNode } from '../CoreNode.js';
|
|
3
|
+
import type { Stage } from '../Stage.js';
|
|
4
|
+
|
|
5
|
+
export interface AdvShaderProp<T = any, Props = Record<string, unknown>> {
|
|
6
|
+
/**
|
|
7
|
+
* default value
|
|
8
|
+
*/
|
|
9
|
+
default: T;
|
|
10
|
+
resolve?: (this: AdvShaderProp<T, Props>, value: T, props: Props) => T;
|
|
11
|
+
transform?: (start: T, end: T, progress: number) => T;
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
export type AdvancedShaderProp<T = any, Props = Record<string, unknown>> =
|
|
15
|
+
| (AdvShaderProp<T, Props> & {
|
|
16
|
+
set: (value: T, props: Props) => void;
|
|
17
|
+
get: (props: Props) => T;
|
|
18
|
+
})
|
|
19
|
+
| (AdvShaderProp<T, Props> & { set?: never; get?: never });
|
|
20
|
+
|
|
21
|
+
export type ShaderProp<T, Props> = T | AdvancedShaderProp<T, Props>;
|
|
22
|
+
|
|
23
|
+
export type ShaderProps<Props> = {
|
|
24
|
+
[K in keyof Props]: ShaderProp<Props[K], Props>;
|
|
25
|
+
};
|
|
26
|
+
|
|
27
|
+
export function isAdvancedShaderProp(obj: any): obj is AdvancedShaderProp {
|
|
28
|
+
return obj !== null && typeof obj === 'object' && obj.default !== undefined;
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
export function resolveShaderProps(
|
|
32
|
+
props: Record<string, unknown>,
|
|
33
|
+
propsConfig: ShaderProps<Record<string, unknown>>,
|
|
34
|
+
) {
|
|
35
|
+
for (const key in propsConfig) {
|
|
36
|
+
if (!isAdvancedShaderProp(propsConfig[key]) && props[key] === undefined) {
|
|
37
|
+
props[key] = propsConfig[key];
|
|
38
|
+
continue;
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
const pConfig = propsConfig[key]! as AdvancedShaderProp;
|
|
42
|
+
const hasValue = props[key] !== undefined;
|
|
43
|
+
|
|
44
|
+
if (pConfig.resolve !== undefined) {
|
|
45
|
+
props[key] = pConfig.resolve!(props[key], props);
|
|
46
|
+
continue;
|
|
47
|
+
}
|
|
48
|
+
if (hasValue && pConfig.set !== undefined) {
|
|
49
|
+
pConfig.set(props[key], props);
|
|
50
|
+
continue;
|
|
51
|
+
}
|
|
52
|
+
if (hasValue) {
|
|
53
|
+
continue;
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
if (props[key] === undefined && pConfig.get === undefined) {
|
|
57
|
+
props[key] = deepClone(pConfig.default);
|
|
58
|
+
continue;
|
|
59
|
+
}
|
|
60
|
+
props[key] = pConfig.get!(props);
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
/**
|
|
65
|
+
* CoreShaderType is a template for ShaderTypes the renderer.
|
|
66
|
+
* You could view a ShaderType as a configuration object that contains methods,
|
|
67
|
+
* and values that you can use to alter the way a node is drawn by the Renderer.
|
|
68
|
+
*/
|
|
69
|
+
export interface CoreShaderType<Props extends object = any> {
|
|
70
|
+
/**
|
|
71
|
+
* Values you use to draw the Shader
|
|
72
|
+
*/
|
|
73
|
+
props?: ShaderProps<Props>;
|
|
74
|
+
/**
|
|
75
|
+
* used for making a cache key to check for reusability, currently only used for webgl ShaderTypes but might be needed for other types of renderer
|
|
76
|
+
*/
|
|
77
|
+
getCacheMarkers?: (props: Props) => string;
|
|
78
|
+
/**
|
|
79
|
+
* timer that updates every loop, by default uses the stage elapsed time If you want to do a special calculation you can define a function.
|
|
80
|
+
* When you calculate your own value you can use the Stage timing values deltaTime, lastFrameTime, and currentFrameTime;
|
|
81
|
+
*/
|
|
82
|
+
time?: boolean | ((stage: Stage) => number);
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
/**
|
|
86
|
+
* CoreShaderNode is a base class that manages the shader prop values.
|
|
87
|
+
* When a prop is being updated the CoreShaderNode will notify either the associated CoreNode,
|
|
88
|
+
* or the Stage that there has been a change and a new render of the scene.
|
|
89
|
+
*/
|
|
90
|
+
export class CoreShaderNode<Props extends object = Record<string, unknown>> {
|
|
91
|
+
readonly stage: Stage;
|
|
92
|
+
readonly shaderType: CoreShaderType<Props>;
|
|
93
|
+
protected propsConfig: ShaderProps<Props> | undefined;
|
|
94
|
+
readonly resolvedProps: Props | undefined = undefined;
|
|
95
|
+
protected definedProps: Props | undefined = undefined;
|
|
96
|
+
protected node: CoreNode | null = null;
|
|
97
|
+
readonly time: CoreShaderType['time'] = undefined;
|
|
98
|
+
update: (() => void) | undefined = undefined;
|
|
99
|
+
private _valueKeyCache = '';
|
|
100
|
+
private _valueKeyDirty = true;
|
|
101
|
+
private _lastW = 0;
|
|
102
|
+
private _lastH = 0;
|
|
103
|
+
|
|
104
|
+
constructor(
|
|
105
|
+
readonly shaderKey: string,
|
|
106
|
+
type: CoreShaderType<Props>,
|
|
107
|
+
stage: Stage,
|
|
108
|
+
props?: Props,
|
|
109
|
+
) {
|
|
110
|
+
this.stage = stage;
|
|
111
|
+
this.shaderType = type;
|
|
112
|
+
this.time = type.time;
|
|
113
|
+
|
|
114
|
+
if (props !== undefined) {
|
|
115
|
+
/**
|
|
116
|
+
* props are already resolved by shadermanager
|
|
117
|
+
*/
|
|
118
|
+
this.resolvedProps = props;
|
|
119
|
+
this.defineProps(props);
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
private defineProps(props: Props) {
|
|
124
|
+
const definedProps = {};
|
|
125
|
+
for (const key in props) {
|
|
126
|
+
const propConfig = this.shaderType.props![key];
|
|
127
|
+
const isAdvancedProp = isAdvancedShaderProp(propConfig);
|
|
128
|
+
|
|
129
|
+
Object.defineProperty(definedProps, key, {
|
|
130
|
+
get: () => {
|
|
131
|
+
return this.resolvedProps![key as keyof Props];
|
|
132
|
+
},
|
|
133
|
+
set: (value) => {
|
|
134
|
+
// this.resolvedProps![key as keyof Props] = value;
|
|
135
|
+
if (isAdvancedProp === true && propConfig.resolve !== undefined) {
|
|
136
|
+
this.resolvedProps![key] = propConfig.resolve(
|
|
137
|
+
value,
|
|
138
|
+
this.resolvedProps as Record<string, unknown>,
|
|
139
|
+
);
|
|
140
|
+
} else if (isAdvancedProp === true && propConfig.set !== undefined) {
|
|
141
|
+
propConfig.set(
|
|
142
|
+
value,
|
|
143
|
+
this.resolvedProps as Record<string, unknown>,
|
|
144
|
+
);
|
|
145
|
+
} else {
|
|
146
|
+
this.resolvedProps![key] = value;
|
|
147
|
+
}
|
|
148
|
+
this._valueKeyDirty = true;
|
|
149
|
+
|
|
150
|
+
if (this.update !== undefined && this.node !== null) {
|
|
151
|
+
this.node.setUpdateType(UpdateType.RecalcUniforms);
|
|
152
|
+
} else {
|
|
153
|
+
this.stage.requestRender();
|
|
154
|
+
}
|
|
155
|
+
},
|
|
156
|
+
});
|
|
157
|
+
}
|
|
158
|
+
this.definedProps = definedProps as Props;
|
|
159
|
+
}
|
|
160
|
+
|
|
161
|
+
attachNode(node: CoreNode) {
|
|
162
|
+
this.node = node;
|
|
163
|
+
}
|
|
164
|
+
|
|
165
|
+
createValueKey() {
|
|
166
|
+
if (
|
|
167
|
+
this._valueKeyDirty === false &&
|
|
168
|
+
this.node !== null &&
|
|
169
|
+
this.node.w === this._lastW &&
|
|
170
|
+
this.node.h === this._lastH
|
|
171
|
+
) {
|
|
172
|
+
return this._valueKeyCache;
|
|
173
|
+
}
|
|
174
|
+
|
|
175
|
+
let valueKey = '';
|
|
176
|
+
for (const key in this.resolvedProps) {
|
|
177
|
+
valueKey += `${key}:${this.resolvedProps[key]!};`;
|
|
178
|
+
}
|
|
179
|
+
valueKey += `node-width:${this.node!.w}`;
|
|
180
|
+
valueKey += `node-height:${this.node!.h}`;
|
|
181
|
+
|
|
182
|
+
this._valueKeyCache = valueKey;
|
|
183
|
+
this._valueKeyDirty = false;
|
|
184
|
+
this._lastW = this.node!.w;
|
|
185
|
+
this._lastH = this.node!.h;
|
|
186
|
+
|
|
187
|
+
return valueKey;
|
|
188
|
+
}
|
|
189
|
+
|
|
190
|
+
get props(): Props | undefined {
|
|
191
|
+
return this.definedProps;
|
|
192
|
+
}
|
|
193
|
+
|
|
194
|
+
set props(props: Props | undefined) {
|
|
195
|
+
if (props === undefined) {
|
|
196
|
+
return;
|
|
197
|
+
}
|
|
198
|
+
for (const key in props) {
|
|
199
|
+
this.props![key] = props[key];
|
|
200
|
+
}
|
|
201
|
+
}
|
|
202
|
+
}
|