@lightningjs/renderer 0.9.4 → 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.
Files changed (289) hide show
  1. package/README.md +0 -82
  2. package/dist/exports/index.d.ts +40 -3
  3. package/dist/exports/index.js +35 -3
  4. package/dist/exports/index.js.map +1 -1
  5. package/dist/src/core/CoreNode.d.ts +462 -46
  6. package/dist/src/core/CoreNode.js +171 -103
  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 +136 -44
  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 +24 -8
  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 +11 -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 +3 -9
  118. package/dist/src/main-api/DynamicShaderController.js +18 -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 +27 -21
  127. package/dist/src/main-api/Renderer.js +38 -107
  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 +60 -3
  137. package/package.json +8 -7
  138. package/src/core/CoreNode.test.ts +93 -0
  139. package/src/core/CoreNode.ts +675 -187
  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 +193 -68
  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 +114 -55
  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 +20 -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 +97 -0
  186. package/src/main-api/INode.ts +56 -479
  187. package/src/main-api/Inspector.ts +37 -39
  188. package/src/main-api/Renderer.ts +543 -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: 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(protected stage: Stage, props: CoreNodeProps) {
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
- // Allow for Render Texture to be processed appropriately
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<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);
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
- this.onTextureLoaded(texture, texture.dimensions!);
718
+ assertTruthy(texture.dimensions);
719
+ this.onTextureLoaded(texture, texture.dimensions);
309
720
  } else if (texture.state === 'failed') {
310
- this.onTextureFailed(texture, texture.error!);
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.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);
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 = (target, dimensions) => {
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 = (target, error) => {
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 = (target: Texture) => {
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
- this.props.rotation,
824
+ rotation,
421
825
  this.scaleRotateTransform,
422
- ).scale(this.props.scaleX, this.props.scaleY);
826
+ ).scale(scaleX, scaleY);
423
827
  }
424
828
 
425
829
  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);
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
- parentClippingRect.x - renderM[3],
716
- parentClippingRect.y - renderM[0],
717
- parentClippingRect.x + rectW + renderM[1],
718
- parentClippingRect.y + rectH + renderM[2],
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
- setRenderState(state: CoreNodeRenderState) {
772
- if (state !== this.renderState) {
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.props.texture?.setRenderableOwner(this, isRenderable);
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 = null;
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, texture, textureOptions, shader, shaderProps, rtt } =
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 { zIndex, worldAlpha, globalTransform: gt, clippingRect } = this;
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.props.id;
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
- 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
- }
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 (!value) {
1382
- if (this.props.rtt) {
1383
- this.props.rtt = false;
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
  }