@lightningjs/renderer 0.9.4 → 1.0.0-rc.1

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.
Files changed (289) hide show
  1. package/README.md +0 -82
  2. package/dist/exports/index.d.ts +42 -3
  3. package/dist/exports/index.js +37 -3
  4. package/dist/exports/index.js.map +1 -1
  5. package/dist/src/core/CoreNode.d.ts +461 -46
  6. package/dist/src/core/CoreNode.js +170 -104
  7. package/dist/src/core/CoreNode.js.map +1 -1
  8. package/dist/src/core/CoreShaderManager.d.ts +16 -6
  9. package/dist/src/core/CoreShaderManager.js +20 -20
  10. package/dist/src/core/CoreShaderManager.js.map +1 -1
  11. package/dist/src/core/CoreTextNode.d.ts +30 -4
  12. package/dist/src/core/CoreTextNode.js +24 -1
  13. package/dist/src/core/CoreTextNode.js.map +1 -1
  14. package/dist/src/core/CoreTextureManager.d.ts +31 -82
  15. package/dist/src/core/CoreTextureManager.js +39 -126
  16. package/dist/src/core/CoreTextureManager.js.map +1 -1
  17. package/dist/src/core/Stage.d.ts +67 -9
  18. package/dist/src/core/Stage.js +174 -30
  19. package/dist/src/core/Stage.js.map +1 -1
  20. package/dist/src/core/TextureMemoryManager.d.ts +97 -8
  21. package/dist/src/core/TextureMemoryManager.js +142 -19
  22. package/dist/src/core/TextureMemoryManager.js.map +1 -1
  23. package/dist/src/core/animations/CoreAnimation.d.ts +14 -6
  24. package/dist/src/core/animations/CoreAnimation.js +137 -43
  25. package/dist/src/core/animations/CoreAnimation.js.map +1 -1
  26. package/dist/src/core/lib/ImageWorker.js +59 -52
  27. package/dist/src/core/lib/ImageWorker.js.map +1 -1
  28. package/dist/src/core/lib/utils.js.map +1 -1
  29. package/dist/src/core/platform.js +7 -1
  30. package/dist/src/core/platform.js.map +1 -1
  31. package/dist/src/core/renderers/CoreContextTexture.d.ts +3 -2
  32. package/dist/src/core/renderers/CoreContextTexture.js +7 -1
  33. package/dist/src/core/renderers/CoreContextTexture.js.map +1 -1
  34. package/dist/src/core/renderers/CoreRenderer.d.ts +5 -1
  35. package/dist/src/core/renderers/CoreRenderer.js +0 -1
  36. package/dist/src/core/renderers/CoreRenderer.js.map +1 -1
  37. package/dist/src/core/renderers/canvas/CanvasCoreRenderer.d.ts +3 -0
  38. package/dist/src/core/renderers/canvas/CanvasCoreRenderer.js +16 -1
  39. package/dist/src/core/renderers/canvas/CanvasCoreRenderer.js.map +1 -1
  40. package/dist/src/core/renderers/canvas/CanvasCoreTexture.d.ts +0 -1
  41. package/dist/src/core/renderers/canvas/CanvasCoreTexture.js +2 -5
  42. package/dist/src/core/renderers/canvas/CanvasCoreTexture.js.map +1 -1
  43. package/dist/src/core/renderers/webgl/WebGlCoreCtxRenderTexture.js +2 -2
  44. package/dist/src/core/renderers/webgl/WebGlCoreCtxRenderTexture.js.map +1 -1
  45. package/dist/src/core/renderers/webgl/WebGlCoreCtxTexture.d.ts +0 -1
  46. package/dist/src/core/renderers/webgl/WebGlCoreCtxTexture.js +7 -10
  47. package/dist/src/core/renderers/webgl/WebGlCoreCtxTexture.js.map +1 -1
  48. package/dist/src/core/renderers/webgl/WebGlCoreRenderer.d.ts +3 -0
  49. package/dist/src/core/renderers/webgl/WebGlCoreRenderer.js +47 -9
  50. package/dist/src/core/renderers/webgl/WebGlCoreRenderer.js.map +1 -1
  51. package/dist/src/core/renderers/webgl/shaders/DynamicShader.d.ts +2 -43
  52. package/dist/src/core/renderers/webgl/shaders/DynamicShader.js +70 -37
  53. package/dist/src/core/renderers/webgl/shaders/DynamicShader.js.map +1 -1
  54. package/dist/src/core/renderers/webgl/shaders/effects/BorderBottomEffect.js +2 -2
  55. package/dist/src/core/renderers/webgl/shaders/effects/BorderBottomEffect.js.map +1 -1
  56. package/dist/src/core/renderers/webgl/shaders/effects/BorderEffect.js +2 -2
  57. package/dist/src/core/renderers/webgl/shaders/effects/BorderEffect.js.map +1 -1
  58. package/dist/src/core/renderers/webgl/shaders/effects/BorderLeftEffect.js +2 -2
  59. package/dist/src/core/renderers/webgl/shaders/effects/BorderLeftEffect.js.map +1 -1
  60. package/dist/src/core/renderers/webgl/shaders/effects/BorderRightEffect.js +2 -2
  61. package/dist/src/core/renderers/webgl/shaders/effects/BorderRightEffect.js.map +1 -1
  62. package/dist/src/core/renderers/webgl/shaders/effects/BorderTopEffect.js +2 -2
  63. package/dist/src/core/renderers/webgl/shaders/effects/BorderTopEffect.js.map +1 -1
  64. package/dist/src/core/renderers/webgl/shaders/effects/EffectUtils.d.ts +8 -0
  65. package/dist/src/core/renderers/webgl/shaders/effects/EffectUtils.js +103 -0
  66. package/dist/src/core/renderers/webgl/shaders/effects/EffectUtils.js.map +1 -1
  67. package/dist/src/core/renderers/webgl/shaders/effects/FadeOutEffect.js +3 -18
  68. package/dist/src/core/renderers/webgl/shaders/effects/FadeOutEffect.js.map +1 -1
  69. package/dist/src/core/renderers/webgl/shaders/effects/GlitchEffect.js +5 -2
  70. package/dist/src/core/renderers/webgl/shaders/effects/GlitchEffect.js.map +1 -1
  71. package/dist/src/core/renderers/webgl/shaders/effects/HolePunchEffect.js +4 -36
  72. package/dist/src/core/renderers/webgl/shaders/effects/HolePunchEffect.js.map +1 -1
  73. package/dist/src/core/renderers/webgl/shaders/effects/LinearGradientEffect.js +3 -2
  74. package/dist/src/core/renderers/webgl/shaders/effects/LinearGradientEffect.js.map +1 -1
  75. package/dist/src/core/renderers/webgl/shaders/effects/RadialGradientEffect.js +4 -2
  76. package/dist/src/core/renderers/webgl/shaders/effects/RadialGradientEffect.js.map +1 -1
  77. package/dist/src/core/renderers/webgl/shaders/effects/RadialProgressEffect.js +2 -1
  78. package/dist/src/core/renderers/webgl/shaders/effects/RadialProgressEffect.js.map +1 -1
  79. package/dist/src/core/renderers/webgl/shaders/effects/RadiusEffect.js +4 -36
  80. package/dist/src/core/renderers/webgl/shaders/effects/RadiusEffect.js.map +1 -1
  81. package/dist/src/core/renderers/webgl/shaders/effects/ShaderEffect.d.ts +69 -0
  82. package/dist/src/core/renderers/webgl/shaders/effects/ShaderEffect.js.map +1 -1
  83. package/dist/src/core/text-rendering/font-face-types/SdfTrFontFace/SdfTrFontFace.js +5 -2
  84. package/dist/src/core/text-rendering/font-face-types/SdfTrFontFace/SdfTrFontFace.js.map +1 -1
  85. package/dist/src/core/text-rendering/font-face-types/TrFontFace.d.ts +0 -1
  86. package/dist/src/core/text-rendering/font-face-types/TrFontFace.js +0 -1
  87. package/dist/src/core/text-rendering/font-face-types/TrFontFace.js.map +1 -1
  88. package/dist/src/core/text-rendering/font-face-types/WebTrFontFace.js +0 -1
  89. package/dist/src/core/text-rendering/font-face-types/WebTrFontFace.js.map +1 -1
  90. package/dist/src/core/text-rendering/renderers/CanvasTextRenderer.d.ts +10 -26
  91. package/dist/src/core/text-rendering/renderers/CanvasTextRenderer.js +116 -365
  92. package/dist/src/core/text-rendering/renderers/CanvasTextRenderer.js.map +1 -1
  93. package/dist/src/core/text-rendering/renderers/LightningTextTextureRenderer.d.ts +0 -1
  94. package/dist/src/core/text-rendering/renderers/LightningTextTextureRenderer.js +0 -2
  95. package/dist/src/core/text-rendering/renderers/LightningTextTextureRenderer.js.map +1 -1
  96. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.js +2 -2
  97. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.js.map +1 -1
  98. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText.js +2 -0
  99. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText.js.map +1 -1
  100. package/dist/src/core/text-rendering/renderers/TextRenderer.d.ts +3 -2
  101. package/dist/src/core/text-rendering/renderers/TextRenderer.js.map +1 -1
  102. package/dist/src/core/textures/ColorTexture.d.ts +1 -1
  103. package/dist/src/core/textures/ColorTexture.js +1 -1
  104. package/dist/src/core/textures/ImageTexture.d.ts +1 -1
  105. package/dist/src/core/textures/NoiseTexture.d.ts +1 -1
  106. package/dist/src/core/textures/NoiseTexture.js +3 -0
  107. package/dist/src/core/textures/NoiseTexture.js.map +1 -1
  108. package/dist/src/core/textures/SubTexture.d.ts +2 -2
  109. package/dist/src/core/textures/SubTexture.js +5 -1
  110. package/dist/src/core/textures/SubTexture.js.map +1 -1
  111. package/dist/src/core/textures/Texture.d.ts +23 -2
  112. package/dist/src/core/textures/Texture.js +32 -3
  113. package/dist/src/core/textures/Texture.js.map +1 -1
  114. package/dist/src/core/utils.d.ts +7 -0
  115. package/dist/src/core/utils.js +12 -10
  116. package/dist/src/core/utils.js.map +1 -1
  117. package/dist/src/main-api/DynamicShaderController.d.ts +9 -14
  118. package/dist/src/main-api/DynamicShaderController.js +21 -17
  119. package/dist/src/main-api/DynamicShaderController.js.map +1 -1
  120. package/dist/src/main-api/INode.d.ts +43 -463
  121. package/dist/src/main-api/INode.js +1 -19
  122. package/dist/src/main-api/INode.js.map +1 -1
  123. package/dist/src/main-api/Inspector.d.ts +10 -10
  124. package/dist/src/main-api/Inspector.js +18 -15
  125. package/dist/src/main-api/Inspector.js.map +1 -1
  126. package/dist/src/main-api/Renderer.d.ts +71 -25
  127. package/dist/src/main-api/Renderer.js +80 -109
  128. package/dist/src/main-api/Renderer.js.map +1 -1
  129. package/dist/src/main-api/ShaderController.d.ts +3 -8
  130. package/dist/src/main-api/ShaderController.js +8 -3
  131. package/dist/src/main-api/ShaderController.js.map +1 -1
  132. package/dist/src/utils.d.ts +1 -0
  133. package/dist/src/utils.js +7 -0
  134. package/dist/src/utils.js.map +1 -1
  135. package/dist/tsconfig.dist.tsbuildinfo +1 -1
  136. package/exports/index.ts +62 -3
  137. package/package.json +8 -7
  138. package/src/core/CoreNode.test.ts +93 -0
  139. package/src/core/CoreNode.ts +675 -188
  140. package/src/core/CoreShaderManager.ts +56 -29
  141. package/src/core/CoreTextNode.ts +41 -9
  142. package/src/core/CoreTextureManager.ts +55 -175
  143. package/src/core/Stage.ts +199 -43
  144. package/src/core/TextureMemoryManager.ts +231 -22
  145. package/src/core/animations/CoreAnimation.ts +194 -67
  146. package/src/core/lib/ImageWorker.ts +79 -52
  147. package/src/core/lib/utils.ts +1 -0
  148. package/src/core/platform.ts +8 -1
  149. package/src/core/renderers/CoreContextTexture.ts +9 -2
  150. package/src/core/renderers/CoreRenderer.ts +5 -2
  151. package/src/core/renderers/canvas/CanvasCoreRenderer.ts +20 -1
  152. package/src/core/renderers/canvas/CanvasCoreTexture.ts +2 -6
  153. package/src/core/renderers/webgl/WebGlCoreCtxRenderTexture.ts +2 -2
  154. package/src/core/renderers/webgl/WebGlCoreCtxTexture.ts +7 -11
  155. package/src/core/renderers/webgl/WebGlCoreRenderer.ts +51 -9
  156. package/src/core/renderers/webgl/shaders/DynamicShader.ts +94 -92
  157. package/src/core/renderers/webgl/shaders/effects/BorderBottomEffect.ts +2 -2
  158. package/src/core/renderers/webgl/shaders/effects/BorderEffect.ts +2 -2
  159. package/src/core/renderers/webgl/shaders/effects/BorderLeftEffect.ts +2 -2
  160. package/src/core/renderers/webgl/shaders/effects/BorderRightEffect.ts +2 -2
  161. package/src/core/renderers/webgl/shaders/effects/BorderTopEffect.ts +2 -2
  162. package/src/core/renderers/webgl/shaders/effects/EffectUtils.ts +129 -3
  163. package/src/core/renderers/webgl/shaders/effects/FadeOutEffect.ts +7 -15
  164. package/src/core/renderers/webgl/shaders/effects/GlitchEffect.ts +5 -2
  165. package/src/core/renderers/webgl/shaders/effects/HolePunchEffect.ts +6 -15
  166. package/src/core/renderers/webgl/shaders/effects/LinearGradientEffect.ts +6 -2
  167. package/src/core/renderers/webgl/shaders/effects/RadialGradientEffect.ts +10 -2
  168. package/src/core/renderers/webgl/shaders/effects/RadialProgressEffect.ts +2 -1
  169. package/src/core/renderers/webgl/shaders/effects/RadiusEffect.ts +6 -15
  170. package/src/core/renderers/webgl/shaders/effects/ShaderEffect.ts +80 -0
  171. package/src/core/text-rendering/font-face-types/SdfTrFontFace/SdfTrFontFace.ts +14 -15
  172. package/src/core/text-rendering/font-face-types/TrFontFace.ts +0 -2
  173. package/src/core/text-rendering/font-face-types/WebTrFontFace.ts +0 -1
  174. package/src/core/text-rendering/renderers/CanvasTextRenderer.ts +139 -447
  175. package/src/core/text-rendering/renderers/LightningTextTextureRenderer.ts +0 -3
  176. package/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.ts +2 -2
  177. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText.ts +4 -2
  178. package/src/core/text-rendering/renderers/TextRenderer.ts +3 -2
  179. package/src/core/textures/ColorTexture.ts +1 -1
  180. package/src/core/textures/ImageTexture.ts +1 -1
  181. package/src/core/textures/NoiseTexture.ts +4 -1
  182. package/src/core/textures/SubTexture.ts +7 -7
  183. package/src/core/textures/Texture.ts +46 -3
  184. package/src/core/utils.ts +12 -11
  185. package/src/main-api/DynamicShaderController.ts +104 -0
  186. package/src/main-api/INode.ts +57 -479
  187. package/src/main-api/Inspector.ts +37 -39
  188. package/src/main-api/Renderer.ts +586 -0
  189. package/src/main-api/ShaderController.ts +81 -0
  190. package/src/main-api/utils.ts +45 -0
  191. package/src/utils.ts +8 -0
  192. package/dist/exports/core-api.d.ts +0 -74
  193. package/dist/exports/core-api.js +0 -96
  194. package/dist/exports/core-api.js.map +0 -1
  195. package/dist/exports/main-api.d.ts +0 -30
  196. package/dist/exports/main-api.js +0 -45
  197. package/dist/exports/main-api.js.map +0 -1
  198. package/dist/src/core/CoreExtension.d.ts +0 -12
  199. package/dist/src/core/CoreExtension.js +0 -29
  200. package/dist/src/core/CoreExtension.js.map +0 -1
  201. package/dist/src/core/renderers/SpecificNode.d.ts +0 -1
  202. package/dist/src/core/renderers/SpecificNode.js +0 -19
  203. package/dist/src/core/renderers/SpecificNode.js.map +0 -1
  204. package/dist/src/core/renderers/webgl/newShader/effectsMock.d.ts +0 -13
  205. package/dist/src/core/renderers/webgl/newShader/effectsMock.js +0 -62
  206. package/dist/src/core/renderers/webgl/newShader/effectsMock.js.map +0 -1
  207. package/dist/src/main-api/ICoreDriver.d.ts +0 -24
  208. package/dist/src/main-api/ICoreDriver.js +0 -20
  209. package/dist/src/main-api/ICoreDriver.js.map +0 -1
  210. package/dist/src/main-api/RendererMain.d.ts +0 -378
  211. package/dist/src/main-api/RendererMain.js +0 -367
  212. package/dist/src/main-api/RendererMain.js.map +0 -1
  213. package/dist/src/main-api/texture-usage-trackers/FinalizationRegistryTextureUsageTracker.d.ts +0 -9
  214. package/dist/src/main-api/texture-usage-trackers/FinalizationRegistryTextureUsageTracker.js +0 -38
  215. package/dist/src/main-api/texture-usage-trackers/FinalizationRegistryTextureUsageTracker.js.map +0 -1
  216. package/dist/src/main-api/texture-usage-trackers/ManualCountTextureUsageTracker.d.ts +0 -56
  217. package/dist/src/main-api/texture-usage-trackers/ManualCountTextureUsageTracker.js +0 -101
  218. package/dist/src/main-api/texture-usage-trackers/ManualCountTextureUsageTracker.js.map +0 -1
  219. package/dist/src/main-api/texture-usage-trackers/TextureUsageTracker.d.ts +0 -32
  220. package/dist/src/main-api/texture-usage-trackers/TextureUsageTracker.js +0 -28
  221. package/dist/src/main-api/texture-usage-trackers/TextureUsageTracker.js.map +0 -1
  222. package/dist/src/render-drivers/main/MainCoreDriver.d.ts +0 -21
  223. package/dist/src/render-drivers/main/MainCoreDriver.js +0 -115
  224. package/dist/src/render-drivers/main/MainCoreDriver.js.map +0 -1
  225. package/dist/src/render-drivers/main/MainOnlyNode.d.ts +0 -101
  226. package/dist/src/render-drivers/main/MainOnlyNode.js +0 -425
  227. package/dist/src/render-drivers/main/MainOnlyNode.js.map +0 -1
  228. package/dist/src/render-drivers/main/MainOnlyTextNode.d.ts +0 -47
  229. package/dist/src/render-drivers/main/MainOnlyTextNode.js +0 -204
  230. package/dist/src/render-drivers/main/MainOnlyTextNode.js.map +0 -1
  231. package/dist/src/render-drivers/threadx/NodeStruct.d.ts +0 -93
  232. package/dist/src/render-drivers/threadx/NodeStruct.js +0 -290
  233. package/dist/src/render-drivers/threadx/NodeStruct.js.map +0 -1
  234. package/dist/src/render-drivers/threadx/SharedNode.d.ts +0 -40
  235. package/dist/src/render-drivers/threadx/SharedNode.js +0 -61
  236. package/dist/src/render-drivers/threadx/SharedNode.js.map +0 -1
  237. package/dist/src/render-drivers/threadx/TextNodeStruct.d.ts +0 -44
  238. package/dist/src/render-drivers/threadx/TextNodeStruct.js +0 -203
  239. package/dist/src/render-drivers/threadx/TextNodeStruct.js.map +0 -1
  240. package/dist/src/render-drivers/threadx/ThreadXCoreDriver.d.ts +0 -25
  241. package/dist/src/render-drivers/threadx/ThreadXCoreDriver.js +0 -232
  242. package/dist/src/render-drivers/threadx/ThreadXCoreDriver.js.map +0 -1
  243. package/dist/src/render-drivers/threadx/ThreadXMainAnimationController.d.ts +0 -24
  244. package/dist/src/render-drivers/threadx/ThreadXMainAnimationController.js +0 -113
  245. package/dist/src/render-drivers/threadx/ThreadXMainAnimationController.js.map +0 -1
  246. package/dist/src/render-drivers/threadx/ThreadXMainNode.d.ts +0 -46
  247. package/dist/src/render-drivers/threadx/ThreadXMainNode.js +0 -160
  248. package/dist/src/render-drivers/threadx/ThreadXMainNode.js.map +0 -1
  249. package/dist/src/render-drivers/threadx/ThreadXMainTextNode.d.ts +0 -28
  250. package/dist/src/render-drivers/threadx/ThreadXMainTextNode.js +0 -55
  251. package/dist/src/render-drivers/threadx/ThreadXMainTextNode.js.map +0 -1
  252. package/dist/src/render-drivers/threadx/ThreadXRendererMessage.d.ts +0 -70
  253. package/dist/src/render-drivers/threadx/ThreadXRendererMessage.js +0 -32
  254. package/dist/src/render-drivers/threadx/ThreadXRendererMessage.js.map +0 -1
  255. package/dist/src/render-drivers/threadx/worker/ThreadXRendererNode.d.ts +0 -19
  256. package/dist/src/render-drivers/threadx/worker/ThreadXRendererNode.js +0 -184
  257. package/dist/src/render-drivers/threadx/worker/ThreadXRendererNode.js.map +0 -1
  258. package/dist/src/render-drivers/threadx/worker/ThreadXRendererTextNode.d.ts +0 -27
  259. package/dist/src/render-drivers/threadx/worker/ThreadXRendererTextNode.js +0 -109
  260. package/dist/src/render-drivers/threadx/worker/ThreadXRendererTextNode.js.map +0 -1
  261. package/dist/src/render-drivers/threadx/worker/renderer.d.ts +0 -1
  262. package/dist/src/render-drivers/threadx/worker/renderer.js +0 -147
  263. package/dist/src/render-drivers/threadx/worker/renderer.js.map +0 -1
  264. package/dist/src/render-drivers/utils.d.ts +0 -12
  265. package/dist/src/render-drivers/utils.js +0 -74
  266. package/dist/src/render-drivers/utils.js.map +0 -1
  267. package/exports/core-api.ts +0 -102
  268. package/exports/main-api.ts +0 -62
  269. package/src/core/CoreExtension.ts +0 -32
  270. package/src/main-api/ICoreDriver.ts +0 -68
  271. package/src/main-api/RendererMain.ts +0 -685
  272. package/src/main-api/texture-usage-trackers/FinalizationRegistryTextureUsageTracker.ts +0 -45
  273. package/src/main-api/texture-usage-trackers/ManualCountTextureUsageTracker.ts +0 -154
  274. package/src/main-api/texture-usage-trackers/TextureUsageTracker.ts +0 -54
  275. package/src/render-drivers/main/MainCoreDriver.ts +0 -159
  276. package/src/render-drivers/main/MainOnlyNode.ts +0 -553
  277. package/src/render-drivers/main/MainOnlyTextNode.ts +0 -261
  278. package/src/render-drivers/threadx/NodeStruct.ts +0 -320
  279. package/src/render-drivers/threadx/SharedNode.ts +0 -101
  280. package/src/render-drivers/threadx/TextNodeStruct.ts +0 -213
  281. package/src/render-drivers/threadx/ThreadXCoreDriver.ts +0 -291
  282. package/src/render-drivers/threadx/ThreadXMainAnimationController.ts +0 -135
  283. package/src/render-drivers/threadx/ThreadXMainNode.ts +0 -201
  284. package/src/render-drivers/threadx/ThreadXMainTextNode.ts +0 -85
  285. package/src/render-drivers/threadx/ThreadXRendererMessage.ts +0 -112
  286. package/src/render-drivers/threadx/worker/ThreadXRendererNode.ts +0 -253
  287. package/src/render-drivers/threadx/worker/ThreadXRendererTextNode.ts +0 -151
  288. package/src/render-drivers/threadx/worker/renderer.ts +0 -156
  289. package/src/render-drivers/utils.ts +0 -102
@@ -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 { ShaderMap } from './CoreShaderManager.js';
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
- export class CoreNode extends EventEmitter implements ICoreNode {
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 props: Required<CoreNodeProps>;
646
+ protected _id: number = getNewId();
647
+ readonly props: CoreNodeProps;
241
648
 
242
649
  public updateType = UpdateType.All;
243
650
 
@@ -267,47 +674,46 @@ export class CoreNode extends EventEmitter implements ICoreNode {
267
674
  public hasRTTupdates = false;
268
675
  public parentHasRenderTexture = false;
269
676
 
270
- constructor(protected stage: Stage, props: CoreNodeProps) {
677
+ constructor(readonly stage: Stage, props: CoreNodeProps) {
271
678
  super();
679
+
272
680
  this.props = {
273
681
  ...props,
274
682
  parent: null,
683
+ texture: null,
684
+ src: null,
685
+ rtt: false,
275
686
  };
276
- // Allow for parent to be processed appropriately
277
- this.parent = props.parent;
278
687
 
279
- // Allow for Render Texture to be processed appropriately
688
+ // Assign props to instance
689
+ this.parent = props.parent;
690
+ this.texture = props.texture;
691
+ this.src = props.src;
280
692
  this.rtt = props.rtt;
281
693
 
282
694
  this.updateScaleRotateTransform();
283
695
  }
284
696
 
285
697
  //#region Textures
286
- loadTexture<Type extends keyof TextureMap>(
287
- textureType: Type,
288
- props: ExtractProps<TextureMap[Type]>,
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);
698
+ loadTexture(): void {
699
+ const { texture } = this.props;
700
+ assertTruthy(texture);
301
701
 
302
702
  // If texture is already loaded / failed, trigger loaded event manually
303
703
  // so that users get a consistent event experience.
304
704
  // We do this in a microtask to allow listeners to be attached in the same
305
705
  // synchronous task after calling loadTexture()
306
706
  queueMicrotask(() => {
707
+ // Preload texture if required
708
+ if (this.textureOptions.preload) {
709
+ texture.ctxTexture.load();
710
+ }
307
711
  if (texture.state === 'loaded') {
308
- this.onTextureLoaded(texture, texture.dimensions!);
712
+ assertTruthy(texture.dimensions);
713
+ this.onTextureLoaded(texture, texture.dimensions);
309
714
  } else if (texture.state === 'failed') {
310
- this.onTextureFailed(texture, texture.error!);
715
+ assertTruthy(texture.error);
716
+ this.onTextureFailed(texture, texture.error);
311
717
  } else if (texture.state === 'freed') {
312
718
  this.onTextureFreed(texture);
313
719
  }
@@ -318,16 +724,12 @@ export class CoreNode extends EventEmitter implements ICoreNode {
318
724
  }
319
725
 
320
726
  unloadTexture(): void {
321
- if (this.props.texture) {
322
- const { texture } = this.props;
323
- texture.off('loaded', this.onTextureLoaded);
324
- texture.off('failed', this.onTextureFailed);
325
- texture.off('freed', this.onTextureFreed);
326
- texture.setRenderableOwner(this, false);
727
+ if (this.texture) {
728
+ this.texture.off('loaded', this.onTextureLoaded);
729
+ this.texture.off('failed', this.onTextureFailed);
730
+ this.texture.off('freed', this.onTextureFreed);
731
+ this.texture.setRenderableOwner(this, false);
327
732
  }
328
- this.props.texture = null;
329
- this.props.textureOptions = null;
330
- this.setUpdateType(UpdateType.IsRenderable);
331
733
  }
332
734
 
333
735
  autosizeNode(dimensions: Dimensions) {
@@ -337,7 +739,7 @@ export class CoreNode extends EventEmitter implements ICoreNode {
337
739
  }
338
740
  }
339
741
 
340
- private onTextureLoaded: TextureLoadedEventHandler = (target, dimensions) => {
742
+ private onTextureLoaded: TextureLoadedEventHandler = (_, dimensions) => {
341
743
  this.autosizeNode(dimensions);
342
744
 
343
745
  // Texture was loaded. In case the RAF loop has already stopped, we request
@@ -361,32 +763,20 @@ export class CoreNode extends EventEmitter implements ICoreNode {
361
763
  }
362
764
  };
363
765
 
364
- private onTextureFailed: TextureFailedEventHandler = (target, error) => {
766
+ private onTextureFailed: TextureFailedEventHandler = (_, error) => {
365
767
  this.emit('failed', {
366
768
  type: 'texture',
367
769
  error,
368
770
  } satisfies NodeTextureFailedPayload);
369
771
  };
370
772
 
371
- private onTextureFreed: TextureFreedEventHandler = (target: Texture) => {
773
+ private onTextureFreed: TextureFreedEventHandler = () => {
372
774
  this.emit('freed', {
373
775
  type: 'texture',
374
776
  } satisfies NodeTextureFreedPayload);
375
777
  };
376
778
  //#endregion Textures
377
779
 
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
780
  /**
391
781
  * Change types types is used to determine the scope of the changes being applied
392
782
  *
@@ -416,29 +806,45 @@ export class CoreNode extends EventEmitter implements ICoreNode {
416
806
  }
417
807
 
418
808
  updateScaleRotateTransform() {
809
+ const { rotation, scaleX, scaleY } = this.props;
810
+
811
+ // optimize simple translation cases
812
+ if (rotation === 0 && scaleX === 1 && scaleY === 1) {
813
+ this.scaleRotateTransform = undefined;
814
+ return;
815
+ }
816
+
419
817
  this.scaleRotateTransform = Matrix3d.rotate(
420
- this.props.rotation,
818
+ rotation,
421
819
  this.scaleRotateTransform,
422
- ).scale(this.props.scaleX, this.props.scaleY);
820
+ ).scale(scaleX, scaleY);
423
821
  }
424
822
 
425
823
  updateLocalTransform() {
426
- assertTruthy(this.scaleRotateTransform);
427
- const pivotTranslateX = this.props.pivotX * this.props.width;
428
- const pivotTranslateY = this.props.pivotY * this.props.height;
429
- const mountTranslateX = this.props.mountX * this.props.width;
430
- const mountTranslateY = this.props.mountY * this.props.height;
431
-
432
- this.localTransform = Matrix3d.translate(
433
- pivotTranslateX - mountTranslateX + this.props.x,
434
- pivotTranslateY - mountTranslateY + this.props.y,
435
- this.localTransform,
436
- )
437
- .multiply(this.scaleRotateTransform)
438
- .translate(-pivotTranslateX, -pivotTranslateY);
824
+ const { x, y, width, height } = this.props;
825
+ const mountTranslateX = this.props.mountX * width;
826
+ const mountTranslateY = this.props.mountY * height;
827
+
828
+ if (this.scaleRotateTransform) {
829
+ const pivotTranslateX = this.props.pivotX * width;
830
+ const pivotTranslateY = this.props.pivotY * height;
831
+
832
+ this.localTransform = Matrix3d.translate(
833
+ x - mountTranslateX + pivotTranslateX,
834
+ y - mountTranslateY + pivotTranslateY,
835
+ this.localTransform,
836
+ )
837
+ .multiply(this.scaleRotateTransform)
838
+ .translate(-pivotTranslateX, -pivotTranslateY);
839
+ } else {
840
+ this.localTransform = Matrix3d.translate(
841
+ x - mountTranslateX,
842
+ y - mountTranslateY,
843
+ this.localTransform,
844
+ );
845
+ }
439
846
 
440
847
  // Handle 'contain' resize mode
441
- const { width, height } = this.props;
442
848
  const texture = this.props.texture;
443
849
  if (
444
850
  texture &&
@@ -650,7 +1056,7 @@ export class CoreNode extends EventEmitter implements ICoreNode {
650
1056
  return false;
651
1057
  }
652
1058
 
653
- if (this.props.shader) {
1059
+ if (this.props.shader !== this.stage.defShaderCtr) {
654
1060
  return true;
655
1061
  }
656
1062
 
@@ -710,19 +1116,19 @@ export class CoreNode extends EventEmitter implements ICoreNode {
710
1116
  this.strictBound,
711
1117
  );
712
1118
 
1119
+ if (boundInsideBound(this.renderBound, this.strictBound)) {
1120
+ return CoreNodeRenderState.InViewport;
1121
+ }
1122
+
713
1123
  const renderM = this.stage.boundsMargin;
714
1124
  this.preloadBound = createBound(
715
- parentClippingRect.x - renderM[3],
716
- parentClippingRect.y - renderM[0],
717
- parentClippingRect.x + rectW + renderM[1],
718
- parentClippingRect.y + rectH + renderM[2],
1125
+ this.strictBound.x1 - renderM[3],
1126
+ this.strictBound.y1 - renderM[0],
1127
+ this.strictBound.x2 + renderM[1],
1128
+ this.strictBound.y2 + renderM[2],
719
1129
  this.preloadBound,
720
1130
  );
721
1131
 
722
- if (boundInsideBound(this.renderBound, this.strictBound)) {
723
- return CoreNodeRenderState.InViewport;
724
- }
725
-
726
1132
  if (boundInsideBound(this.renderBound, this.preloadBound)) {
727
1133
  return CoreNodeRenderState.InBounds;
728
1134
  }
@@ -731,48 +1137,19 @@ export class CoreNode extends EventEmitter implements ICoreNode {
731
1137
 
732
1138
  updateRenderState(parentClippingRect: RectWithValid) {
733
1139
  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
1140
 
771
- setRenderState(state: CoreNodeRenderState) {
772
- if (state !== this.renderState) {
773
- this.renderState = state;
774
- this.emit(CoreNodeRenderState[state]);
1141
+ if (renderState === this.renderState) {
1142
+ return;
775
1143
  }
1144
+
1145
+ const previous = this.renderState;
1146
+ this.renderState = renderState;
1147
+ const event = CoreNodeRenderStateMap.get(renderState);
1148
+ assertTruthy(event);
1149
+ this.emit(event, {
1150
+ previous,
1151
+ current: renderState,
1152
+ });
776
1153
  }
777
1154
 
778
1155
  /**
@@ -794,7 +1171,7 @@ export class CoreNode extends EventEmitter implements ICoreNode {
794
1171
  }
795
1172
 
796
1173
  onChangeIsRenderable(isRenderable: boolean) {
797
- this.props.texture?.setRenderableOwner(this, isRenderable);
1174
+ this.texture?.setRenderableOwner(this, isRenderable);
798
1175
  }
799
1176
 
800
1177
  calculateRenderCoords() {
@@ -927,19 +1304,25 @@ export class CoreNode extends EventEmitter implements ICoreNode {
927
1304
  delete this.localTransform;
928
1305
 
929
1306
  this.props.texture = null;
930
- this.props.shader = null;
1307
+ this.props.shader = this.stage.defShaderCtr;
1308
+
1309
+ const children = [...this.children];
1310
+ for (let i = 0; i < children.length; i++) {
1311
+ // eslint-disable-next-line @typescript-eslint/no-non-null-assertion
1312
+ children[i]!.destroy();
1313
+ }
1314
+ // This very action will also remove the node from the parent's children array
1315
+ this.parent = null;
931
1316
 
932
1317
  if (this.rtt) {
933
1318
  this.stage.renderer.removeRTTNode(this);
934
1319
  }
935
1320
 
936
1321
  this.removeAllListeners();
937
- this.parent = null;
938
1322
  }
939
1323
 
940
1324
  renderQuads(renderer: CoreRenderer): void {
941
- const { width, height, texture, textureOptions, shader, shaderProps, rtt } =
942
- this.props;
1325
+ const { texture, width, height, textureOptions, rtt, shader } = this.props;
943
1326
 
944
1327
  // Prevent quad rendering if parent has a render texture
945
1328
  // and renderer is not currently rendering to a texture
@@ -960,9 +1343,16 @@ export class CoreNode extends EventEmitter implements ICoreNode {
960
1343
  premultipliedColorBr,
961
1344
  } = this;
962
1345
 
963
- const { zIndex, worldAlpha, globalTransform: gt, clippingRect } = this;
1346
+ const {
1347
+ zIndex,
1348
+ worldAlpha,
1349
+ globalTransform: gt,
1350
+ clippingRect,
1351
+ renderCoords,
1352
+ } = this;
964
1353
 
965
1354
  assertTruthy(gt);
1355
+ assertTruthy(renderCoords);
966
1356
 
967
1357
  // add to list of renderables to be sorted before rendering
968
1358
  renderer.addQuad({
@@ -975,8 +1365,8 @@ export class CoreNode extends EventEmitter implements ICoreNode {
975
1365
  texture,
976
1366
  textureOptions,
977
1367
  zIndex,
978
- shader,
979
- shaderProps,
1368
+ shader: shader.shader,
1369
+ shaderProps: shader.getResolvedProps(),
980
1370
  alpha: worldAlpha,
981
1371
  clippingRect,
982
1372
  tx: gt.tx,
@@ -985,6 +1375,7 @@ export class CoreNode extends EventEmitter implements ICoreNode {
985
1375
  tb: gt.tb,
986
1376
  tc: gt.tc,
987
1377
  td: gt.td,
1378
+ renderCoords,
988
1379
  rtt,
989
1380
  parentHasRenderTexture: this.parentHasRenderTexture,
990
1381
  framebufferDimensions: this.framebufferDimensions,
@@ -993,7 +1384,7 @@ export class CoreNode extends EventEmitter implements ICoreNode {
993
1384
 
994
1385
  //#region Properties
995
1386
  get id(): number {
996
- return this.props.id;
1387
+ return this._id;
997
1388
  }
998
1389
 
999
1390
  get x(): number {
@@ -1039,6 +1430,11 @@ export class CoreNode extends EventEmitter implements ICoreNode {
1039
1430
  this.setUpdateType(UpdateType.Local);
1040
1431
 
1041
1432
  if (this.props.rtt) {
1433
+ this.texture = this.stage.txManager.loadTexture('RenderTexture', {
1434
+ width: this.width,
1435
+ height: this.height,
1436
+ });
1437
+ this.textureOptions.preload = true;
1042
1438
  this.setUpdateType(UpdateType.RenderTexture);
1043
1439
  }
1044
1440
  }
@@ -1054,6 +1450,11 @@ export class CoreNode extends EventEmitter implements ICoreNode {
1054
1450
  this.setUpdateType(UpdateType.Local);
1055
1451
 
1056
1452
  if (this.props.rtt) {
1453
+ this.texture = this.stage.txManager.loadTexture('RenderTexture', {
1454
+ width: this.width,
1455
+ height: this.height,
1456
+ });
1457
+ this.textureOptions.preload = true;
1057
1458
  this.setUpdateType(UpdateType.RenderTexture);
1058
1459
  }
1059
1460
  }
@@ -1206,17 +1607,10 @@ export class CoreNode extends EventEmitter implements ICoreNode {
1206
1607
  }
1207
1608
 
1208
1609
  set color(value: number) {
1209
- if (
1210
- this.props.colorTl !== value ||
1211
- this.props.colorTr !== value ||
1212
- this.props.colorBl !== value ||
1213
- this.props.colorBr !== value
1214
- ) {
1215
- this.colorTl = value;
1216
- this.colorTr = value;
1217
- this.colorBl = value;
1218
- this.colorBr = value;
1219
- }
1610
+ this.colorTop = value;
1611
+ this.colorBottom = value;
1612
+ this.colorLeft = value;
1613
+ this.colorRight = value;
1220
1614
  this.props.color = value;
1221
1615
 
1222
1616
  this.setUpdateType(UpdateType.PremultipliedColors);
@@ -1378,9 +1772,11 @@ export class CoreNode extends EventEmitter implements ICoreNode {
1378
1772
  }
1379
1773
 
1380
1774
  set rtt(value: boolean) {
1381
- if (!value) {
1382
- if (this.props.rtt) {
1383
- this.props.rtt = false;
1775
+ if (this.props.rtt === true) {
1776
+ this.props.rtt = value;
1777
+
1778
+ // unload texture if we used to have a render texture
1779
+ if (value === false && this.texture !== null) {
1384
1780
  this.unloadTexture();
1385
1781
  this.setUpdateType(UpdateType.All);
1386
1782
 
@@ -1389,10 +1785,22 @@ export class CoreNode extends EventEmitter implements ICoreNode {
1389
1785
  });
1390
1786
 
1391
1787
  this.stage.renderer?.removeRTTNode(this);
1788
+ return;
1392
1789
  }
1790
+ }
1791
+
1792
+ // if the new value is false and we didnt have rtt previously, we don't need to do anything
1793
+ if (value === false) {
1393
1794
  return;
1394
1795
  }
1395
1796
 
1797
+ // load texture
1798
+ this.texture = this.stage.txManager.loadTexture('RenderTexture', {
1799
+ width: this.width,
1800
+ height: this.height,
1801
+ });
1802
+ this.textureOptions.preload = true;
1803
+
1396
1804
  this.props.rtt = true;
1397
1805
  this.hasRTTupdates = true;
1398
1806
  this.setUpdateType(UpdateType.All);
@@ -1405,6 +1813,41 @@ export class CoreNode extends EventEmitter implements ICoreNode {
1405
1813
  this.stage.renderer?.renderToTexture(this);
1406
1814
  }
1407
1815
 
1816
+ get shader(): BaseShaderController {
1817
+ return this.props.shader;
1818
+ }
1819
+
1820
+ set shader(value: BaseShaderController) {
1821
+ if (this.props.shader === value) {
1822
+ return;
1823
+ }
1824
+
1825
+ this.props.shader = value;
1826
+
1827
+ this.setUpdateType(UpdateType.IsRenderable);
1828
+ }
1829
+
1830
+ get src(): string | null {
1831
+ return this.props.src;
1832
+ }
1833
+
1834
+ set src(imageUrl: string | null) {
1835
+ if (this.props.src === imageUrl) {
1836
+ return;
1837
+ }
1838
+
1839
+ this.props.src = imageUrl;
1840
+
1841
+ if (!imageUrl) {
1842
+ this.texture = null;
1843
+ return;
1844
+ }
1845
+
1846
+ this.texture = this.stage.txManager.loadTexture('ImageTexture', {
1847
+ src: imageUrl,
1848
+ });
1849
+ }
1850
+
1408
1851
  /**
1409
1852
  * Returns the framebuffer dimensions of the node.
1410
1853
  * If the node has a render texture, the dimensions are the same as the node's dimensions.
@@ -1436,9 +1879,53 @@ export class CoreNode extends EventEmitter implements ICoreNode {
1436
1879
  return this.props.texture;
1437
1880
  }
1438
1881
 
1882
+ set texture(value: Texture | null) {
1883
+ if (this.props.texture === value) {
1884
+ return;
1885
+ }
1886
+ const oldTexture = this.props.texture;
1887
+ if (oldTexture) {
1888
+ oldTexture.setRenderableOwner(this, false);
1889
+ this.unloadTexture();
1890
+ }
1891
+ this.props.texture = value;
1892
+ if (value) {
1893
+ value.setRenderableOwner(this, this.isRenderable);
1894
+ this.loadTexture();
1895
+ }
1896
+ this.setUpdateType(UpdateType.IsRenderable);
1897
+ }
1898
+
1899
+ set textureOptions(value: TextureOptions) {
1900
+ this.props.textureOptions = value;
1901
+ }
1902
+
1903
+ get textureOptions(): TextureOptions {
1904
+ return this.props.textureOptions;
1905
+ }
1906
+
1439
1907
  setRTTUpdates(type: number) {
1440
1908
  this.hasRTTupdates = true;
1441
1909
  this.parent?.setRTTUpdates(type);
1442
1910
  }
1911
+
1912
+ animate(
1913
+ props: Partial<CoreNodeAnimateProps>,
1914
+ settings: Partial<AnimationSettings>,
1915
+ ): IAnimationController {
1916
+ const animation = new CoreAnimation(this, props, settings);
1917
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment, @typescript-eslint/no-unsafe-call
1918
+ const controller = new CoreAnimationController(
1919
+ this.stage.animationManager,
1920
+ animation,
1921
+ );
1922
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-return
1923
+ return controller;
1924
+ }
1925
+
1926
+ flush() {
1927
+ // no-op
1928
+ }
1929
+
1443
1930
  //#endregion Properties
1444
1931
  }