@lightningjs/renderer 0.9.3 → 1.0.0-rc.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/README.md +0 -82
- package/dist/exports/index.d.ts +40 -3
- package/dist/exports/index.js +35 -3
- package/dist/exports/index.js.map +1 -1
- package/dist/src/core/CoreNode.d.ts +462 -46
- package/dist/src/core/CoreNode.js +171 -103
- package/dist/src/core/CoreNode.js.map +1 -1
- package/dist/src/core/CoreShaderManager.d.ts +19 -8
- package/dist/src/core/CoreShaderManager.js +21 -21
- package/dist/src/core/CoreShaderManager.js.map +1 -1
- package/dist/src/core/CoreTextNode.d.ts +30 -4
- package/dist/src/core/CoreTextNode.js +24 -1
- package/dist/src/core/CoreTextNode.js.map +1 -1
- package/dist/src/core/CoreTextureManager.d.ts +31 -82
- package/dist/src/core/CoreTextureManager.js +39 -126
- package/dist/src/core/CoreTextureManager.js.map +1 -1
- package/dist/src/core/Stage.d.ts +67 -9
- package/dist/src/core/Stage.js +174 -30
- package/dist/src/core/Stage.js.map +1 -1
- package/dist/src/core/TextureMemoryManager.d.ts +97 -8
- package/dist/src/core/TextureMemoryManager.js +142 -19
- package/dist/src/core/TextureMemoryManager.js.map +1 -1
- package/dist/src/core/animations/CoreAnimation.d.ts +14 -6
- package/dist/src/core/animations/CoreAnimation.js +136 -44
- package/dist/src/core/animations/CoreAnimation.js.map +1 -1
- package/dist/src/core/lib/ImageWorker.js +59 -52
- package/dist/src/core/lib/ImageWorker.js.map +1 -1
- package/dist/src/core/lib/utils.d.ts +1 -0
- package/dist/src/core/lib/utils.js +3 -2
- package/dist/src/core/lib/utils.js.map +1 -1
- package/dist/src/core/platform.js +7 -1
- package/dist/src/core/platform.js.map +1 -1
- package/dist/src/core/renderers/CoreContextTexture.d.ts +3 -2
- package/dist/src/core/renderers/CoreContextTexture.js +7 -1
- package/dist/src/core/renderers/CoreContextTexture.js.map +1 -1
- package/dist/src/core/renderers/CoreRenderer.d.ts +5 -1
- package/dist/src/core/renderers/CoreRenderer.js +0 -1
- package/dist/src/core/renderers/CoreRenderer.js.map +1 -1
- package/dist/src/core/renderers/canvas/CanvasCoreRenderer.d.ts +3 -0
- package/dist/src/core/renderers/canvas/CanvasCoreRenderer.js +16 -1
- package/dist/src/core/renderers/canvas/CanvasCoreRenderer.js.map +1 -1
- package/dist/src/core/renderers/canvas/CanvasCoreTexture.d.ts +0 -1
- package/dist/src/core/renderers/canvas/CanvasCoreTexture.js +2 -5
- package/dist/src/core/renderers/canvas/CanvasCoreTexture.js.map +1 -1
- package/dist/src/core/renderers/webgl/WebGlCoreCtxRenderTexture.js +2 -2
- package/dist/src/core/renderers/webgl/WebGlCoreCtxRenderTexture.js.map +1 -1
- package/dist/src/core/renderers/webgl/WebGlCoreCtxTexture.d.ts +0 -1
- package/dist/src/core/renderers/webgl/WebGlCoreCtxTexture.js +7 -10
- package/dist/src/core/renderers/webgl/WebGlCoreCtxTexture.js.map +1 -1
- package/dist/src/core/renderers/webgl/WebGlCoreRenderer.d.ts +3 -0
- package/dist/src/core/renderers/webgl/WebGlCoreRenderer.js +47 -9
- package/dist/src/core/renderers/webgl/WebGlCoreRenderer.js.map +1 -1
- package/dist/src/core/renderers/webgl/newShader/abcMock.js +2 -0
- package/dist/src/core/renderers/webgl/newShader/abcMock.js.map +1 -0
- package/dist/src/core/renderers/webgl/shaders/DynamicShader.d.ts +24 -8
- package/dist/src/core/renderers/webgl/shaders/DynamicShader.js +70 -37
- package/dist/src/core/renderers/webgl/shaders/DynamicShader.js.map +1 -1
- package/dist/src/core/renderers/webgl/shaders/effects/BorderBottomEffect.js +2 -2
- package/dist/src/core/renderers/webgl/shaders/effects/BorderBottomEffect.js.map +1 -1
- package/dist/src/core/renderers/webgl/shaders/effects/BorderEffect.js +2 -2
- package/dist/src/core/renderers/webgl/shaders/effects/BorderEffect.js.map +1 -1
- package/dist/src/core/renderers/webgl/shaders/effects/BorderLeftEffect.js +2 -2
- package/dist/src/core/renderers/webgl/shaders/effects/BorderLeftEffect.js.map +1 -1
- package/dist/src/core/renderers/webgl/shaders/effects/BorderRightEffect.js +2 -2
- package/dist/src/core/renderers/webgl/shaders/effects/BorderRightEffect.js.map +1 -1
- package/dist/src/core/renderers/webgl/shaders/effects/BorderTopEffect.js +2 -2
- package/dist/src/core/renderers/webgl/shaders/effects/BorderTopEffect.js.map +1 -1
- package/dist/src/core/renderers/webgl/shaders/effects/EffectUtils.d.ts +8 -0
- package/dist/src/core/renderers/webgl/shaders/effects/EffectUtils.js +103 -0
- package/dist/src/core/renderers/webgl/shaders/effects/EffectUtils.js.map +1 -1
- package/dist/src/core/renderers/webgl/shaders/effects/FadeOutEffect.js +3 -18
- package/dist/src/core/renderers/webgl/shaders/effects/FadeOutEffect.js.map +1 -1
- package/dist/src/core/renderers/webgl/shaders/effects/GlitchEffect.js +5 -2
- package/dist/src/core/renderers/webgl/shaders/effects/GlitchEffect.js.map +1 -1
- package/dist/src/core/renderers/webgl/shaders/effects/HolePunchEffect.js +4 -36
- package/dist/src/core/renderers/webgl/shaders/effects/HolePunchEffect.js.map +1 -1
- package/dist/src/core/renderers/webgl/shaders/effects/LinearGradientEffect.js +3 -2
- package/dist/src/core/renderers/webgl/shaders/effects/LinearGradientEffect.js.map +1 -1
- package/dist/src/core/renderers/webgl/shaders/effects/RadialGradientEffect.js +4 -2
- package/dist/src/core/renderers/webgl/shaders/effects/RadialGradientEffect.js.map +1 -1
- package/dist/src/core/renderers/webgl/shaders/effects/RadialProgressEffect.js +2 -1
- package/dist/src/core/renderers/webgl/shaders/effects/RadialProgressEffect.js.map +1 -1
- package/dist/src/core/renderers/webgl/shaders/effects/RadiusEffect.js +4 -36
- package/dist/src/core/renderers/webgl/shaders/effects/RadiusEffect.js.map +1 -1
- package/dist/src/core/renderers/webgl/shaders/effects/ShaderEffect.d.ts +11 -0
- package/dist/src/core/renderers/webgl/shaders/effects/ShaderEffect.js.map +1 -1
- package/dist/src/core/text-rendering/font-face-types/SdfTrFontFace/SdfTrFontFace.js +5 -2
- package/dist/src/core/text-rendering/font-face-types/SdfTrFontFace/SdfTrFontFace.js.map +1 -1
- package/dist/src/core/text-rendering/font-face-types/TrFontFace.d.ts +0 -1
- package/dist/src/core/text-rendering/font-face-types/TrFontFace.js +0 -1
- package/dist/src/core/text-rendering/font-face-types/TrFontFace.js.map +1 -1
- package/dist/src/core/text-rendering/font-face-types/WebTrFontFace.js +0 -1
- package/dist/src/core/text-rendering/font-face-types/WebTrFontFace.js.map +1 -1
- package/dist/src/core/text-rendering/renderers/CanvasTextRenderer.d.ts +10 -26
- package/dist/src/core/text-rendering/renderers/CanvasTextRenderer.js +116 -365
- package/dist/src/core/text-rendering/renderers/CanvasTextRenderer.js.map +1 -1
- package/dist/src/core/text-rendering/renderers/LightningTextTextureRenderer.d.ts +0 -1
- package/dist/src/core/text-rendering/renderers/LightningTextTextureRenderer.js +0 -2
- package/dist/src/core/text-rendering/renderers/LightningTextTextureRenderer.js.map +1 -1
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.js +2 -2
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.js.map +1 -1
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText.js +2 -0
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText.js.map +1 -1
- package/dist/src/core/text-rendering/renderers/TextRenderer.d.ts +3 -2
- 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 +1 -1
- package/dist/src/core/textures/ImageTexture.d.ts +1 -1
- package/dist/src/core/textures/NoiseTexture.d.ts +1 -1
- package/dist/src/core/textures/NoiseTexture.js +3 -0
- package/dist/src/core/textures/NoiseTexture.js.map +1 -1
- package/dist/src/core/textures/SubTexture.d.ts +2 -2
- package/dist/src/core/textures/SubTexture.js +5 -1
- package/dist/src/core/textures/SubTexture.js.map +1 -1
- package/dist/src/core/textures/Texture.d.ts +23 -2
- package/dist/src/core/textures/Texture.js +32 -3
- package/dist/src/core/textures/Texture.js.map +1 -1
- package/dist/src/core/utils.d.ts +7 -0
- package/dist/src/core/utils.js +12 -10
- package/dist/src/core/utils.js.map +1 -1
- package/dist/src/effectsMock.d.ts +13 -0
- package/dist/src/effectsMock.js +62 -0
- package/dist/src/effectsMock.js.map +1 -0
- package/dist/src/main-api/DynamicShaderController.d.ts +28 -0
- package/dist/src/main-api/DynamicShaderController.js +55 -0
- package/dist/src/main-api/DynamicShaderController.js.map +1 -0
- package/dist/src/main-api/INode.d.ts +43 -463
- package/dist/src/main-api/INode.js +1 -19
- package/dist/src/main-api/INode.js.map +1 -1
- package/dist/src/main-api/Inspector.d.ts +10 -10
- package/dist/src/main-api/Inspector.js +18 -15
- package/dist/src/main-api/Inspector.js.map +1 -1
- package/dist/src/main-api/Renderer.d.ts +28 -24
- package/dist/src/main-api/Renderer.js +22 -103
- 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/test.js +4 -0
- package/dist/src/test.js.map +1 -0
- package/dist/src/utils.d.ts +1 -0
- package/dist/src/utils.js +7 -0
- package/dist/src/utils.js.map +1 -1
- package/dist/tsconfig.dist.tsbuildinfo +1 -1
- package/exports/index.ts +60 -3
- package/package.json +8 -7
- package/src/core/CoreNode.test.ts +93 -0
- package/src/core/CoreNode.ts +675 -187
- package/src/core/CoreShaderManager.ts +63 -31
- package/src/core/CoreTextNode.ts +41 -9
- package/src/core/CoreTextureManager.ts +55 -175
- package/src/core/Stage.ts +199 -43
- package/src/core/TextureMemoryManager.ts +231 -22
- package/src/core/animations/CoreAnimation.ts +193 -68
- package/src/core/lib/ImageWorker.ts +79 -52
- package/src/core/lib/utils.ts +5 -2
- package/src/core/platform.ts +8 -1
- package/src/core/renderers/CoreContextTexture.ts +9 -2
- package/src/core/renderers/CoreRenderer.ts +5 -2
- package/src/core/renderers/canvas/CanvasCoreRenderer.ts +20 -1
- package/src/core/renderers/canvas/CanvasCoreTexture.ts +2 -6
- package/src/core/renderers/webgl/WebGlCoreCtxRenderTexture.ts +2 -2
- package/src/core/renderers/webgl/WebGlCoreCtxTexture.ts +7 -11
- package/src/core/renderers/webgl/WebGlCoreRenderer.ts +51 -9
- package/src/core/renderers/webgl/shaders/DynamicShader.ts +114 -55
- package/src/core/renderers/webgl/shaders/effects/BorderBottomEffect.ts +2 -2
- package/src/core/renderers/webgl/shaders/effects/BorderEffect.ts +2 -2
- package/src/core/renderers/webgl/shaders/effects/BorderLeftEffect.ts +2 -2
- package/src/core/renderers/webgl/shaders/effects/BorderRightEffect.ts +2 -2
- package/src/core/renderers/webgl/shaders/effects/BorderTopEffect.ts +2 -2
- package/src/core/renderers/webgl/shaders/effects/EffectUtils.ts +129 -3
- package/src/core/renderers/webgl/shaders/effects/FadeOutEffect.ts +7 -15
- package/src/core/renderers/webgl/shaders/effects/GlitchEffect.ts +5 -2
- package/src/core/renderers/webgl/shaders/effects/HolePunchEffect.ts +6 -15
- package/src/core/renderers/webgl/shaders/effects/LinearGradientEffect.ts +6 -2
- package/src/core/renderers/webgl/shaders/effects/RadialGradientEffect.ts +10 -2
- package/src/core/renderers/webgl/shaders/effects/RadialProgressEffect.ts +2 -1
- package/src/core/renderers/webgl/shaders/effects/RadiusEffect.ts +6 -15
- package/src/core/renderers/webgl/shaders/effects/ShaderEffect.ts +20 -0
- package/src/core/text-rendering/font-face-types/SdfTrFontFace/SdfTrFontFace.ts +14 -15
- package/src/core/text-rendering/font-face-types/TrFontFace.ts +0 -2
- package/src/core/text-rendering/font-face-types/WebTrFontFace.ts +0 -1
- package/src/core/text-rendering/renderers/CanvasTextRenderer.ts +139 -447
- package/src/core/text-rendering/renderers/LightningTextTextureRenderer.ts +0 -3
- package/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.ts +2 -2
- package/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText.ts +4 -2
- package/src/core/text-rendering/renderers/TextRenderer.ts +3 -2
- package/src/core/textures/ColorTexture.ts +1 -1
- package/src/core/textures/ImageTexture.ts +1 -1
- package/src/core/textures/NoiseTexture.ts +4 -1
- package/src/core/textures/SubTexture.ts +7 -7
- package/src/core/textures/Texture.ts +46 -3
- package/src/core/utils.ts +12 -11
- package/src/main-api/DynamicShaderController.ts +97 -0
- package/src/main-api/INode.ts +56 -479
- package/src/main-api/Inspector.ts +37 -39
- package/src/main-api/Renderer.ts +543 -0
- package/src/main-api/ShaderController.ts +81 -0
- package/src/main-api/utils.ts +45 -0
- package/src/utils.ts +8 -0
- package/dist/exports/core-api.d.ts +0 -74
- package/dist/exports/core-api.js +0 -96
- package/dist/exports/core-api.js.map +0 -1
- package/dist/exports/main-api.d.ts +0 -30
- package/dist/exports/main-api.js +0 -45
- package/dist/exports/main-api.js.map +0 -1
- package/dist/src/core/CoreExtension.d.ts +0 -12
- package/dist/src/core/CoreExtension.js +0 -29
- package/dist/src/core/CoreExtension.js.map +0 -1
- package/dist/src/core/renderers/webgl/newShader/effectsMock.js +0 -36
- package/dist/src/core/renderers/webgl/newShader/effectsMock.js.map +0 -1
- package/dist/src/main-api/ICoreDriver.d.ts +0 -24
- package/dist/src/main-api/ICoreDriver.js +0 -20
- package/dist/src/main-api/ICoreDriver.js.map +0 -1
- package/dist/src/main-api/RendererMain.d.ts +0 -378
- package/dist/src/main-api/RendererMain.js +0 -367
- package/dist/src/main-api/RendererMain.js.map +0 -1
- package/dist/src/main-api/texture-usage-trackers/FinalizationRegistryTextureUsageTracker.d.ts +0 -9
- package/dist/src/main-api/texture-usage-trackers/FinalizationRegistryTextureUsageTracker.js +0 -38
- package/dist/src/main-api/texture-usage-trackers/FinalizationRegistryTextureUsageTracker.js.map +0 -1
- package/dist/src/main-api/texture-usage-trackers/ManualCountTextureUsageTracker.d.ts +0 -56
- package/dist/src/main-api/texture-usage-trackers/ManualCountTextureUsageTracker.js +0 -101
- package/dist/src/main-api/texture-usage-trackers/ManualCountTextureUsageTracker.js.map +0 -1
- package/dist/src/main-api/texture-usage-trackers/TextureUsageTracker.d.ts +0 -32
- package/dist/src/main-api/texture-usage-trackers/TextureUsageTracker.js +0 -28
- package/dist/src/main-api/texture-usage-trackers/TextureUsageTracker.js.map +0 -1
- package/dist/src/render-drivers/main/MainCoreDriver.d.ts +0 -21
- package/dist/src/render-drivers/main/MainCoreDriver.js +0 -115
- package/dist/src/render-drivers/main/MainCoreDriver.js.map +0 -1
- package/dist/src/render-drivers/main/MainOnlyNode.d.ts +0 -101
- package/dist/src/render-drivers/main/MainOnlyNode.js +0 -425
- package/dist/src/render-drivers/main/MainOnlyNode.js.map +0 -1
- package/dist/src/render-drivers/main/MainOnlyTextNode.d.ts +0 -47
- package/dist/src/render-drivers/main/MainOnlyTextNode.js +0 -204
- package/dist/src/render-drivers/main/MainOnlyTextNode.js.map +0 -1
- package/dist/src/render-drivers/threadx/NodeStruct.d.ts +0 -93
- package/dist/src/render-drivers/threadx/NodeStruct.js +0 -290
- package/dist/src/render-drivers/threadx/NodeStruct.js.map +0 -1
- package/dist/src/render-drivers/threadx/SharedNode.d.ts +0 -40
- package/dist/src/render-drivers/threadx/SharedNode.js +0 -61
- package/dist/src/render-drivers/threadx/SharedNode.js.map +0 -1
- package/dist/src/render-drivers/threadx/TextNodeStruct.d.ts +0 -44
- package/dist/src/render-drivers/threadx/TextNodeStruct.js +0 -203
- package/dist/src/render-drivers/threadx/TextNodeStruct.js.map +0 -1
- package/dist/src/render-drivers/threadx/ThreadXCoreDriver.d.ts +0 -25
- package/dist/src/render-drivers/threadx/ThreadXCoreDriver.js +0 -232
- package/dist/src/render-drivers/threadx/ThreadXCoreDriver.js.map +0 -1
- package/dist/src/render-drivers/threadx/ThreadXMainAnimationController.d.ts +0 -24
- package/dist/src/render-drivers/threadx/ThreadXMainAnimationController.js +0 -113
- package/dist/src/render-drivers/threadx/ThreadXMainAnimationController.js.map +0 -1
- package/dist/src/render-drivers/threadx/ThreadXMainNode.d.ts +0 -46
- package/dist/src/render-drivers/threadx/ThreadXMainNode.js +0 -160
- package/dist/src/render-drivers/threadx/ThreadXMainNode.js.map +0 -1
- package/dist/src/render-drivers/threadx/ThreadXMainTextNode.d.ts +0 -28
- package/dist/src/render-drivers/threadx/ThreadXMainTextNode.js +0 -55
- package/dist/src/render-drivers/threadx/ThreadXMainTextNode.js.map +0 -1
- package/dist/src/render-drivers/threadx/ThreadXRendererMessage.d.ts +0 -70
- package/dist/src/render-drivers/threadx/ThreadXRendererMessage.js +0 -32
- package/dist/src/render-drivers/threadx/ThreadXRendererMessage.js.map +0 -1
- package/dist/src/render-drivers/threadx/worker/ThreadXRendererNode.d.ts +0 -19
- package/dist/src/render-drivers/threadx/worker/ThreadXRendererNode.js +0 -184
- package/dist/src/render-drivers/threadx/worker/ThreadXRendererNode.js.map +0 -1
- package/dist/src/render-drivers/threadx/worker/ThreadXRendererTextNode.d.ts +0 -27
- package/dist/src/render-drivers/threadx/worker/ThreadXRendererTextNode.js +0 -109
- package/dist/src/render-drivers/threadx/worker/ThreadXRendererTextNode.js.map +0 -1
- package/dist/src/render-drivers/threadx/worker/renderer.js +0 -147
- package/dist/src/render-drivers/threadx/worker/renderer.js.map +0 -1
- package/dist/src/render-drivers/utils.d.ts +0 -12
- package/dist/src/render-drivers/utils.js +0 -74
- package/dist/src/render-drivers/utils.js.map +0 -1
- package/exports/core-api.ts +0 -102
- package/exports/main-api.ts +0 -60
- package/src/core/CoreExtension.ts +0 -32
- package/src/main-api/ICoreDriver.ts +0 -68
- package/src/main-api/RendererMain.ts +0 -685
- package/src/main-api/texture-usage-trackers/FinalizationRegistryTextureUsageTracker.ts +0 -45
- package/src/main-api/texture-usage-trackers/ManualCountTextureUsageTracker.ts +0 -154
- package/src/main-api/texture-usage-trackers/TextureUsageTracker.ts +0 -54
- package/src/render-drivers/main/MainCoreDriver.ts +0 -159
- package/src/render-drivers/main/MainOnlyNode.ts +0 -553
- package/src/render-drivers/main/MainOnlyTextNode.ts +0 -261
- package/src/render-drivers/threadx/NodeStruct.ts +0 -320
- package/src/render-drivers/threadx/SharedNode.ts +0 -101
- package/src/render-drivers/threadx/TextNodeStruct.ts +0 -213
- package/src/render-drivers/threadx/ThreadXCoreDriver.ts +0 -291
- package/src/render-drivers/threadx/ThreadXMainAnimationController.ts +0 -135
- package/src/render-drivers/threadx/ThreadXMainNode.ts +0 -201
- package/src/render-drivers/threadx/ThreadXMainTextNode.ts +0 -85
- package/src/render-drivers/threadx/ThreadXRendererMessage.ts +0 -112
- package/src/render-drivers/threadx/worker/ThreadXRendererNode.ts +0 -253
- package/src/render-drivers/threadx/worker/ThreadXRendererTextNode.ts +0 -151
- package/src/render-drivers/threadx/worker/renderer.ts +0 -156
- package/src/render-drivers/utils.ts +0 -102
- /package/dist/src/core/renderers/webgl/newShader/{effectsMock.d.ts → abcMock.d.ts} +0 -0
- /package/dist/src/{render-drivers/threadx/worker/renderer.d.ts → test.d.ts} +0 -0
package/src/core/CoreNode.ts
CHANGED
|
@@ -19,17 +19,11 @@
|
|
|
19
19
|
|
|
20
20
|
import {
|
|
21
21
|
assertTruthy,
|
|
22
|
+
getNewId,
|
|
22
23
|
mergeColorAlphaPremultiplied,
|
|
23
|
-
getImageAspectRatio,
|
|
24
24
|
} from '../utils.js';
|
|
25
|
-
import type {
|
|
26
|
-
import type {
|
|
27
|
-
ExtractProps,
|
|
28
|
-
TextureMap,
|
|
29
|
-
TextureOptions,
|
|
30
|
-
} from './CoreTextureManager.js';
|
|
25
|
+
import type { TextureOptions } from './CoreTextureManager.js';
|
|
31
26
|
import type { CoreRenderer } from './renderers/CoreRenderer.js';
|
|
32
|
-
import type { CoreShader } from './renderers/CoreShader.js';
|
|
33
27
|
import type { Stage } from './Stage.js';
|
|
34
28
|
import type {
|
|
35
29
|
Texture,
|
|
@@ -37,7 +31,6 @@ import type {
|
|
|
37
31
|
TextureFreedEventHandler,
|
|
38
32
|
TextureLoadedEventHandler,
|
|
39
33
|
} from './textures/Texture.js';
|
|
40
|
-
import { RenderTexture } from './textures/RenderTexture.js';
|
|
41
34
|
import type {
|
|
42
35
|
Dimensions,
|
|
43
36
|
NodeTextureFailedPayload,
|
|
@@ -55,6 +48,11 @@ import {
|
|
|
55
48
|
} from './lib/utils.js';
|
|
56
49
|
import { Matrix3d } from './lib/Matrix3d.js';
|
|
57
50
|
import { RenderCoords } from './lib/RenderCoords.js';
|
|
51
|
+
import type { AnimationSettings } from './animations/CoreAnimation.js';
|
|
52
|
+
import type { IAnimationController } from '../common/IAnimationController.js';
|
|
53
|
+
import { CoreAnimation } from './animations/CoreAnimation.js';
|
|
54
|
+
import { CoreAnimationController } from './animations/CoreAnimationController.js';
|
|
55
|
+
import type { BaseShaderController } from '../main-api/ShaderController.js';
|
|
58
56
|
|
|
59
57
|
export enum CoreNodeRenderState {
|
|
60
58
|
Init = 0,
|
|
@@ -69,50 +67,6 @@ CoreNodeRenderStateMap.set(CoreNodeRenderState.OutOfBounds, 'outOfBounds');
|
|
|
69
67
|
CoreNodeRenderStateMap.set(CoreNodeRenderState.InBounds, 'inBounds');
|
|
70
68
|
CoreNodeRenderStateMap.set(CoreNodeRenderState.InViewport, 'inViewport');
|
|
71
69
|
|
|
72
|
-
export interface CoreNodeProps {
|
|
73
|
-
id: number;
|
|
74
|
-
// External facing properties whose defaults are determined by
|
|
75
|
-
// RendererMain's resolveNodeDefaults() method
|
|
76
|
-
x: number;
|
|
77
|
-
y: number;
|
|
78
|
-
width: number;
|
|
79
|
-
height: number;
|
|
80
|
-
alpha: number;
|
|
81
|
-
autosize: boolean;
|
|
82
|
-
clipping: boolean;
|
|
83
|
-
color: number;
|
|
84
|
-
colorTop: number;
|
|
85
|
-
colorBottom: number;
|
|
86
|
-
colorLeft: number;
|
|
87
|
-
colorRight: number;
|
|
88
|
-
colorTl: number;
|
|
89
|
-
colorTr: number;
|
|
90
|
-
colorBl: number;
|
|
91
|
-
colorBr: number;
|
|
92
|
-
parent: CoreNode | null;
|
|
93
|
-
zIndex: number;
|
|
94
|
-
texture: Texture | null;
|
|
95
|
-
textureOptions: TextureOptions | null;
|
|
96
|
-
shader: CoreShader | null;
|
|
97
|
-
shaderProps: Record<string, unknown> | null;
|
|
98
|
-
zIndexLocked: number;
|
|
99
|
-
scaleX: number;
|
|
100
|
-
scaleY: number;
|
|
101
|
-
mount: number;
|
|
102
|
-
mountX: number;
|
|
103
|
-
mountY: number;
|
|
104
|
-
pivot: number;
|
|
105
|
-
pivotX: number;
|
|
106
|
-
pivotY: number;
|
|
107
|
-
rotation: number;
|
|
108
|
-
rtt: boolean;
|
|
109
|
-
}
|
|
110
|
-
|
|
111
|
-
type ICoreNode = Omit<
|
|
112
|
-
CoreNodeProps,
|
|
113
|
-
'texture' | 'textureOptions' | 'shader' | 'shaderProps'
|
|
114
|
-
>;
|
|
115
|
-
|
|
116
70
|
export enum UpdateType {
|
|
117
71
|
/**
|
|
118
72
|
* Child updates
|
|
@@ -235,9 +189,462 @@ export enum UpdateType {
|
|
|
235
189
|
All = 8191,
|
|
236
190
|
}
|
|
237
191
|
|
|
238
|
-
|
|
192
|
+
/**
|
|
193
|
+
* A custom data map which can be stored on an CoreNode
|
|
194
|
+
*
|
|
195
|
+
* @remarks
|
|
196
|
+
* This is a map of key-value pairs that can be stored on an INode. It is used
|
|
197
|
+
* to store custom data that can be used by the application.
|
|
198
|
+
* The data stored can only be of type string, number or boolean.
|
|
199
|
+
*/
|
|
200
|
+
export type CustomDataMap = {
|
|
201
|
+
[key: string]: string | number | boolean | undefined;
|
|
202
|
+
};
|
|
203
|
+
|
|
204
|
+
/**
|
|
205
|
+
* Writable properties of a Node.
|
|
206
|
+
*/
|
|
207
|
+
export interface CoreNodeProps {
|
|
208
|
+
/**
|
|
209
|
+
* The x coordinate of the Node's Mount Point.
|
|
210
|
+
*
|
|
211
|
+
* @remarks
|
|
212
|
+
* See {@link mountX} and {@link mountY} for more information about setting
|
|
213
|
+
* the Mount Point.
|
|
214
|
+
*
|
|
215
|
+
* @default `0`
|
|
216
|
+
*/
|
|
217
|
+
x: number;
|
|
218
|
+
/**
|
|
219
|
+
* The y coordinate of the Node's Mount Point.
|
|
220
|
+
*
|
|
221
|
+
* @remarks
|
|
222
|
+
* See {@link mountX} and {@link mountY} for more information about setting
|
|
223
|
+
* the Mount Point.
|
|
224
|
+
*
|
|
225
|
+
* @default `0`
|
|
226
|
+
*/
|
|
227
|
+
y: number;
|
|
228
|
+
/**
|
|
229
|
+
* The width of the Node.
|
|
230
|
+
*
|
|
231
|
+
* @default `0`
|
|
232
|
+
*/
|
|
233
|
+
width: number;
|
|
234
|
+
/**
|
|
235
|
+
* The height of the Node.
|
|
236
|
+
*
|
|
237
|
+
* @default `0`
|
|
238
|
+
*/
|
|
239
|
+
height: number;
|
|
240
|
+
/**
|
|
241
|
+
* The alpha opacity of the Node.
|
|
242
|
+
*
|
|
243
|
+
* @remarks
|
|
244
|
+
* The alpha value is a number between 0 and 1, where 0 is fully transparent
|
|
245
|
+
* and 1 is fully opaque.
|
|
246
|
+
*
|
|
247
|
+
* @default `1`
|
|
248
|
+
*/
|
|
249
|
+
alpha: number;
|
|
250
|
+
/**
|
|
251
|
+
* Autosize mode
|
|
252
|
+
*
|
|
253
|
+
* @remarks
|
|
254
|
+
* When enabled, when a texture is loaded into the Node, the Node will
|
|
255
|
+
* automatically resize to the dimensions of the texture.
|
|
256
|
+
*
|
|
257
|
+
* Text Nodes are always autosized based on their text content regardless
|
|
258
|
+
* of this mode setting.
|
|
259
|
+
*
|
|
260
|
+
* @default `false`
|
|
261
|
+
*/
|
|
262
|
+
autosize: boolean;
|
|
263
|
+
/**
|
|
264
|
+
* Clipping Mode
|
|
265
|
+
*
|
|
266
|
+
* @remarks
|
|
267
|
+
* Enable Clipping Mode when you want to prevent the drawing of a Node and
|
|
268
|
+
* its descendants from overflowing outside of the Node's x/y/width/height
|
|
269
|
+
* bounds.
|
|
270
|
+
*
|
|
271
|
+
* For WebGL, clipping is implemented using the high-performance WebGL
|
|
272
|
+
* operation scissor. As a consequence, clipping does not work for
|
|
273
|
+
* non-rectangular areas. So, if the element is rotated
|
|
274
|
+
* (by itself or by any of its ancestors), clipping will not work as intended.
|
|
275
|
+
*
|
|
276
|
+
* TODO: Add support for non-rectangular clipping either automatically or
|
|
277
|
+
* via Render-To-Texture.
|
|
278
|
+
*
|
|
279
|
+
* @default `false`
|
|
280
|
+
*/
|
|
281
|
+
clipping: boolean;
|
|
282
|
+
/**
|
|
283
|
+
* The color of the Node.
|
|
284
|
+
*
|
|
285
|
+
* @remarks
|
|
286
|
+
* The color value is a number in the format 0xRRGGBBAA, where RR is the red
|
|
287
|
+
* component, GG is the green component, BB is the blue component, and AA is
|
|
288
|
+
* the alpha component.
|
|
289
|
+
*
|
|
290
|
+
* Gradient colors may be set by setting the different color sub-properties:
|
|
291
|
+
* {@link colorTop}, {@link colorBottom}, {@link colorLeft}, {@link colorRight},
|
|
292
|
+
* {@link colorTl}, {@link colorTr}, {@link colorBr}, {@link colorBl} accordingly.
|
|
293
|
+
*
|
|
294
|
+
* @default `0xffffffff` (opaque white)
|
|
295
|
+
*/
|
|
296
|
+
color: number;
|
|
297
|
+
/**
|
|
298
|
+
* The color of the top edge of the Node for gradient rendering.
|
|
299
|
+
*
|
|
300
|
+
* @remarks
|
|
301
|
+
* See {@link color} for more information about color values and gradient
|
|
302
|
+
* rendering.
|
|
303
|
+
*/
|
|
304
|
+
colorTop: number;
|
|
305
|
+
/**
|
|
306
|
+
* The color of the bottom edge of the Node for gradient rendering.
|
|
307
|
+
*
|
|
308
|
+
* @remarks
|
|
309
|
+
* See {@link color} for more information about color values and gradient
|
|
310
|
+
* rendering.
|
|
311
|
+
*/
|
|
312
|
+
colorBottom: number;
|
|
313
|
+
/**
|
|
314
|
+
* The color of the left edge of the Node for gradient rendering.
|
|
315
|
+
*
|
|
316
|
+
* @remarks
|
|
317
|
+
* See {@link color} for more information about color values and gradient
|
|
318
|
+
* rendering.
|
|
319
|
+
*/
|
|
320
|
+
colorLeft: number;
|
|
321
|
+
/**
|
|
322
|
+
* The color of the right edge of the Node for gradient rendering.
|
|
323
|
+
*
|
|
324
|
+
* @remarks
|
|
325
|
+
* See {@link color} for more information about color values and gradient
|
|
326
|
+
* rendering.
|
|
327
|
+
*/
|
|
328
|
+
colorRight: number;
|
|
329
|
+
/**
|
|
330
|
+
* The color of the top-left corner of the Node for gradient rendering.
|
|
331
|
+
*
|
|
332
|
+
* @remarks
|
|
333
|
+
* See {@link color} for more information about color values and gradient
|
|
334
|
+
* rendering.
|
|
335
|
+
*/
|
|
336
|
+
colorTl: number;
|
|
337
|
+
/**
|
|
338
|
+
* The color of the top-right corner of the Node for gradient rendering.
|
|
339
|
+
*
|
|
340
|
+
* @remarks
|
|
341
|
+
* See {@link color} for more information about color values and gradient
|
|
342
|
+
* rendering.
|
|
343
|
+
*/
|
|
344
|
+
colorTr: number;
|
|
345
|
+
/**
|
|
346
|
+
* The color of the bottom-right corner of the Node for gradient rendering.
|
|
347
|
+
*
|
|
348
|
+
* @remarks
|
|
349
|
+
* See {@link color} for more information about color values and gradient
|
|
350
|
+
* rendering.
|
|
351
|
+
*/
|
|
352
|
+
colorBr: number;
|
|
353
|
+
/**
|
|
354
|
+
* The color of the bottom-left corner of the Node for gradient rendering.
|
|
355
|
+
*
|
|
356
|
+
* @remarks
|
|
357
|
+
* See {@link color} for more information about color values and gradient
|
|
358
|
+
* rendering.
|
|
359
|
+
*/
|
|
360
|
+
colorBl: number;
|
|
361
|
+
/**
|
|
362
|
+
* The Node's parent Node.
|
|
363
|
+
*
|
|
364
|
+
* @remarks
|
|
365
|
+
* The value `null` indicates that the Node has no parent. This may either be
|
|
366
|
+
* because the Node is the root Node of the scene graph, or because the Node
|
|
367
|
+
* has been removed from the scene graph.
|
|
368
|
+
*
|
|
369
|
+
* In order to make sure that a Node can be rendered on the screen, it must
|
|
370
|
+
* be added to the scene graph by setting it's parent property to a Node that
|
|
371
|
+
* is already in the scene graph such as the root Node.
|
|
372
|
+
*
|
|
373
|
+
* @default `null`
|
|
374
|
+
*/
|
|
375
|
+
parent: CoreNode | null;
|
|
376
|
+
/**
|
|
377
|
+
* The Node's z-index.
|
|
378
|
+
*
|
|
379
|
+
* @remarks
|
|
380
|
+
* TBD
|
|
381
|
+
*/
|
|
382
|
+
zIndex: number;
|
|
383
|
+
/**
|
|
384
|
+
* The Node's Texture.
|
|
385
|
+
*
|
|
386
|
+
* @remarks
|
|
387
|
+
* The `texture` defines a rasterized image that is contained within the
|
|
388
|
+
* {@link width} and {@link height} dimensions of the Node. If null, the
|
|
389
|
+
* Node will use an opaque white {@link ColorTexture} when being drawn, which
|
|
390
|
+
* essentially enables colors (including gradients) to be drawn.
|
|
391
|
+
*
|
|
392
|
+
* If set, by default, the texture will be drawn, as is, stretched to the
|
|
393
|
+
* dimensions of the Node. This behavior can be modified by setting the TBD
|
|
394
|
+
* and TBD properties.
|
|
395
|
+
*
|
|
396
|
+
* To create a Texture in order to set it on this property, call
|
|
397
|
+
* {@link RendererMain.createTexture}.
|
|
398
|
+
*
|
|
399
|
+
* If the {@link src} is set on a Node, the Node will use the
|
|
400
|
+
* {@link ImageTexture} by default and the Node will simply load the image at
|
|
401
|
+
* the specified URL.
|
|
402
|
+
*
|
|
403
|
+
* Note: If this is a Text Node, the Texture will be managed by the Node's
|
|
404
|
+
* {@link TextRenderer} and should not be set explicitly.
|
|
405
|
+
*/
|
|
406
|
+
texture: Texture | null;
|
|
407
|
+
|
|
408
|
+
/**
|
|
409
|
+
* Options to associate with the Node's Texture
|
|
410
|
+
*/
|
|
411
|
+
textureOptions: TextureOptions;
|
|
412
|
+
|
|
413
|
+
/**
|
|
414
|
+
* The Node's shader
|
|
415
|
+
*
|
|
416
|
+
* @remarks
|
|
417
|
+
* The `shader` defines a {@link Shader} used to draw the Node. By default,
|
|
418
|
+
* the Default Shader is used which simply draws the defined {@link texture}
|
|
419
|
+
* or {@link color}(s) within the Node without any special effects.
|
|
420
|
+
*
|
|
421
|
+
* To create a Shader in order to set it on this property, call
|
|
422
|
+
* {@link RendererMain.createShader}.
|
|
423
|
+
*
|
|
424
|
+
* Note: If this is a Text Node, the Shader will be managed by the Node's
|
|
425
|
+
* {@link TextRenderer} and should not be set explicitly.
|
|
426
|
+
*/
|
|
427
|
+
shader: BaseShaderController;
|
|
428
|
+
/**
|
|
429
|
+
* Image URL
|
|
430
|
+
*
|
|
431
|
+
* @remarks
|
|
432
|
+
* When set, the Node's {@link texture} is automatically set to an
|
|
433
|
+
* {@link ImageTexture} using the source image URL provided (with all other
|
|
434
|
+
* settings being defaults)
|
|
435
|
+
*/
|
|
436
|
+
src: string | null;
|
|
437
|
+
zIndexLocked: number;
|
|
438
|
+
/**
|
|
439
|
+
* Scale to render the Node at
|
|
440
|
+
*
|
|
441
|
+
* @remarks
|
|
442
|
+
* The scale value multiplies the provided {@link width} and {@link height}
|
|
443
|
+
* of the Node around the Node's Pivot Point (defined by the {@link pivot}
|
|
444
|
+
* props).
|
|
445
|
+
*
|
|
446
|
+
* Behind the scenes, setting this property sets both the {@link scaleX} and
|
|
447
|
+
* {@link scaleY} props to the same value.
|
|
448
|
+
*
|
|
449
|
+
* NOTE: When the scaleX and scaleY props are explicitly set to different values,
|
|
450
|
+
* this property returns `null`. Setting `null` on this property will have no
|
|
451
|
+
* effect.
|
|
452
|
+
*
|
|
453
|
+
* @default 1.0
|
|
454
|
+
*/
|
|
455
|
+
scale: number | null;
|
|
456
|
+
/**
|
|
457
|
+
* Scale to render the Node at (X-Axis)
|
|
458
|
+
*
|
|
459
|
+
* @remarks
|
|
460
|
+
* The scaleX value multiplies the provided {@link width} of the Node around
|
|
461
|
+
* the Node's Pivot Point (defined by the {@link pivot} props).
|
|
462
|
+
*
|
|
463
|
+
* @default 1.0
|
|
464
|
+
*/
|
|
465
|
+
scaleX: number;
|
|
466
|
+
/**
|
|
467
|
+
* Scale to render the Node at (Y-Axis)
|
|
468
|
+
*
|
|
469
|
+
* @remarks
|
|
470
|
+
* The scaleY value multiplies the provided {@link height} of the Node around
|
|
471
|
+
* the Node's Pivot Point (defined by the {@link pivot} props).
|
|
472
|
+
*
|
|
473
|
+
* @default 1.0
|
|
474
|
+
*/
|
|
475
|
+
scaleY: number;
|
|
476
|
+
/**
|
|
477
|
+
* Combined position of the Node's Mount Point
|
|
478
|
+
*
|
|
479
|
+
* @remarks
|
|
480
|
+
* The value can be any number between `0.0` and `1.0`:
|
|
481
|
+
* - `0.0` defines the Mount Point at the top-left corner of the Node.
|
|
482
|
+
* - `0.5` defines it at the center of the Node.
|
|
483
|
+
* - `1.0` defines it at the bottom-right corner of the node.
|
|
484
|
+
*
|
|
485
|
+
* Use the {@link mountX} and {@link mountY} props seperately for more control
|
|
486
|
+
* of the Mount Point.
|
|
487
|
+
*
|
|
488
|
+
* When assigned, the same value is also passed to both the {@link mountX} and
|
|
489
|
+
* {@link mountY} props.
|
|
490
|
+
*
|
|
491
|
+
* @default 0 (top-left)
|
|
492
|
+
*/
|
|
493
|
+
mount: number;
|
|
494
|
+
/**
|
|
495
|
+
* X position of the Node's Mount Point
|
|
496
|
+
*
|
|
497
|
+
* @remarks
|
|
498
|
+
* The value can be any number between `0.0` and `1.0`:
|
|
499
|
+
* - `0.0` defines the Mount Point's X position as the left-most edge of the
|
|
500
|
+
* Node
|
|
501
|
+
* - `0.5` defines it as the horizontal center of the Node
|
|
502
|
+
* - `1.0` defines it as the right-most edge of the Node.
|
|
503
|
+
*
|
|
504
|
+
* The combination of {@link mountX} and {@link mountY} define the Mount Point
|
|
505
|
+
*
|
|
506
|
+
* @default 0 (left-most edge)
|
|
507
|
+
*/
|
|
508
|
+
mountX: number;
|
|
509
|
+
/**
|
|
510
|
+
* Y position of the Node's Mount Point
|
|
511
|
+
*
|
|
512
|
+
* @remarks
|
|
513
|
+
* The value can be any number between `0.0` and `1.0`:
|
|
514
|
+
* - `0.0` defines the Mount Point's Y position as the top-most edge of the
|
|
515
|
+
* Node
|
|
516
|
+
* - `0.5` defines it as the vertical center of the Node
|
|
517
|
+
* - `1.0` defines it as the bottom-most edge of the Node.
|
|
518
|
+
*
|
|
519
|
+
* The combination of {@link mountX} and {@link mountY} define the Mount Point
|
|
520
|
+
*
|
|
521
|
+
* @default 0 (top-most edge)
|
|
522
|
+
*/
|
|
523
|
+
mountY: number;
|
|
524
|
+
/**
|
|
525
|
+
* Combined position of the Node's Pivot Point
|
|
526
|
+
*
|
|
527
|
+
* @remarks
|
|
528
|
+
* The value can be any number between `0.0` and `1.0`:
|
|
529
|
+
* - `0.0` defines the Pivot Point at the top-left corner of the Node.
|
|
530
|
+
* - `0.5` defines it at the center of the Node.
|
|
531
|
+
* - `1.0` defines it at the bottom-right corner of the node.
|
|
532
|
+
*
|
|
533
|
+
* Use the {@link pivotX} and {@link pivotY} props seperately for more control
|
|
534
|
+
* of the Pivot Point.
|
|
535
|
+
*
|
|
536
|
+
* When assigned, the same value is also passed to both the {@link pivotX} and
|
|
537
|
+
* {@link pivotY} props.
|
|
538
|
+
*
|
|
539
|
+
* @default 0.5 (center)
|
|
540
|
+
*/
|
|
541
|
+
pivot: number;
|
|
542
|
+
/**
|
|
543
|
+
* X position of the Node's Pivot Point
|
|
544
|
+
*
|
|
545
|
+
* @remarks
|
|
546
|
+
* The value can be any number between `0.0` and `1.0`:
|
|
547
|
+
* - `0.0` defines the Pivot Point's X position as the left-most edge of the
|
|
548
|
+
* Node
|
|
549
|
+
* - `0.5` defines it as the horizontal center of the Node
|
|
550
|
+
* - `1.0` defines it as the right-most edge of the Node.
|
|
551
|
+
*
|
|
552
|
+
* The combination of {@link pivotX} and {@link pivotY} define the Pivot Point
|
|
553
|
+
*
|
|
554
|
+
* @default 0.5 (centered on x-axis)
|
|
555
|
+
*/
|
|
556
|
+
pivotX: number;
|
|
557
|
+
/**
|
|
558
|
+
* Y position of the Node's Pivot Point
|
|
559
|
+
*
|
|
560
|
+
* @remarks
|
|
561
|
+
* The value can be any number between `0.0` and `1.0`:
|
|
562
|
+
* - `0.0` defines the Pivot Point's Y position as the top-most edge of the
|
|
563
|
+
* Node
|
|
564
|
+
* - `0.5` defines it as the vertical center of the Node
|
|
565
|
+
* - `1.0` defines it as the bottom-most edge of the Node.
|
|
566
|
+
*
|
|
567
|
+
* The combination of {@link pivotX} and {@link pivotY} define the Pivot Point
|
|
568
|
+
*
|
|
569
|
+
* @default 0.5 (centered on y-axis)
|
|
570
|
+
*/
|
|
571
|
+
pivotY: number;
|
|
572
|
+
/**
|
|
573
|
+
* Rotation of the Node (in Radians)
|
|
574
|
+
*
|
|
575
|
+
* @remarks
|
|
576
|
+
* Sets the amount to rotate the Node by around it's Pivot Point (defined by
|
|
577
|
+
* the {@link pivot} props). Positive values rotate the Node clockwise, while
|
|
578
|
+
* negative values rotate it counter-clockwise.
|
|
579
|
+
*
|
|
580
|
+
* Example values:
|
|
581
|
+
* - `-Math.PI / 2`: 90 degree rotation counter-clockwise
|
|
582
|
+
* - `0`: No rotation
|
|
583
|
+
* - `Math.PI / 2`: 90 degree rotation clockwise
|
|
584
|
+
* - `Math.PI`: 180 degree rotation clockwise
|
|
585
|
+
* - `3 * Math.PI / 2`: 270 degree rotation clockwise
|
|
586
|
+
* - `2 * Math.PI`: 360 rotation clockwise
|
|
587
|
+
*/
|
|
588
|
+
rotation: number;
|
|
589
|
+
|
|
590
|
+
/**
|
|
591
|
+
* Whether the Node is rendered to a texture
|
|
592
|
+
*
|
|
593
|
+
* @remarks
|
|
594
|
+
* TBD
|
|
595
|
+
*
|
|
596
|
+
* @default false
|
|
597
|
+
*/
|
|
598
|
+
rtt: boolean;
|
|
599
|
+
|
|
600
|
+
/**
|
|
601
|
+
* Node data element for custom data storage (optional)
|
|
602
|
+
*
|
|
603
|
+
* @remarks
|
|
604
|
+
* This property is used to store custom data on the Node as a key/value data store.
|
|
605
|
+
* Data values are limited to string, numbers, booleans. Strings will be truncated
|
|
606
|
+
* to a 2048 character limit for performance reasons.
|
|
607
|
+
*
|
|
608
|
+
* This is not a data storage mechanism for large amounts of data please use a
|
|
609
|
+
* dedicated data storage mechanism for that.
|
|
610
|
+
*
|
|
611
|
+
* The custom data will be reflected in the inspector as part of `data-*` attributes
|
|
612
|
+
*
|
|
613
|
+
* @default `undefined`
|
|
614
|
+
*/
|
|
615
|
+
data?: CustomDataMap;
|
|
616
|
+
}
|
|
617
|
+
|
|
618
|
+
/**
|
|
619
|
+
* Grab all the number properties of type T
|
|
620
|
+
*/
|
|
621
|
+
type NumberProps<T> = {
|
|
622
|
+
[Key in keyof T as NonNullable<T[Key]> extends number ? Key : never]: number;
|
|
623
|
+
};
|
|
624
|
+
|
|
625
|
+
/**
|
|
626
|
+
* Properties of a Node used by the animate() function
|
|
627
|
+
*/
|
|
628
|
+
export interface CoreNodeAnimateProps extends NumberProps<CoreNodeProps> {
|
|
629
|
+
/**
|
|
630
|
+
* Shader properties to animate
|
|
631
|
+
*/
|
|
632
|
+
shaderProps: Record<string, number>;
|
|
633
|
+
// TODO: textureProps: Record<string, number>;
|
|
634
|
+
}
|
|
635
|
+
|
|
636
|
+
/**
|
|
637
|
+
* A visual Node in the Renderer scene graph.
|
|
638
|
+
*
|
|
639
|
+
* @remarks
|
|
640
|
+
* CoreNode is an internally used class that represents a Renderer Node in the
|
|
641
|
+
* scene graph. See INode.ts for the public APIs exposed to Renderer users
|
|
642
|
+
* that include generic types for Shaders.
|
|
643
|
+
*/
|
|
644
|
+
export class CoreNode extends EventEmitter {
|
|
239
645
|
readonly children: CoreNode[] = [];
|
|
240
|
-
protected
|
|
646
|
+
protected _id: number = getNewId();
|
|
647
|
+
readonly props: Required<CoreNodeProps>;
|
|
241
648
|
|
|
242
649
|
public updateType = UpdateType.All;
|
|
243
650
|
|
|
@@ -266,48 +673,53 @@ export class CoreNode extends EventEmitter implements ICoreNode {
|
|
|
266
673
|
public calcZIndex = 0;
|
|
267
674
|
public hasRTTupdates = false;
|
|
268
675
|
public parentHasRenderTexture = false;
|
|
676
|
+
private _src = '';
|
|
269
677
|
|
|
270
|
-
constructor(
|
|
678
|
+
constructor(readonly stage: Stage, props: CoreNodeProps) {
|
|
271
679
|
super();
|
|
680
|
+
|
|
272
681
|
this.props = {
|
|
273
682
|
...props,
|
|
274
683
|
parent: null,
|
|
684
|
+
texture: null,
|
|
685
|
+
shader: stage.defShaderCtr,
|
|
686
|
+
src: '',
|
|
687
|
+
rtt: false,
|
|
688
|
+
data: props.data || {},
|
|
275
689
|
};
|
|
276
|
-
// Allow for parent to be processed appropriately
|
|
277
|
-
this.parent = props.parent;
|
|
278
690
|
|
|
279
|
-
//
|
|
691
|
+
// Assign props to instance
|
|
692
|
+
this.parent = props.parent;
|
|
693
|
+
this.shader = props.shader;
|
|
694
|
+
this.texture = props.texture;
|
|
695
|
+
this.src = props.src || '';
|
|
696
|
+
// FIXME
|
|
697
|
+
// this.data = props.data;
|
|
280
698
|
this.rtt = props.rtt;
|
|
281
699
|
|
|
282
700
|
this.updateScaleRotateTransform();
|
|
283
701
|
}
|
|
284
702
|
|
|
285
703
|
//#region Textures
|
|
286
|
-
loadTexture
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
options: TextureOptions | null = null,
|
|
290
|
-
): void {
|
|
291
|
-
// First unload any existing texture
|
|
292
|
-
if (this.props.texture) {
|
|
293
|
-
this.unloadTexture();
|
|
294
|
-
}
|
|
295
|
-
const { txManager } = this.stage;
|
|
296
|
-
const texture = txManager.loadTexture(textureType, props, options);
|
|
297
|
-
|
|
298
|
-
this.props.texture = texture;
|
|
299
|
-
this.props.textureOptions = options;
|
|
300
|
-
this.setUpdateType(UpdateType.IsRenderable);
|
|
704
|
+
loadTexture(): void {
|
|
705
|
+
const { texture } = this.props;
|
|
706
|
+
assertTruthy(texture);
|
|
301
707
|
|
|
302
708
|
// If texture is already loaded / failed, trigger loaded event manually
|
|
303
709
|
// so that users get a consistent event experience.
|
|
304
710
|
// We do this in a microtask to allow listeners to be attached in the same
|
|
305
711
|
// synchronous task after calling loadTexture()
|
|
306
712
|
queueMicrotask(() => {
|
|
713
|
+
// Preload texture if required
|
|
714
|
+
if (this.textureOptions.preload) {
|
|
715
|
+
texture.ctxTexture.load();
|
|
716
|
+
}
|
|
307
717
|
if (texture.state === 'loaded') {
|
|
308
|
-
|
|
718
|
+
assertTruthy(texture.dimensions);
|
|
719
|
+
this.onTextureLoaded(texture, texture.dimensions);
|
|
309
720
|
} else if (texture.state === 'failed') {
|
|
310
|
-
|
|
721
|
+
assertTruthy(texture.error);
|
|
722
|
+
this.onTextureFailed(texture, texture.error);
|
|
311
723
|
} else if (texture.state === 'freed') {
|
|
312
724
|
this.onTextureFreed(texture);
|
|
313
725
|
}
|
|
@@ -318,16 +730,12 @@ export class CoreNode extends EventEmitter implements ICoreNode {
|
|
|
318
730
|
}
|
|
319
731
|
|
|
320
732
|
unloadTexture(): void {
|
|
321
|
-
if (this.
|
|
322
|
-
|
|
323
|
-
texture.off('
|
|
324
|
-
texture.off('
|
|
325
|
-
texture.
|
|
326
|
-
texture.setRenderableOwner(this, false);
|
|
733
|
+
if (this.texture) {
|
|
734
|
+
this.texture.off('loaded', this.onTextureLoaded);
|
|
735
|
+
this.texture.off('failed', this.onTextureFailed);
|
|
736
|
+
this.texture.off('freed', this.onTextureFreed);
|
|
737
|
+
this.texture.setRenderableOwner(this, false);
|
|
327
738
|
}
|
|
328
|
-
this.props.texture = null;
|
|
329
|
-
this.props.textureOptions = null;
|
|
330
|
-
this.setUpdateType(UpdateType.IsRenderable);
|
|
331
739
|
}
|
|
332
740
|
|
|
333
741
|
autosizeNode(dimensions: Dimensions) {
|
|
@@ -337,7 +745,7 @@ export class CoreNode extends EventEmitter implements ICoreNode {
|
|
|
337
745
|
}
|
|
338
746
|
}
|
|
339
747
|
|
|
340
|
-
private onTextureLoaded: TextureLoadedEventHandler = (
|
|
748
|
+
private onTextureLoaded: TextureLoadedEventHandler = (_, dimensions) => {
|
|
341
749
|
this.autosizeNode(dimensions);
|
|
342
750
|
|
|
343
751
|
// Texture was loaded. In case the RAF loop has already stopped, we request
|
|
@@ -361,32 +769,20 @@ export class CoreNode extends EventEmitter implements ICoreNode {
|
|
|
361
769
|
}
|
|
362
770
|
};
|
|
363
771
|
|
|
364
|
-
private onTextureFailed: TextureFailedEventHandler = (
|
|
772
|
+
private onTextureFailed: TextureFailedEventHandler = (_, error) => {
|
|
365
773
|
this.emit('failed', {
|
|
366
774
|
type: 'texture',
|
|
367
775
|
error,
|
|
368
776
|
} satisfies NodeTextureFailedPayload);
|
|
369
777
|
};
|
|
370
778
|
|
|
371
|
-
private onTextureFreed: TextureFreedEventHandler = (
|
|
779
|
+
private onTextureFreed: TextureFreedEventHandler = () => {
|
|
372
780
|
this.emit('freed', {
|
|
373
781
|
type: 'texture',
|
|
374
782
|
} satisfies NodeTextureFreedPayload);
|
|
375
783
|
};
|
|
376
784
|
//#endregion Textures
|
|
377
785
|
|
|
378
|
-
loadShader<Type extends keyof ShaderMap>(
|
|
379
|
-
shaderType: Type,
|
|
380
|
-
props: ExtractProps<ShaderMap[Type]>,
|
|
381
|
-
): void {
|
|
382
|
-
const shManager = this.stage.renderer.getShaderManager();
|
|
383
|
-
assertTruthy(shManager);
|
|
384
|
-
const { shader, props: p } = shManager.loadShader(shaderType, props);
|
|
385
|
-
this.props.shader = shader;
|
|
386
|
-
this.props.shaderProps = p;
|
|
387
|
-
this.setUpdateType(UpdateType.IsRenderable);
|
|
388
|
-
}
|
|
389
|
-
|
|
390
786
|
/**
|
|
391
787
|
* Change types types is used to determine the scope of the changes being applied
|
|
392
788
|
*
|
|
@@ -416,29 +812,45 @@ export class CoreNode extends EventEmitter implements ICoreNode {
|
|
|
416
812
|
}
|
|
417
813
|
|
|
418
814
|
updateScaleRotateTransform() {
|
|
815
|
+
const { rotation, scaleX, scaleY } = this.props;
|
|
816
|
+
|
|
817
|
+
// optimize simple translation cases
|
|
818
|
+
if (rotation === 0 && scaleX === 1 && scaleY === 1) {
|
|
819
|
+
this.scaleRotateTransform = undefined;
|
|
820
|
+
return;
|
|
821
|
+
}
|
|
822
|
+
|
|
419
823
|
this.scaleRotateTransform = Matrix3d.rotate(
|
|
420
|
-
|
|
824
|
+
rotation,
|
|
421
825
|
this.scaleRotateTransform,
|
|
422
|
-
).scale(
|
|
826
|
+
).scale(scaleX, scaleY);
|
|
423
827
|
}
|
|
424
828
|
|
|
425
829
|
updateLocalTransform() {
|
|
426
|
-
|
|
427
|
-
const
|
|
428
|
-
const
|
|
429
|
-
|
|
430
|
-
|
|
431
|
-
|
|
432
|
-
|
|
433
|
-
|
|
434
|
-
|
|
435
|
-
|
|
436
|
-
|
|
437
|
-
|
|
438
|
-
|
|
830
|
+
const { x, y, width, height } = this.props;
|
|
831
|
+
const mountTranslateX = this.props.mountX * width;
|
|
832
|
+
const mountTranslateY = this.props.mountY * height;
|
|
833
|
+
|
|
834
|
+
if (this.scaleRotateTransform) {
|
|
835
|
+
const pivotTranslateX = this.props.pivotX * width;
|
|
836
|
+
const pivotTranslateY = this.props.pivotY * height;
|
|
837
|
+
|
|
838
|
+
this.localTransform = Matrix3d.translate(
|
|
839
|
+
x - mountTranslateX + pivotTranslateX,
|
|
840
|
+
y - mountTranslateY + pivotTranslateY,
|
|
841
|
+
this.localTransform,
|
|
842
|
+
)
|
|
843
|
+
.multiply(this.scaleRotateTransform)
|
|
844
|
+
.translate(-pivotTranslateX, -pivotTranslateY);
|
|
845
|
+
} else {
|
|
846
|
+
this.localTransform = Matrix3d.translate(
|
|
847
|
+
x - mountTranslateX,
|
|
848
|
+
y - mountTranslateY,
|
|
849
|
+
this.localTransform,
|
|
850
|
+
);
|
|
851
|
+
}
|
|
439
852
|
|
|
440
853
|
// Handle 'contain' resize mode
|
|
441
|
-
const { width, height } = this.props;
|
|
442
854
|
const texture = this.props.texture;
|
|
443
855
|
if (
|
|
444
856
|
texture &&
|
|
@@ -650,7 +1062,7 @@ export class CoreNode extends EventEmitter implements ICoreNode {
|
|
|
650
1062
|
return false;
|
|
651
1063
|
}
|
|
652
1064
|
|
|
653
|
-
if (this.props.shader) {
|
|
1065
|
+
if (this.props.shader === this.stage.defShaderCtr) {
|
|
654
1066
|
return true;
|
|
655
1067
|
}
|
|
656
1068
|
|
|
@@ -710,19 +1122,19 @@ export class CoreNode extends EventEmitter implements ICoreNode {
|
|
|
710
1122
|
this.strictBound,
|
|
711
1123
|
);
|
|
712
1124
|
|
|
1125
|
+
if (boundInsideBound(this.renderBound, this.strictBound)) {
|
|
1126
|
+
return CoreNodeRenderState.InViewport;
|
|
1127
|
+
}
|
|
1128
|
+
|
|
713
1129
|
const renderM = this.stage.boundsMargin;
|
|
714
1130
|
this.preloadBound = createBound(
|
|
715
|
-
|
|
716
|
-
|
|
717
|
-
|
|
718
|
-
|
|
1131
|
+
this.strictBound.x1 - renderM[3],
|
|
1132
|
+
this.strictBound.y1 - renderM[0],
|
|
1133
|
+
this.strictBound.x2 + renderM[1],
|
|
1134
|
+
this.strictBound.y2 + renderM[2],
|
|
719
1135
|
this.preloadBound,
|
|
720
1136
|
);
|
|
721
1137
|
|
|
722
|
-
if (boundInsideBound(this.renderBound, this.strictBound)) {
|
|
723
|
-
return CoreNodeRenderState.InViewport;
|
|
724
|
-
}
|
|
725
|
-
|
|
726
1138
|
if (boundInsideBound(this.renderBound, this.preloadBound)) {
|
|
727
1139
|
return CoreNodeRenderState.InBounds;
|
|
728
1140
|
}
|
|
@@ -731,48 +1143,19 @@ export class CoreNode extends EventEmitter implements ICoreNode {
|
|
|
731
1143
|
|
|
732
1144
|
updateRenderState(parentClippingRect: RectWithValid) {
|
|
733
1145
|
const renderState = this.checkRenderBounds(parentClippingRect);
|
|
734
|
-
if (renderState !== this.renderState) {
|
|
735
|
-
let previous = this.renderState;
|
|
736
|
-
this.renderState = renderState;
|
|
737
|
-
if (previous === CoreNodeRenderState.InViewport) {
|
|
738
|
-
this.emit('outOfViewport', {
|
|
739
|
-
previous,
|
|
740
|
-
current: renderState,
|
|
741
|
-
});
|
|
742
|
-
}
|
|
743
|
-
if (
|
|
744
|
-
previous < CoreNodeRenderState.InBounds &&
|
|
745
|
-
renderState === CoreNodeRenderState.InViewport
|
|
746
|
-
) {
|
|
747
|
-
this.emit(CoreNodeRenderStateMap.get(CoreNodeRenderState.InBounds)!, {
|
|
748
|
-
previous,
|
|
749
|
-
current: renderState,
|
|
750
|
-
});
|
|
751
|
-
previous = CoreNodeRenderState.InBounds;
|
|
752
|
-
} else if (
|
|
753
|
-
previous > CoreNodeRenderState.InBounds &&
|
|
754
|
-
renderState === CoreNodeRenderState.OutOfBounds
|
|
755
|
-
) {
|
|
756
|
-
this.emit(CoreNodeRenderStateMap.get(CoreNodeRenderState.InBounds)!, {
|
|
757
|
-
previous,
|
|
758
|
-
current: renderState,
|
|
759
|
-
});
|
|
760
|
-
previous = CoreNodeRenderState.InBounds;
|
|
761
|
-
}
|
|
762
|
-
const event = CoreNodeRenderStateMap.get(renderState);
|
|
763
|
-
assertTruthy(event);
|
|
764
|
-
this.emit(event, {
|
|
765
|
-
previous,
|
|
766
|
-
current: renderState,
|
|
767
|
-
});
|
|
768
|
-
}
|
|
769
|
-
}
|
|
770
1146
|
|
|
771
|
-
|
|
772
|
-
|
|
773
|
-
this.renderState = state;
|
|
774
|
-
this.emit(CoreNodeRenderState[state]);
|
|
1147
|
+
if (renderState === this.renderState) {
|
|
1148
|
+
return;
|
|
775
1149
|
}
|
|
1150
|
+
|
|
1151
|
+
const previous = this.renderState;
|
|
1152
|
+
this.renderState = renderState;
|
|
1153
|
+
const event = CoreNodeRenderStateMap.get(renderState);
|
|
1154
|
+
assertTruthy(event);
|
|
1155
|
+
this.emit(event, {
|
|
1156
|
+
previous,
|
|
1157
|
+
current: renderState,
|
|
1158
|
+
});
|
|
776
1159
|
}
|
|
777
1160
|
|
|
778
1161
|
/**
|
|
@@ -794,7 +1177,7 @@ export class CoreNode extends EventEmitter implements ICoreNode {
|
|
|
794
1177
|
}
|
|
795
1178
|
|
|
796
1179
|
onChangeIsRenderable(isRenderable: boolean) {
|
|
797
|
-
this.
|
|
1180
|
+
this.texture?.setRenderableOwner(this, isRenderable);
|
|
798
1181
|
}
|
|
799
1182
|
|
|
800
1183
|
calculateRenderCoords() {
|
|
@@ -927,7 +1310,7 @@ export class CoreNode extends EventEmitter implements ICoreNode {
|
|
|
927
1310
|
delete this.localTransform;
|
|
928
1311
|
|
|
929
1312
|
this.props.texture = null;
|
|
930
|
-
this.props.shader =
|
|
1313
|
+
this.props.shader = this.stage.defShaderCtr;
|
|
931
1314
|
|
|
932
1315
|
if (this.rtt) {
|
|
933
1316
|
this.stage.renderer.removeRTTNode(this);
|
|
@@ -938,8 +1321,7 @@ export class CoreNode extends EventEmitter implements ICoreNode {
|
|
|
938
1321
|
}
|
|
939
1322
|
|
|
940
1323
|
renderQuads(renderer: CoreRenderer): void {
|
|
941
|
-
const { width, height,
|
|
942
|
-
this.props;
|
|
1324
|
+
const { texture, width, height, textureOptions, rtt, shader } = this.props;
|
|
943
1325
|
|
|
944
1326
|
// Prevent quad rendering if parent has a render texture
|
|
945
1327
|
// and renderer is not currently rendering to a texture
|
|
@@ -960,9 +1342,16 @@ export class CoreNode extends EventEmitter implements ICoreNode {
|
|
|
960
1342
|
premultipliedColorBr,
|
|
961
1343
|
} = this;
|
|
962
1344
|
|
|
963
|
-
const {
|
|
1345
|
+
const {
|
|
1346
|
+
zIndex,
|
|
1347
|
+
worldAlpha,
|
|
1348
|
+
globalTransform: gt,
|
|
1349
|
+
clippingRect,
|
|
1350
|
+
renderCoords,
|
|
1351
|
+
} = this;
|
|
964
1352
|
|
|
965
1353
|
assertTruthy(gt);
|
|
1354
|
+
assertTruthy(renderCoords);
|
|
966
1355
|
|
|
967
1356
|
// add to list of renderables to be sorted before rendering
|
|
968
1357
|
renderer.addQuad({
|
|
@@ -975,8 +1364,8 @@ export class CoreNode extends EventEmitter implements ICoreNode {
|
|
|
975
1364
|
texture,
|
|
976
1365
|
textureOptions,
|
|
977
1366
|
zIndex,
|
|
978
|
-
shader,
|
|
979
|
-
shaderProps,
|
|
1367
|
+
shader: shader.shader,
|
|
1368
|
+
shaderProps: shader.getResolvedProps(),
|
|
980
1369
|
alpha: worldAlpha,
|
|
981
1370
|
clippingRect,
|
|
982
1371
|
tx: gt.tx,
|
|
@@ -985,6 +1374,7 @@ export class CoreNode extends EventEmitter implements ICoreNode {
|
|
|
985
1374
|
tb: gt.tb,
|
|
986
1375
|
tc: gt.tc,
|
|
987
1376
|
td: gt.td,
|
|
1377
|
+
renderCoords,
|
|
988
1378
|
rtt,
|
|
989
1379
|
parentHasRenderTexture: this.parentHasRenderTexture,
|
|
990
1380
|
framebufferDimensions: this.framebufferDimensions,
|
|
@@ -993,7 +1383,7 @@ export class CoreNode extends EventEmitter implements ICoreNode {
|
|
|
993
1383
|
|
|
994
1384
|
//#region Properties
|
|
995
1385
|
get id(): number {
|
|
996
|
-
return this.
|
|
1386
|
+
return this._id;
|
|
997
1387
|
}
|
|
998
1388
|
|
|
999
1389
|
get x(): number {
|
|
@@ -1039,6 +1429,11 @@ export class CoreNode extends EventEmitter implements ICoreNode {
|
|
|
1039
1429
|
this.setUpdateType(UpdateType.Local);
|
|
1040
1430
|
|
|
1041
1431
|
if (this.props.rtt) {
|
|
1432
|
+
this.texture = this.stage.txManager.loadTexture('RenderTexture', {
|
|
1433
|
+
width: this.width,
|
|
1434
|
+
height: this.height,
|
|
1435
|
+
});
|
|
1436
|
+
this.textureOptions.preload = true;
|
|
1042
1437
|
this.setUpdateType(UpdateType.RenderTexture);
|
|
1043
1438
|
}
|
|
1044
1439
|
}
|
|
@@ -1054,6 +1449,11 @@ export class CoreNode extends EventEmitter implements ICoreNode {
|
|
|
1054
1449
|
this.setUpdateType(UpdateType.Local);
|
|
1055
1450
|
|
|
1056
1451
|
if (this.props.rtt) {
|
|
1452
|
+
this.texture = this.stage.txManager.loadTexture('RenderTexture', {
|
|
1453
|
+
width: this.width,
|
|
1454
|
+
height: this.height,
|
|
1455
|
+
});
|
|
1456
|
+
this.textureOptions.preload = true;
|
|
1057
1457
|
this.setUpdateType(UpdateType.RenderTexture);
|
|
1058
1458
|
}
|
|
1059
1459
|
}
|
|
@@ -1206,17 +1606,10 @@ export class CoreNode extends EventEmitter implements ICoreNode {
|
|
|
1206
1606
|
}
|
|
1207
1607
|
|
|
1208
1608
|
set color(value: number) {
|
|
1209
|
-
|
|
1210
|
-
|
|
1211
|
-
|
|
1212
|
-
|
|
1213
|
-
this.props.colorBr !== value
|
|
1214
|
-
) {
|
|
1215
|
-
this.colorTl = value;
|
|
1216
|
-
this.colorTr = value;
|
|
1217
|
-
this.colorBl = value;
|
|
1218
|
-
this.colorBr = value;
|
|
1219
|
-
}
|
|
1609
|
+
this.colorTop = value;
|
|
1610
|
+
this.colorBottom = value;
|
|
1611
|
+
this.colorLeft = value;
|
|
1612
|
+
this.colorRight = value;
|
|
1220
1613
|
this.props.color = value;
|
|
1221
1614
|
|
|
1222
1615
|
this.setUpdateType(UpdateType.PremultipliedColors);
|
|
@@ -1378,9 +1771,11 @@ export class CoreNode extends EventEmitter implements ICoreNode {
|
|
|
1378
1771
|
}
|
|
1379
1772
|
|
|
1380
1773
|
set rtt(value: boolean) {
|
|
1381
|
-
if (
|
|
1382
|
-
|
|
1383
|
-
|
|
1774
|
+
if (this.props.rtt === true) {
|
|
1775
|
+
this.props.rtt = value;
|
|
1776
|
+
|
|
1777
|
+
// unload texture if we used to have a render texture
|
|
1778
|
+
if (value === false && this.texture !== null) {
|
|
1384
1779
|
this.unloadTexture();
|
|
1385
1780
|
this.setUpdateType(UpdateType.All);
|
|
1386
1781
|
|
|
@@ -1389,10 +1784,22 @@ export class CoreNode extends EventEmitter implements ICoreNode {
|
|
|
1389
1784
|
});
|
|
1390
1785
|
|
|
1391
1786
|
this.stage.renderer?.removeRTTNode(this);
|
|
1787
|
+
return;
|
|
1392
1788
|
}
|
|
1789
|
+
}
|
|
1790
|
+
|
|
1791
|
+
// if the new value is false and we didnt have rtt previously, we don't need to do anything
|
|
1792
|
+
if (value === false) {
|
|
1393
1793
|
return;
|
|
1394
1794
|
}
|
|
1395
1795
|
|
|
1796
|
+
// load texture
|
|
1797
|
+
this.texture = this.stage.txManager.loadTexture('RenderTexture', {
|
|
1798
|
+
width: this.width,
|
|
1799
|
+
height: this.height,
|
|
1800
|
+
});
|
|
1801
|
+
this.textureOptions.preload = true;
|
|
1802
|
+
|
|
1396
1803
|
this.props.rtt = true;
|
|
1397
1804
|
this.hasRTTupdates = true;
|
|
1398
1805
|
this.setUpdateType(UpdateType.All);
|
|
@@ -1405,6 +1812,43 @@ export class CoreNode extends EventEmitter implements ICoreNode {
|
|
|
1405
1812
|
this.stage.renderer?.renderToTexture(this);
|
|
1406
1813
|
}
|
|
1407
1814
|
|
|
1815
|
+
get shader(): BaseShaderController {
|
|
1816
|
+
return this.props.shader;
|
|
1817
|
+
}
|
|
1818
|
+
|
|
1819
|
+
set shader(value: BaseShaderController) {
|
|
1820
|
+
if (this.props.shader === value) {
|
|
1821
|
+
return;
|
|
1822
|
+
}
|
|
1823
|
+
|
|
1824
|
+
this.props.shader = value;
|
|
1825
|
+
|
|
1826
|
+
if (value === this.stage.defShaderCtr) {
|
|
1827
|
+
this.setUpdateType(UpdateType.IsRenderable);
|
|
1828
|
+
}
|
|
1829
|
+
}
|
|
1830
|
+
|
|
1831
|
+
get src(): string {
|
|
1832
|
+
return this._src;
|
|
1833
|
+
}
|
|
1834
|
+
|
|
1835
|
+
set src(imageUrl: string) {
|
|
1836
|
+
if (this._src === imageUrl) {
|
|
1837
|
+
return;
|
|
1838
|
+
}
|
|
1839
|
+
|
|
1840
|
+
this._src = imageUrl;
|
|
1841
|
+
|
|
1842
|
+
if (!imageUrl) {
|
|
1843
|
+
this.texture = null;
|
|
1844
|
+
return;
|
|
1845
|
+
}
|
|
1846
|
+
|
|
1847
|
+
this.texture = this.stage.txManager.loadTexture('ImageTexture', {
|
|
1848
|
+
src: imageUrl,
|
|
1849
|
+
});
|
|
1850
|
+
}
|
|
1851
|
+
|
|
1408
1852
|
/**
|
|
1409
1853
|
* Returns the framebuffer dimensions of the node.
|
|
1410
1854
|
* If the node has a render texture, the dimensions are the same as the node's dimensions.
|
|
@@ -1436,9 +1880,53 @@ export class CoreNode extends EventEmitter implements ICoreNode {
|
|
|
1436
1880
|
return this.props.texture;
|
|
1437
1881
|
}
|
|
1438
1882
|
|
|
1883
|
+
set texture(value: Texture | null) {
|
|
1884
|
+
if (this.props.texture === value) {
|
|
1885
|
+
return;
|
|
1886
|
+
}
|
|
1887
|
+
const oldTexture = this.props.texture;
|
|
1888
|
+
if (oldTexture) {
|
|
1889
|
+
oldTexture.setRenderableOwner(this, false);
|
|
1890
|
+
this.unloadTexture();
|
|
1891
|
+
}
|
|
1892
|
+
this.props.texture = value;
|
|
1893
|
+
if (value) {
|
|
1894
|
+
value.setRenderableOwner(this, this.isRenderable);
|
|
1895
|
+
this.loadTexture();
|
|
1896
|
+
}
|
|
1897
|
+
this.setUpdateType(UpdateType.IsRenderable);
|
|
1898
|
+
}
|
|
1899
|
+
|
|
1900
|
+
set textureOptions(value: TextureOptions) {
|
|
1901
|
+
this.props.textureOptions = value;
|
|
1902
|
+
}
|
|
1903
|
+
|
|
1904
|
+
get textureOptions(): TextureOptions {
|
|
1905
|
+
return this.props.textureOptions;
|
|
1906
|
+
}
|
|
1907
|
+
|
|
1439
1908
|
setRTTUpdates(type: number) {
|
|
1440
1909
|
this.hasRTTupdates = true;
|
|
1441
1910
|
this.parent?.setRTTUpdates(type);
|
|
1442
1911
|
}
|
|
1912
|
+
|
|
1913
|
+
animate(
|
|
1914
|
+
props: Partial<CoreNodeAnimateProps>,
|
|
1915
|
+
settings: Partial<AnimationSettings>,
|
|
1916
|
+
): IAnimationController {
|
|
1917
|
+
const animation = new CoreAnimation(this, props, settings);
|
|
1918
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment, @typescript-eslint/no-unsafe-call
|
|
1919
|
+
const controller = new CoreAnimationController(
|
|
1920
|
+
this.stage.animationManager,
|
|
1921
|
+
animation,
|
|
1922
|
+
);
|
|
1923
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-return
|
|
1924
|
+
return controller;
|
|
1925
|
+
}
|
|
1926
|
+
|
|
1927
|
+
flush() {
|
|
1928
|
+
// no-op
|
|
1929
|
+
}
|
|
1930
|
+
|
|
1443
1931
|
//#endregion Properties
|
|
1444
1932
|
}
|