@lightningjs/renderer 3.0.0-beta1 → 3.0.0-beta10

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 (611) hide show
  1. package/COPYING +1 -0
  2. package/LICENSE +202 -202
  3. package/NOTICE +3 -3
  4. package/README.md +133 -147
  5. package/dist/exports/canvas.d.ts +1 -1
  6. package/dist/exports/canvas.js +1 -1
  7. package/dist/exports/canvas.js.map +1 -1
  8. package/dist/exports/index.d.ts +1 -5
  9. package/dist/exports/index.js +1 -5
  10. package/dist/exports/index.js.map +1 -1
  11. package/dist/exports/utils.d.ts +2 -1
  12. package/dist/exports/utils.js +2 -1
  13. package/dist/exports/utils.js.map +1 -1
  14. package/dist/exports/webgl.d.ts +2 -1
  15. package/dist/exports/webgl.js +2 -1
  16. package/dist/exports/webgl.js.map +1 -1
  17. package/dist/src/core/CoreNode.d.ts +45 -69
  18. package/dist/src/core/CoreNode.js +323 -305
  19. package/dist/src/core/CoreNode.js.map +1 -1
  20. package/dist/src/core/CoreShaderManager.d.ts +3 -5
  21. package/dist/src/core/CoreShaderManager.js.map +1 -1
  22. package/dist/src/core/CoreTextNode.d.ts +58 -87
  23. package/dist/src/core/CoreTextNode.js +243 -237
  24. package/dist/src/core/CoreTextNode.js.map +1 -1
  25. package/dist/src/core/CoreTextureManager.d.ts +9 -11
  26. package/dist/src/core/CoreTextureManager.js +80 -91
  27. package/dist/src/core/CoreTextureManager.js.map +1 -1
  28. package/dist/src/core/Stage.d.ts +75 -31
  29. package/dist/src/core/Stage.js +270 -136
  30. package/dist/src/core/Stage.js.map +1 -1
  31. package/dist/src/core/TextureMemoryManager.d.ts +10 -1
  32. package/dist/src/core/TextureMemoryManager.js +112 -78
  33. package/dist/src/core/TextureMemoryManager.js.map +1 -1
  34. package/dist/src/core/animations/CoreAnimation.js +5 -0
  35. package/dist/src/core/animations/CoreAnimation.js.map +1 -1
  36. package/dist/src/core/animations/CoreAnimationController.d.ts +1 -0
  37. package/dist/src/core/animations/CoreAnimationController.js +11 -4
  38. package/dist/src/core/animations/CoreAnimationController.js.map +1 -1
  39. package/dist/src/core/lib/ImageWorker.js +3 -2
  40. package/dist/src/core/lib/ImageWorker.js.map +1 -1
  41. package/dist/src/core/lib/RenderCoords.d.ts +9 -10
  42. package/dist/src/core/lib/RenderCoords.js +43 -55
  43. package/dist/src/core/lib/RenderCoords.js.map +1 -1
  44. package/dist/src/core/lib/WebGlContextWrapper.d.ts +51 -2
  45. package/dist/src/core/lib/WebGlContextWrapper.js +92 -22
  46. package/dist/src/core/lib/WebGlContextWrapper.js.map +1 -1
  47. package/dist/src/core/lib/colorCache.d.ts +1 -0
  48. package/dist/src/core/lib/colorCache.js +19 -0
  49. package/dist/src/core/lib/colorCache.js.map +1 -0
  50. package/dist/src/core/lib/colorParser.d.ts +21 -0
  51. package/dist/src/core/lib/colorParser.js +72 -0
  52. package/dist/src/core/lib/colorParser.js.map +1 -0
  53. package/dist/src/core/lib/utils.d.ts +3 -0
  54. package/dist/src/core/lib/utils.js +42 -0
  55. package/dist/src/core/lib/utils.js.map +1 -1
  56. package/dist/src/core/lib/validateImageBitmap.d.ts +2 -1
  57. package/dist/src/core/lib/validateImageBitmap.js +4 -4
  58. package/dist/src/core/lib/validateImageBitmap.js.map +1 -1
  59. package/dist/src/core/platforms/Platform.d.ts +37 -0
  60. package/dist/src/{main-api/IRenderDriver.js → core/platforms/Platform.js} +4 -2
  61. package/dist/src/core/platforms/Platform.js.map +1 -0
  62. package/dist/src/core/platforms/web/WebPlatform.d.ts +9 -0
  63. package/dist/src/core/platforms/web/WebPlatform.js +84 -0
  64. package/dist/src/core/platforms/web/WebPlatform.js.map +1 -0
  65. package/dist/src/core/renderers/CoreContextTexture.d.ts +1 -1
  66. package/dist/src/core/renderers/CoreRenderer.d.ts +5 -2
  67. package/dist/src/core/renderers/CoreRenderer.js.map +1 -1
  68. package/dist/src/core/renderers/CoreShaderNode.d.ts +3 -3
  69. package/dist/src/core/renderers/CoreShaderNode.js +8 -2
  70. package/dist/src/core/renderers/CoreShaderNode.js.map +1 -1
  71. package/dist/src/core/renderers/canvas/CanvasRenderer.d.ts +1 -2
  72. package/dist/src/core/renderers/canvas/CanvasRenderer.js +10 -21
  73. package/dist/src/core/renderers/canvas/CanvasRenderer.js.map +1 -1
  74. package/dist/src/core/renderers/canvas/CanvasShaderNode.js +3 -5
  75. package/dist/src/core/renderers/canvas/CanvasShaderNode.js.map +1 -1
  76. package/dist/src/core/renderers/canvas/CanvasTexture.d.ts +2 -2
  77. package/dist/src/core/renderers/canvas/CanvasTexture.js +11 -9
  78. package/dist/src/core/renderers/canvas/CanvasTexture.js.map +1 -1
  79. package/dist/src/core/renderers/webgl/WebGlCtxRenderTexture.js +3 -0
  80. package/dist/src/core/renderers/webgl/WebGlCtxRenderTexture.js.map +1 -1
  81. package/dist/src/core/renderers/webgl/WebGlCtxTexture.d.ts +5 -6
  82. package/dist/src/core/renderers/webgl/WebGlCtxTexture.js +30 -21
  83. package/dist/src/core/renderers/webgl/WebGlCtxTexture.js.map +1 -1
  84. package/dist/src/core/renderers/webgl/WebGlRenderOp.d.ts +10 -2
  85. package/dist/src/core/renderers/webgl/WebGlRenderOp.js +37 -19
  86. package/dist/src/core/renderers/webgl/WebGlRenderOp.js.map +1 -1
  87. package/dist/src/core/renderers/webgl/WebGlRenderer.d.ts +5 -3
  88. package/dist/src/core/renderers/webgl/WebGlRenderer.js +144 -117
  89. package/dist/src/core/renderers/webgl/WebGlRenderer.js.map +1 -1
  90. package/dist/src/core/renderers/webgl/WebGlShaderNode.d.ts +2 -1
  91. package/dist/src/core/renderers/webgl/WebGlShaderNode.js +1 -4
  92. package/dist/src/core/renderers/webgl/WebGlShaderNode.js.map +1 -1
  93. package/dist/src/core/renderers/webgl/WebGlShaderProgram.d.ts +5 -3
  94. package/dist/src/core/renderers/webgl/WebGlShaderProgram.js +55 -31
  95. package/dist/src/core/renderers/webgl/WebGlShaderProgram.js.map +1 -1
  96. package/dist/src/core/renderers/webgl/internal/ShaderUtils.js +35 -35
  97. package/dist/src/core/shaders/canvas/Border.js +1 -1
  98. package/dist/src/core/shaders/canvas/Border.js.map +1 -1
  99. package/dist/src/core/shaders/canvas/LinearGradient.js +5 -3
  100. package/dist/src/core/shaders/canvas/LinearGradient.js.map +1 -1
  101. package/dist/src/core/shaders/canvas/RadialGradient.js +13 -11
  102. package/dist/src/core/shaders/canvas/RadialGradient.js.map +1 -1
  103. package/dist/src/core/shaders/canvas/RoundedWithBorder.js +14 -6
  104. package/dist/src/core/shaders/canvas/RoundedWithBorder.js.map +1 -1
  105. package/dist/src/core/shaders/canvas/RoundedWithBorderAndShadow.js +10 -8
  106. package/dist/src/core/shaders/canvas/RoundedWithBorderAndShadow.js.map +1 -1
  107. package/dist/src/core/shaders/canvas/RoundedWithShadow.js +7 -5
  108. package/dist/src/core/shaders/canvas/RoundedWithShadow.js.map +1 -1
  109. package/dist/src/core/shaders/templates/BorderTemplate.d.ts +1 -1
  110. package/dist/src/core/shaders/templates/BorderTemplate.js +1 -1
  111. package/dist/src/core/shaders/templates/BorderTemplate.js.map +1 -1
  112. package/dist/src/core/shaders/templates/HolePunchTemplate.js +1 -1
  113. package/dist/src/core/shaders/templates/HolePunchTemplate.js.map +1 -1
  114. package/dist/src/core/shaders/templates/RoundedTemplate.js +1 -1
  115. package/dist/src/core/shaders/templates/RoundedTemplate.js.map +1 -1
  116. package/dist/src/core/shaders/templates/RoundedWithBorderAndShadowTemplate.d.ts +1 -1
  117. package/dist/src/core/shaders/templates/RoundedWithBorderTemplate.d.ts +1 -1
  118. package/dist/src/core/shaders/templates/RoundedWithShadowTemplate.d.ts +1 -1
  119. package/dist/src/core/shaders/templates/ShadowTemplate.d.ts +1 -1
  120. package/dist/src/core/shaders/{templates/shaderUtils.d.ts → utils.d.ts} +1 -1
  121. package/dist/src/core/shaders/{templates/shaderUtils.js → utils.js} +2 -2
  122. package/dist/src/core/shaders/utils.js.map +1 -0
  123. package/dist/src/core/shaders/webgl/Border.js +86 -63
  124. package/dist/src/core/shaders/webgl/Border.js.map +1 -1
  125. package/dist/src/core/shaders/webgl/Default.js +47 -47
  126. package/dist/src/core/shaders/webgl/DefaultBatched.js +61 -61
  127. package/dist/src/core/shaders/webgl/HolePunch.js +36 -35
  128. package/dist/src/core/shaders/webgl/HolePunch.js.map +1 -1
  129. package/dist/src/core/shaders/webgl/LinearGradient.js +41 -40
  130. package/dist/src/core/shaders/webgl/LinearGradient.js.map +1 -1
  131. package/dist/src/core/shaders/webgl/RadialGradient.js +39 -38
  132. package/dist/src/core/shaders/webgl/RadialGradient.js.map +1 -1
  133. package/dist/src/core/shaders/webgl/Rounded.js +71 -71
  134. package/dist/src/core/shaders/webgl/RoundedWithBorder.js +115 -72
  135. package/dist/src/core/shaders/webgl/RoundedWithBorder.js.map +1 -1
  136. package/dist/src/core/shaders/webgl/RoundedWithBorderAndShadow.js +138 -88
  137. package/dist/src/core/shaders/webgl/RoundedWithBorderAndShadow.js.map +1 -1
  138. package/dist/src/core/shaders/webgl/RoundedWithShadow.js +54 -54
  139. package/dist/src/core/shaders/webgl/SdfShader.js +63 -63
  140. package/dist/src/core/shaders/webgl/SdfShader.js.map +1 -1
  141. package/dist/src/core/shaders/webgl/Shadow.js +83 -83
  142. package/dist/src/core/text-rendering/CanvasFontHandler.d.ts +25 -0
  143. package/dist/src/core/text-rendering/CanvasFontHandler.js +130 -0
  144. package/dist/src/core/text-rendering/CanvasFontHandler.js.map +1 -0
  145. package/dist/src/core/text-rendering/CanvasTextRenderer.d.ts +22 -0
  146. package/dist/src/core/text-rendering/CanvasTextRenderer.js +366 -0
  147. package/dist/src/core/text-rendering/CanvasTextRenderer.js.map +1 -0
  148. package/dist/src/core/text-rendering/SdfFontHandler.d.ts +137 -0
  149. package/dist/src/core/text-rendering/SdfFontHandler.js +336 -0
  150. package/dist/src/core/text-rendering/SdfFontHandler.js.map +1 -0
  151. package/dist/src/core/text-rendering/SdfTextRenderer.d.ts +17 -0
  152. package/dist/src/core/text-rendering/SdfTextRenderer.js +355 -0
  153. package/dist/src/core/text-rendering/SdfTextRenderer.js.map +1 -0
  154. package/dist/src/core/text-rendering/TextRenderer.d.ts +349 -0
  155. package/dist/src/{main-api/ICoreDriver.js → core/text-rendering/TextRenderer.js} +1 -1
  156. package/dist/src/core/text-rendering/TextRenderer.js.map +1 -0
  157. package/dist/src/core/text-rendering/Utils.d.ts +71 -0
  158. package/dist/src/core/text-rendering/Utils.js +212 -0
  159. package/dist/src/core/text-rendering/Utils.js.map +1 -0
  160. package/dist/src/core/text-rendering/canvas/Settings.d.ts +64 -0
  161. package/dist/src/core/{renderers/CoreShader.js → text-rendering/canvas/Settings.js} +3 -11
  162. package/dist/src/core/text-rendering/canvas/Settings.js.map +1 -0
  163. package/dist/src/core/text-rendering/canvas/Utils.d.ts +20 -0
  164. package/dist/src/core/text-rendering/canvas/Utils.js +144 -0
  165. package/dist/src/core/text-rendering/canvas/Utils.js.map +1 -0
  166. package/dist/src/core/text-rendering/canvas/calculateRenderInfo.d.ts +60 -0
  167. package/dist/src/core/text-rendering/canvas/calculateRenderInfo.js +183 -0
  168. package/dist/src/core/text-rendering/canvas/calculateRenderInfo.js.map +1 -0
  169. package/dist/src/core/text-rendering/canvas/draw.d.ts +5 -0
  170. package/dist/src/core/text-rendering/canvas/draw.js +132 -0
  171. package/dist/src/core/text-rendering/canvas/draw.js.map +1 -0
  172. package/dist/src/core/text-rendering/renderers/CanvasTextRenderer.js +5 -0
  173. package/dist/src/core/text-rendering/renderers/CanvasTextRenderer.js.map +1 -1
  174. package/dist/src/core/text-rendering/renderers/LightningTextTextureRenderer.d.ts +1 -1
  175. package/dist/src/core/text-rendering/renderers/LightningTextTextureRenderer.js +50 -2
  176. package/dist/src/core/text-rendering/renderers/LightningTextTextureRenderer.js.map +1 -1
  177. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.js +9 -54
  178. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.js.map +1 -1
  179. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText.d.ts +1 -1
  180. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText.js +66 -8
  181. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText.js.map +1 -1
  182. package/dist/src/core/text-rendering/renderers/TextRenderer.d.ts +13 -0
  183. package/dist/src/core/text-rendering/renderers/TextRenderer.js +3 -0
  184. package/dist/src/core/text-rendering/renderers/TextRenderer.js.map +1 -1
  185. package/dist/src/core/text-rendering/sdf/Utils.d.ts +26 -0
  186. package/dist/src/core/text-rendering/sdf/Utils.js +304 -0
  187. package/dist/src/core/text-rendering/sdf/Utils.js.map +1 -0
  188. package/dist/src/core/text-rendering/sdf/index.d.ts +1 -0
  189. package/dist/src/{main-api/texture-usage-trackers/TextureUsageTracker.js → core/text-rendering/sdf/index.js} +3 -11
  190. package/dist/src/core/text-rendering/sdf/index.js.map +1 -0
  191. package/dist/src/core/textures/ImageTexture.d.ts +4 -3
  192. package/dist/src/core/textures/ImageTexture.js +36 -9
  193. package/dist/src/core/textures/ImageTexture.js.map +1 -1
  194. package/dist/src/core/textures/Texture.d.ts +21 -2
  195. package/dist/src/core/textures/Texture.js +37 -6
  196. package/dist/src/core/textures/Texture.js.map +1 -1
  197. package/dist/src/core/utils.d.ts +1 -1
  198. package/dist/src/main-api/INode.d.ts +2 -2
  199. package/dist/src/main-api/Inspector.d.ts +6 -1
  200. package/dist/src/main-api/Inspector.js +43 -7
  201. package/dist/src/main-api/Inspector.js.map +1 -1
  202. package/dist/src/main-api/Renderer.d.ts +122 -46
  203. package/dist/src/main-api/Renderer.js +174 -37
  204. package/dist/src/main-api/Renderer.js.map +1 -1
  205. package/dist/src/utils.d.ts +1 -6
  206. package/dist/src/utils.js +2 -9
  207. package/dist/src/utils.js.map +1 -1
  208. package/dist/tsconfig.dist.tsbuildinfo +1 -1
  209. package/exports/canvas-shaders.ts +28 -28
  210. package/exports/canvas.ts +45 -45
  211. package/exports/index.ts +82 -89
  212. package/exports/inspector.ts +24 -24
  213. package/exports/utils.ts +50 -44
  214. package/exports/webgl-shaders.ts +28 -28
  215. package/exports/webgl.ts +52 -50
  216. package/package.json +2 -4
  217. package/src/common/CommonTypes.ts +146 -146
  218. package/src/common/EventEmitter.ts +77 -77
  219. package/src/common/IAnimationController.ts +92 -92
  220. package/src/common/IEventEmitter.ts +28 -28
  221. package/src/core/CoreNode.test.ts +202 -203
  222. package/src/core/CoreNode.ts +2491 -2476
  223. package/src/core/CoreShaderManager.ts +188 -193
  224. package/src/core/CoreTextNode.ts +443 -448
  225. package/src/core/CoreTextureManager.ts +565 -597
  226. package/src/core/Stage.ts +906 -740
  227. package/src/core/TextureMemoryManager.ts +445 -395
  228. package/src/core/animations/AnimationManager.ts +38 -38
  229. package/src/core/animations/CoreAnimation.ts +291 -284
  230. package/src/core/animations/CoreAnimationController.ts +166 -157
  231. package/src/core/lib/ContextSpy.ts +41 -41
  232. package/src/core/lib/ImageWorker.ts +286 -279
  233. package/src/core/lib/Matrix3d.ts +244 -244
  234. package/src/core/lib/RenderCoords.ts +71 -86
  235. package/src/core/lib/WebGlContextWrapper.ts +1381 -1324
  236. package/src/core/lib/colorCache.ts +20 -0
  237. package/src/core/{renderers/canvas/internal/ColorUtils.ts → lib/colorParser.ts} +85 -85
  238. package/src/core/lib/textureCompression.ts +152 -152
  239. package/src/core/lib/textureSvg.ts +78 -78
  240. package/src/core/lib/utils.ts +412 -361
  241. package/src/core/lib/validateImageBitmap.ts +87 -76
  242. package/src/core/platforms/Platform.ts +77 -0
  243. package/src/core/platforms/web/WebPlatform.ts +121 -0
  244. package/src/core/renderers/CoreContextTexture.ts +43 -43
  245. package/src/core/renderers/CoreRenderOp.ts +22 -22
  246. package/src/core/renderers/CoreRenderer.ts +110 -107
  247. package/src/core/renderers/CoreShaderNode.ts +175 -171
  248. package/src/core/renderers/CoreShaderProgram.ts +23 -23
  249. package/src/core/renderers/canvas/CanvasRenderer.ts +283 -299
  250. package/src/core/renderers/canvas/CanvasShaderNode.ts +96 -99
  251. package/src/core/renderers/canvas/CanvasTexture.ts +156 -153
  252. package/src/core/renderers/webgl/WebGlCtxRenderTexture.ts +91 -86
  253. package/src/core/renderers/webgl/WebGlCtxSubTexture.ts +50 -50
  254. package/src/core/renderers/webgl/WebGlCtxTexture.ts +310 -301
  255. package/src/core/renderers/webgl/WebGlRenderOp.ts +167 -145
  256. package/src/core/renderers/webgl/WebGlRenderer.ts +747 -715
  257. package/src/core/renderers/webgl/WebGlShaderNode.ts +435 -433
  258. package/src/core/renderers/webgl/WebGlShaderProgram.ts +341 -310
  259. package/src/core/renderers/webgl/internal/BufferCollection.ts +54 -54
  260. package/src/core/renderers/webgl/internal/RendererUtils.ts +155 -155
  261. package/src/core/renderers/webgl/internal/ShaderUtils.ts +281 -281
  262. package/src/core/renderers/webgl/internal/WebGlUtils.ts +35 -35
  263. package/src/core/shaders/canvas/Border.ts +75 -78
  264. package/src/core/shaders/canvas/HolePunch.ts +62 -62
  265. package/src/core/shaders/canvas/LinearGradient.ts +71 -69
  266. package/src/core/shaders/canvas/RadialGradient.ts +99 -113
  267. package/src/core/shaders/canvas/Rounded.ts +55 -55
  268. package/src/core/shaders/canvas/RoundedWithBorder.ts +74 -68
  269. package/src/core/shaders/canvas/RoundedWithBorderAndShadow.ts +90 -88
  270. package/src/core/shaders/canvas/RoundedWithShadow.ts +70 -69
  271. package/src/core/shaders/canvas/Shadow.ts +52 -52
  272. package/src/core/shaders/canvas/utils/render.ts +151 -151
  273. package/src/core/shaders/templates/BorderTemplate.ts +115 -115
  274. package/src/core/shaders/templates/HolePunchTemplate.ts +82 -82
  275. package/src/core/shaders/templates/LinearGradientTemplate.ts +71 -71
  276. package/src/core/shaders/templates/RadialGradientTemplate.ts +81 -81
  277. package/src/core/shaders/templates/RoundedTemplate.ts +98 -98
  278. package/src/core/shaders/templates/RoundedWithBorderAndShadowTemplate.ts +38 -38
  279. package/src/core/shaders/templates/RoundedWithBorderTemplate.ts +35 -35
  280. package/src/core/shaders/templates/RoundedWithShadowTemplate.ts +35 -35
  281. package/src/core/shaders/templates/ShadowTemplate.ts +106 -106
  282. package/src/core/shaders/{templates/shaderUtils.ts → utils.ts} +46 -47
  283. package/src/core/shaders/webgl/Border.ts +116 -96
  284. package/src/core/shaders/webgl/Default.ts +89 -89
  285. package/src/core/shaders/webgl/DefaultBatched.ts +129 -129
  286. package/src/core/shaders/webgl/HolePunch.ts +75 -78
  287. package/src/core/shaders/webgl/LinearGradient.ts +82 -81
  288. package/src/core/shaders/webgl/RadialGradient.ts +85 -84
  289. package/src/core/shaders/webgl/Rounded.ts +117 -117
  290. package/src/core/shaders/webgl/RoundedWithBorder.ts +155 -114
  291. package/src/core/shaders/webgl/RoundedWithBorderAndShadow.ts +175 -133
  292. package/src/core/shaders/webgl/RoundedWithShadow.ts +98 -98
  293. package/src/core/shaders/webgl/SdfShader.ts +134 -137
  294. package/src/core/shaders/webgl/Shadow.ts +115 -115
  295. package/src/core/text-rendering/CanvasFontHandler.ts +176 -0
  296. package/src/core/text-rendering/CanvasTextRenderer.ts +622 -0
  297. package/src/core/text-rendering/SdfFontHandler.ts +517 -0
  298. package/src/core/text-rendering/SdfTextRenderer.ts +466 -0
  299. package/src/core/text-rendering/TextRenderer.ts +404 -0
  300. package/src/core/text-rendering/{TextTextureRendererUtils.ts → Utils.ts} +257 -263
  301. package/src/core/text-rendering/canvas/Settings.ts +99 -0
  302. package/src/core/text-rendering/canvas/Utils.test.ts +206 -0
  303. package/src/core/text-rendering/canvas/Utils.ts +178 -0
  304. package/src/core/text-rendering/canvas/calculateRenderInfo.ts +299 -0
  305. package/src/core/text-rendering/canvas/draw.ts +165 -0
  306. package/src/core/text-rendering/sdf/Utils.test.ts +402 -0
  307. package/src/core/text-rendering/sdf/Utils.ts +436 -0
  308. package/src/core/text-rendering/sdf/index.ts +20 -0
  309. package/src/core/textures/ColorTexture.ts +102 -102
  310. package/src/core/textures/ImageTexture.ts +418 -376
  311. package/src/core/textures/NoiseTexture.ts +104 -104
  312. package/src/core/textures/RenderTexture.ts +85 -85
  313. package/src/core/textures/SubTexture.ts +205 -205
  314. package/src/core/textures/Texture.ts +381 -337
  315. package/src/core/utils.ts +227 -227
  316. package/src/env.d.ts +7 -7
  317. package/src/main-api/INode.ts +100 -99
  318. package/src/main-api/Inspector.ts +567 -522
  319. package/src/main-api/Renderer.ts +873 -649
  320. package/src/main-api/utils.ts +45 -45
  321. package/src/utils.ts +267 -267
  322. package/dist/exports/core-api.d.ts +0 -74
  323. package/dist/exports/core-api.js +0 -96
  324. package/dist/exports/core-api.js.map +0 -1
  325. package/dist/exports/main-api.d.ts +0 -30
  326. package/dist/exports/main-api.js +0 -45
  327. package/dist/exports/main-api.js.map +0 -1
  328. package/dist/src/core/CoreExtension.d.ts +0 -12
  329. package/dist/src/core/CoreExtension.js +0 -29
  330. package/dist/src/core/CoreExtension.js.map +0 -1
  331. package/dist/src/core/CoreStuff.d.ts +0 -1
  332. package/dist/src/core/CoreStuff.js +0 -138
  333. package/dist/src/core/CoreStuff.js.map +0 -1
  334. package/dist/src/core/CoreTexturizer.d.ts +0 -14
  335. package/dist/src/core/CoreTexturizer.js +0 -47
  336. package/dist/src/core/CoreTexturizer.js.map +0 -1
  337. package/dist/src/core/LngNode.d.ts +0 -736
  338. package/dist/src/core/LngNode.js +0 -1174
  339. package/dist/src/core/LngNode.js.map +0 -1
  340. package/dist/src/core/Matrix2DContext.d.ts +0 -15
  341. package/dist/src/core/Matrix2DContext.js +0 -45
  342. package/dist/src/core/Matrix2DContext.js.map +0 -1
  343. package/dist/src/core/ShaderNode.d.ts +0 -10
  344. package/dist/src/core/ShaderNode.js +0 -30
  345. package/dist/src/core/ShaderNode.js.map +0 -1
  346. package/dist/src/core/TextNode.d.ts +0 -103
  347. package/dist/src/core/TextNode.js +0 -331
  348. package/dist/src/core/TextNode.js.map +0 -1
  349. package/dist/src/core/lib/Coords.d.ts +0 -14
  350. package/dist/src/core/lib/Coords.js +0 -55
  351. package/dist/src/core/lib/Coords.js.map +0 -1
  352. package/dist/src/core/lib/glm/common.d.ts +0 -162
  353. package/dist/src/core/lib/glm/common.js +0 -81
  354. package/dist/src/core/lib/glm/common.js.map +0 -1
  355. package/dist/src/core/lib/glm/index.d.ts +0 -11
  356. package/dist/src/core/lib/glm/index.js +0 -30
  357. package/dist/src/core/lib/glm/index.js.map +0 -1
  358. package/dist/src/core/lib/glm/mat2.d.ts +0 -219
  359. package/dist/src/core/lib/glm/mat2.js +0 -396
  360. package/dist/src/core/lib/glm/mat2.js.map +0 -1
  361. package/dist/src/core/lib/glm/mat2d.d.ts +0 -237
  362. package/dist/src/core/lib/glm/mat2d.js +0 -442
  363. package/dist/src/core/lib/glm/mat2d.js.map +0 -1
  364. package/dist/src/core/lib/glm/mat3.d.ts +0 -283
  365. package/dist/src/core/lib/glm/mat3.js +0 -680
  366. package/dist/src/core/lib/glm/mat3.js.map +0 -1
  367. package/dist/src/core/lib/glm/mat4.d.ts +0 -550
  368. package/dist/src/core/lib/glm/mat4.js +0 -1802
  369. package/dist/src/core/lib/glm/mat4.js.map +0 -1
  370. package/dist/src/core/lib/glm/quat.d.ts +0 -363
  371. package/dist/src/core/lib/glm/quat.js +0 -693
  372. package/dist/src/core/lib/glm/quat.js.map +0 -1
  373. package/dist/src/core/lib/glm/quat2.d.ts +0 -356
  374. package/dist/src/core/lib/glm/quat2.js +0 -754
  375. package/dist/src/core/lib/glm/quat2.js.map +0 -1
  376. package/dist/src/core/lib/glm/vec2.d.ts +0 -365
  377. package/dist/src/core/lib/glm/vec2.js +0 -569
  378. package/dist/src/core/lib/glm/vec2.js.map +0 -1
  379. package/dist/src/core/lib/glm/vec3.d.ts +0 -406
  380. package/dist/src/core/lib/glm/vec3.js +0 -720
  381. package/dist/src/core/lib/glm/vec3.js.map +0 -1
  382. package/dist/src/core/lib/glm/vec4.d.ts +0 -330
  383. package/dist/src/core/lib/glm/vec4.js +0 -608
  384. package/dist/src/core/lib/glm/vec4.js.map +0 -1
  385. package/dist/src/core/platform.d.ts +0 -10
  386. package/dist/src/core/platform.js +0 -56
  387. package/dist/src/core/platform.js.map +0 -1
  388. package/dist/src/core/renderers/CoreShader.d.ts +0 -9
  389. package/dist/src/core/renderers/CoreShader.js.map +0 -1
  390. package/dist/src/core/renderers/CoreShaderManager.d.ts +0 -19
  391. package/dist/src/core/renderers/CoreShaderManager.js +0 -33
  392. package/dist/src/core/renderers/CoreShaderManager.js.map +0 -1
  393. package/dist/src/core/renderers/canvas/CanvasCoreRenderer.d.ts +0 -33
  394. package/dist/src/core/renderers/canvas/CanvasCoreRenderer.js +0 -250
  395. package/dist/src/core/renderers/canvas/CanvasCoreRenderer.js.map +0 -1
  396. package/dist/src/core/renderers/canvas/CanvasCoreTexture.d.ts +0 -16
  397. package/dist/src/core/renderers/canvas/CanvasCoreTexture.js +0 -123
  398. package/dist/src/core/renderers/canvas/CanvasCoreTexture.js.map +0 -1
  399. package/dist/src/core/renderers/canvas/shaders/UnsupportedShader.d.ts +0 -10
  400. package/dist/src/core/renderers/canvas/shaders/UnsupportedShader.js +0 -43
  401. package/dist/src/core/renderers/canvas/shaders/UnsupportedShader.js.map +0 -1
  402. package/dist/src/core/renderers/webgl/WebGlCoreCtxRenderTexture.d.ts +0 -12
  403. package/dist/src/core/renderers/webgl/WebGlCoreCtxRenderTexture.js +0 -55
  404. package/dist/src/core/renderers/webgl/WebGlCoreCtxRenderTexture.js.map +0 -1
  405. package/dist/src/core/renderers/webgl/WebGlCoreCtxSubTexture.d.ts +0 -9
  406. package/dist/src/core/renderers/webgl/WebGlCoreCtxSubTexture.js +0 -38
  407. package/dist/src/core/renderers/webgl/WebGlCoreCtxSubTexture.js.map +0 -1
  408. package/dist/src/core/renderers/webgl/WebGlCoreCtxTexture.d.ts +0 -57
  409. package/dist/src/core/renderers/webgl/WebGlCoreCtxTexture.js +0 -227
  410. package/dist/src/core/renderers/webgl/WebGlCoreCtxTexture.js.map +0 -1
  411. package/dist/src/core/renderers/webgl/WebGlCoreRenderOp.d.ts +0 -34
  412. package/dist/src/core/renderers/webgl/WebGlCoreRenderOp.js +0 -114
  413. package/dist/src/core/renderers/webgl/WebGlCoreRenderOp.js.map +0 -1
  414. package/dist/src/core/renderers/webgl/WebGlCoreRenderer.d.ts +0 -133
  415. package/dist/src/core/renderers/webgl/WebGlCoreRenderer.js +0 -613
  416. package/dist/src/core/renderers/webgl/WebGlCoreRenderer.js.map +0 -1
  417. package/dist/src/core/renderers/webgl/WebGlCoreShader.d.ts +0 -83
  418. package/dist/src/core/renderers/webgl/WebGlCoreShader.js +0 -231
  419. package/dist/src/core/renderers/webgl/WebGlCoreShader.js.map +0 -1
  420. package/dist/src/core/renderers/webgl/WebGlCoreShaderManager.d.ts +0 -27
  421. package/dist/src/core/renderers/webgl/WebGlCoreShaderManager.js +0 -82
  422. package/dist/src/core/renderers/webgl/WebGlCoreShaderManager.js.map +0 -1
  423. package/dist/src/core/renderers/webgl/WebGlCoreShaderProgram.d.ts +0 -11
  424. package/dist/src/core/renderers/webgl/WebGlCoreShaderProgram.js +0 -34
  425. package/dist/src/core/renderers/webgl/WebGlCoreShaderProgram.js.map +0 -1
  426. package/dist/src/core/renderers/webgl/shaders/DefaultShader.d.ts +0 -9
  427. package/dist/src/core/renderers/webgl/shaders/DefaultShader.js +0 -87
  428. package/dist/src/core/renderers/webgl/shaders/DefaultShader.js.map +0 -1
  429. package/dist/src/core/renderers/webgl/shaders/DefaultShaderBatched.d.ts +0 -10
  430. package/dist/src/core/renderers/webgl/shaders/DefaultShaderBatched.js +0 -119
  431. package/dist/src/core/renderers/webgl/shaders/DefaultShaderBatched.js.map +0 -1
  432. package/dist/src/core/renderers/webgl/shaders/DynamicShader.d.ts +0 -29
  433. package/dist/src/core/renderers/webgl/shaders/DynamicShader.js +0 -413
  434. package/dist/src/core/renderers/webgl/shaders/DynamicShader.js.map +0 -1
  435. package/dist/src/core/renderers/webgl/shaders/RoundedRectangle.d.ts +0 -28
  436. package/dist/src/core/renderers/webgl/shaders/RoundedRectangle.js +0 -131
  437. package/dist/src/core/renderers/webgl/shaders/RoundedRectangle.js.map +0 -1
  438. package/dist/src/core/renderers/webgl/shaders/SdfShader.d.ts +0 -47
  439. package/dist/src/core/renderers/webgl/shaders/SdfShader.js +0 -160
  440. package/dist/src/core/renderers/webgl/shaders/SdfShader.js.map +0 -1
  441. package/dist/src/core/renderers/webgl/shaders/effects/BorderBottomEffect.d.ts +0 -31
  442. package/dist/src/core/renderers/webgl/shaders/effects/BorderBottomEffect.js +0 -71
  443. package/dist/src/core/renderers/webgl/shaders/effects/BorderBottomEffect.js.map +0 -1
  444. package/dist/src/core/renderers/webgl/shaders/effects/BorderEffect.d.ts +0 -30
  445. package/dist/src/core/renderers/webgl/shaders/effects/BorderEffect.js +0 -58
  446. package/dist/src/core/renderers/webgl/shaders/effects/BorderEffect.js.map +0 -1
  447. package/dist/src/core/renderers/webgl/shaders/effects/BorderLeftEffect.d.ts +0 -31
  448. package/dist/src/core/renderers/webgl/shaders/effects/BorderLeftEffect.js +0 -71
  449. package/dist/src/core/renderers/webgl/shaders/effects/BorderLeftEffect.js.map +0 -1
  450. package/dist/src/core/renderers/webgl/shaders/effects/BorderRightEffect.d.ts +0 -31
  451. package/dist/src/core/renderers/webgl/shaders/effects/BorderRightEffect.js +0 -71
  452. package/dist/src/core/renderers/webgl/shaders/effects/BorderRightEffect.js.map +0 -1
  453. package/dist/src/core/renderers/webgl/shaders/effects/BorderTopEffect.d.ts +0 -31
  454. package/dist/src/core/renderers/webgl/shaders/effects/BorderTopEffect.js +0 -71
  455. package/dist/src/core/renderers/webgl/shaders/effects/BorderTopEffect.js.map +0 -1
  456. package/dist/src/core/renderers/webgl/shaders/effects/EffectUtils.d.ts +0 -9
  457. package/dist/src/core/renderers/webgl/shaders/effects/EffectUtils.js +0 -136
  458. package/dist/src/core/renderers/webgl/shaders/effects/EffectUtils.js.map +0 -1
  459. package/dist/src/core/renderers/webgl/shaders/effects/FadeOutEffect.d.ts +0 -36
  460. package/dist/src/core/renderers/webgl/shaders/effects/FadeOutEffect.js +0 -85
  461. package/dist/src/core/renderers/webgl/shaders/effects/FadeOutEffect.js.map +0 -1
  462. package/dist/src/core/renderers/webgl/shaders/effects/GlitchEffect.d.ts +0 -45
  463. package/dist/src/core/renderers/webgl/shaders/effects/GlitchEffect.js +0 -104
  464. package/dist/src/core/renderers/webgl/shaders/effects/GlitchEffect.js.map +0 -1
  465. package/dist/src/core/renderers/webgl/shaders/effects/GrayscaleEffect.d.ts +0 -22
  466. package/dist/src/core/renderers/webgl/shaders/effects/GrayscaleEffect.js +0 -45
  467. package/dist/src/core/renderers/webgl/shaders/effects/GrayscaleEffect.js.map +0 -1
  468. package/dist/src/core/renderers/webgl/shaders/effects/HolePunchEffect.d.ts +0 -58
  469. package/dist/src/core/renderers/webgl/shaders/effects/HolePunchEffect.js +0 -80
  470. package/dist/src/core/renderers/webgl/shaders/effects/HolePunchEffect.js.map +0 -1
  471. package/dist/src/core/renderers/webgl/shaders/effects/LinearGradientEffect.d.ts +0 -35
  472. package/dist/src/core/renderers/webgl/shaders/effects/LinearGradientEffect.js +0 -129
  473. package/dist/src/core/renderers/webgl/shaders/effects/LinearGradientEffect.js.map +0 -1
  474. package/dist/src/core/renderers/webgl/shaders/effects/RadialGradientEffect.d.ts +0 -39
  475. package/dist/src/core/renderers/webgl/shaders/effects/RadialGradientEffect.js +0 -116
  476. package/dist/src/core/renderers/webgl/shaders/effects/RadialGradientEffect.js.map +0 -1
  477. package/dist/src/core/renderers/webgl/shaders/effects/RadialProgressEffect.d.ts +0 -61
  478. package/dist/src/core/renderers/webgl/shaders/effects/RadialProgressEffect.js +0 -127
  479. package/dist/src/core/renderers/webgl/shaders/effects/RadialProgressEffect.js.map +0 -1
  480. package/dist/src/core/renderers/webgl/shaders/effects/RadiusEffect.d.ts +0 -40
  481. package/dist/src/core/renderers/webgl/shaders/effects/RadiusEffect.js +0 -71
  482. package/dist/src/core/renderers/webgl/shaders/effects/RadiusEffect.js.map +0 -1
  483. package/dist/src/core/renderers/webgl/shaders/effects/ShaderEffect.d.ts +0 -115
  484. package/dist/src/core/renderers/webgl/shaders/effects/ShaderEffect.js +0 -61
  485. package/dist/src/core/renderers/webgl/shaders/effects/ShaderEffect.js.map +0 -1
  486. package/dist/src/core/scene/Scene.d.ts +0 -59
  487. package/dist/src/core/scene/Scene.js +0 -106
  488. package/dist/src/core/scene/Scene.js.map +0 -1
  489. package/dist/src/core/shaders/templates/shaderUtils.js.map +0 -1
  490. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/makeRenderWindow.d.ts +0 -20
  491. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/makeRenderWindow.js +0 -55
  492. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/makeRenderWindow.js.map +0 -1
  493. package/dist/src/main-api/DynamicShaderController.d.ts +0 -29
  494. package/dist/src/main-api/DynamicShaderController.js +0 -58
  495. package/dist/src/main-api/DynamicShaderController.js.map +0 -1
  496. package/dist/src/main-api/ICoreDriver.d.ts +0 -27
  497. package/dist/src/main-api/ICoreDriver.js.map +0 -1
  498. package/dist/src/main-api/IRenderDriver.d.ts +0 -20
  499. package/dist/src/main-api/IRenderDriver.js.map +0 -1
  500. package/dist/src/main-api/IShaderController.d.ts +0 -14
  501. package/dist/src/main-api/IShaderController.js +0 -30
  502. package/dist/src/main-api/IShaderController.js.map +0 -1
  503. package/dist/src/main-api/IShaderNode.d.ts +0 -17
  504. package/dist/src/main-api/IShaderNode.js +0 -19
  505. package/dist/src/main-api/IShaderNode.js.map +0 -1
  506. package/dist/src/main-api/RendererMain.d.ts +0 -375
  507. package/dist/src/main-api/RendererMain.js +0 -365
  508. package/dist/src/main-api/RendererMain.js.map +0 -1
  509. package/dist/src/main-api/ShaderController.d.ts +0 -31
  510. package/dist/src/main-api/ShaderController.js +0 -37
  511. package/dist/src/main-api/ShaderController.js.map +0 -1
  512. package/dist/src/main-api/texture-usage-trackers/FinalizationRegistryTextureUsageTracker.d.ts +0 -9
  513. package/dist/src/main-api/texture-usage-trackers/FinalizationRegistryTextureUsageTracker.js +0 -38
  514. package/dist/src/main-api/texture-usage-trackers/FinalizationRegistryTextureUsageTracker.js.map +0 -1
  515. package/dist/src/main-api/texture-usage-trackers/ManualCountTextureUsageTracker.d.ts +0 -56
  516. package/dist/src/main-api/texture-usage-trackers/ManualCountTextureUsageTracker.js +0 -101
  517. package/dist/src/main-api/texture-usage-trackers/ManualCountTextureUsageTracker.js.map +0 -1
  518. package/dist/src/main-api/texture-usage-trackers/TextureUsageTracker.d.ts +0 -32
  519. package/dist/src/main-api/texture-usage-trackers/TextureUsageTracker.js.map +0 -1
  520. package/dist/src/render-drivers/main/MainCoreDriver.d.ts +0 -24
  521. package/dist/src/render-drivers/main/MainCoreDriver.js +0 -118
  522. package/dist/src/render-drivers/main/MainCoreDriver.js.map +0 -1
  523. package/dist/src/render-drivers/main/MainOnlyNode.d.ts +0 -99
  524. package/dist/src/render-drivers/main/MainOnlyNode.js +0 -396
  525. package/dist/src/render-drivers/main/MainOnlyNode.js.map +0 -1
  526. package/dist/src/render-drivers/main/MainOnlyShaderController.d.ts +0 -6
  527. package/dist/src/render-drivers/main/MainOnlyShaderController.js +0 -15
  528. package/dist/src/render-drivers/main/MainOnlyShaderController.js.map +0 -1
  529. package/dist/src/render-drivers/main/MainOnlyShaderNode.d.ts +0 -7
  530. package/dist/src/render-drivers/main/MainOnlyShaderNode.js +0 -34
  531. package/dist/src/render-drivers/main/MainOnlyShaderNode.js.map +0 -1
  532. package/dist/src/render-drivers/main/MainOnlyTextNode.d.ts +0 -47
  533. package/dist/src/render-drivers/main/MainOnlyTextNode.js +0 -205
  534. package/dist/src/render-drivers/main/MainOnlyTextNode.js.map +0 -1
  535. package/dist/src/render-drivers/main/MainRenderDriver.d.ts +0 -17
  536. package/dist/src/render-drivers/main/MainRenderDriver.js +0 -88
  537. package/dist/src/render-drivers/main/MainRenderDriver.js.map +0 -1
  538. package/dist/src/render-drivers/threadx/NodeStruct.d.ts +0 -90
  539. package/dist/src/render-drivers/threadx/NodeStruct.js +0 -281
  540. package/dist/src/render-drivers/threadx/NodeStruct.js.map +0 -1
  541. package/dist/src/render-drivers/threadx/SharedNode.d.ts +0 -39
  542. package/dist/src/render-drivers/threadx/SharedNode.js +0 -60
  543. package/dist/src/render-drivers/threadx/SharedNode.js.map +0 -1
  544. package/dist/src/render-drivers/threadx/TextNodeStruct.d.ts +0 -44
  545. package/dist/src/render-drivers/threadx/TextNodeStruct.js +0 -201
  546. package/dist/src/render-drivers/threadx/TextNodeStruct.js.map +0 -1
  547. package/dist/src/render-drivers/threadx/ThreadXCoreDriver.d.ts +0 -28
  548. package/dist/src/render-drivers/threadx/ThreadXCoreDriver.js +0 -234
  549. package/dist/src/render-drivers/threadx/ThreadXCoreDriver.js.map +0 -1
  550. package/dist/src/render-drivers/threadx/ThreadXMainAnimationController.d.ts +0 -20
  551. package/dist/src/render-drivers/threadx/ThreadXMainAnimationController.js +0 -84
  552. package/dist/src/render-drivers/threadx/ThreadXMainAnimationController.js.map +0 -1
  553. package/dist/src/render-drivers/threadx/ThreadXMainNode.d.ts +0 -44
  554. package/dist/src/render-drivers/threadx/ThreadXMainNode.js +0 -154
  555. package/dist/src/render-drivers/threadx/ThreadXMainNode.js.map +0 -1
  556. package/dist/src/render-drivers/threadx/ThreadXMainShaderController.d.ts +0 -6
  557. package/dist/src/render-drivers/threadx/ThreadXMainShaderController.js +0 -16
  558. package/dist/src/render-drivers/threadx/ThreadXMainShaderController.js.map +0 -1
  559. package/dist/src/render-drivers/threadx/ThreadXMainShaderNode.d.ts +0 -7
  560. package/dist/src/render-drivers/threadx/ThreadXMainShaderNode.js +0 -15
  561. package/dist/src/render-drivers/threadx/ThreadXMainShaderNode.js.map +0 -1
  562. package/dist/src/render-drivers/threadx/ThreadXMainTextNode.d.ts +0 -28
  563. package/dist/src/render-drivers/threadx/ThreadXMainTextNode.js +0 -55
  564. package/dist/src/render-drivers/threadx/ThreadXMainTextNode.js.map +0 -1
  565. package/dist/src/render-drivers/threadx/ThreadXRenderDriver.d.ts +0 -21
  566. package/dist/src/render-drivers/threadx/ThreadXRenderDriver.js +0 -198
  567. package/dist/src/render-drivers/threadx/ThreadXRenderDriver.js.map +0 -1
  568. package/dist/src/render-drivers/threadx/ThreadXRendererMessage.d.ts +0 -70
  569. package/dist/src/render-drivers/threadx/ThreadXRendererMessage.js +0 -32
  570. package/dist/src/render-drivers/threadx/ThreadXRendererMessage.js.map +0 -1
  571. package/dist/src/render-drivers/threadx/worker/ThreadXRendererNode.d.ts +0 -19
  572. package/dist/src/render-drivers/threadx/worker/ThreadXRendererNode.js +0 -177
  573. package/dist/src/render-drivers/threadx/worker/ThreadXRendererNode.js.map +0 -1
  574. package/dist/src/render-drivers/threadx/worker/ThreadXRendererTextNode.d.ts +0 -27
  575. package/dist/src/render-drivers/threadx/worker/ThreadXRendererTextNode.js +0 -108
  576. package/dist/src/render-drivers/threadx/worker/ThreadXRendererTextNode.js.map +0 -1
  577. package/dist/src/render-drivers/threadx/worker/renderer.d.ts +0 -1
  578. package/dist/src/render-drivers/threadx/worker/renderer.js +0 -145
  579. package/dist/src/render-drivers/threadx/worker/renderer.js.map +0 -1
  580. package/dist/src/render-drivers/utils.d.ts +0 -12
  581. package/dist/src/render-drivers/utils.js +0 -69
  582. package/dist/src/render-drivers/utils.js.map +0 -1
  583. package/scripts/please-use-pnpm.js +0 -13
  584. package/src/core/platform.ts +0 -64
  585. package/src/core/renderers/canvas/internal/C2DShaderUtils.ts +0 -220
  586. package/src/core/text-rendering/TextRenderingUtils.ts +0 -36
  587. package/src/core/text-rendering/TrFontManager.ts +0 -183
  588. package/src/core/text-rendering/font-face-types/SdfTrFontFace/SdfTrFontFace.ts +0 -176
  589. package/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/FontShaper.ts +0 -139
  590. package/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/SdfFontShaper.test.ts +0 -173
  591. package/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/SdfFontShaper.ts +0 -171
  592. package/src/core/text-rendering/font-face-types/TrFontFace.ts +0 -187
  593. package/src/core/text-rendering/font-face-types/WebTrFontFace.ts +0 -94
  594. package/src/core/text-rendering/font-face-types/utils.ts +0 -39
  595. package/src/core/text-rendering/renderers/CanvasTextRenderer.ts +0 -509
  596. package/src/core/text-rendering/renderers/LightningTextTextureRenderer.ts +0 -815
  597. package/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.ts +0 -841
  598. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/PeekableGenerator.test.ts +0 -48
  599. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/PeekableGenerator.ts +0 -66
  600. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/SpecialCodepoints.ts +0 -52
  601. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/constants.ts +0 -32
  602. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/getStartConditions.ts +0 -117
  603. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/getUnicodeCodepoints.test.ts +0 -133
  604. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/getUnicodeCodepoints.ts +0 -38
  605. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText.ts +0 -408
  606. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/measureText.test.ts +0 -49
  607. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/measureText.ts +0 -52
  608. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/setRenderWindow.test.ts +0 -205
  609. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/setRenderWindow.ts +0 -93
  610. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/util.ts +0 -40
  611. package/src/core/text-rendering/renderers/TextRenderer.ts +0 -550
@@ -1,715 +1,747 @@
1
- /*
2
- * If not stated otherwise in this file or this component's LICENSE file the
3
- * following copyright and licenses apply:
4
- *
5
- * Copyright 2023 Comcast Cable Communications Management, LLC.
6
- *
7
- * Licensed under the Apache License, Version 2.0 (the License);
8
- * you may not use this file except in compliance with the License.
9
- * You may obtain a copy of the License at
10
- *
11
- * http://www.apache.org/licenses/LICENSE-2.0
12
- *
13
- * Unless required by applicable law or agreed to in writing, software
14
- * distributed under the License is distributed on an "AS IS" BASIS,
15
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16
- * See the License for the specific language governing permissions and
17
- * limitations under the License.
18
- */
19
-
20
- import { assertTruthy, createWebGLContext } from '../../../utils.js';
21
- import {
22
- CoreRenderer,
23
- type BufferInfo,
24
- type CoreRendererOptions,
25
- type QuadOptions,
26
- } from '../CoreRenderer.js';
27
- import { WebGlRenderOp } from './WebGlRenderOp.js';
28
- import type { CoreContextTexture } from '../CoreContextTexture.js';
29
- import {
30
- createIndexBuffer,
31
- type CoreWebGlParameters,
32
- type CoreWebGlExtensions,
33
- getWebGlParameters,
34
- getWebGlExtensions,
35
- type WebGlColor,
36
- } from './internal/RendererUtils.js';
37
- import { WebGlCtxTexture } from './WebGlCtxTexture.js';
38
- import { Texture, TextureType } from '../../textures/Texture.js';
39
- import { SubTexture } from '../../textures/SubTexture.js';
40
- import { WebGlCtxSubTexture } from './WebGlCtxSubTexture.js';
41
- import { BufferCollection } from './internal/BufferCollection.js';
42
- import { compareRect, getNormalizedRgbaComponents } from '../../lib/utils.js';
43
- import { WebGlShaderProgram } from './WebGlShaderProgram.js';
44
- import { WebGlContextWrapper } from '../../lib/WebGlContextWrapper.js';
45
- import { RenderTexture } from '../../textures/RenderTexture.js';
46
- import { CoreNodeRenderState, type CoreNode } from '../../CoreNode.js';
47
- import { WebGlCtxRenderTexture } from './WebGlCtxRenderTexture.js';
48
- import { Default } from '../../shaders/webgl/Default.js';
49
- import type { WebGlShaderType } from './WebGlShaderNode.js';
50
- import { WebGlShaderNode } from './WebGlShaderNode.js';
51
- import type { CoreShaderType } from '../CoreShaderNode.js';
52
-
53
- const WORDS_PER_QUAD = 24;
54
- // const BYTES_PER_QUAD = WORDS_PER_QUAD * 4;
55
-
56
- export type WebGlRendererOptions = CoreRendererOptions;
57
-
58
- interface CoreWebGlSystem {
59
- parameters: CoreWebGlParameters;
60
- extensions: CoreWebGlExtensions;
61
- }
62
-
63
- export class WebGlRenderer extends CoreRenderer {
64
- //// WebGL Native Context and Data
65
- glw: WebGlContextWrapper;
66
- system: CoreWebGlSystem;
67
-
68
- //// Persistent data
69
- quadBuffer: ArrayBuffer;
70
- fQuadBuffer: Float32Array;
71
- uiQuadBuffer: Uint32Array;
72
- renderOps: WebGlRenderOp[] = [];
73
-
74
- //// Render Op / Buffer Filling State
75
- curBufferIdx = 0;
76
- curRenderOp: WebGlRenderOp | null = null;
77
- override rttNodes: CoreNode[] = [];
78
- activeRttNode: CoreNode | null = null;
79
-
80
- //// Default Shader
81
- defaultShaderNode: WebGlShaderNode | null = null;
82
- quadBufferCollection: BufferCollection;
83
-
84
- clearColor: WebGlColor = {
85
- raw: 0x00000000,
86
- normalized: [0, 0, 0, 0],
87
- };
88
-
89
- /**
90
- * White pixel texture used by default when no texture is specified.
91
- */
92
-
93
- quadBufferUsage = 0;
94
- numQuadsRendered = 0;
95
- /**
96
- * Whether the renderer is currently rendering to a texture.
97
- */
98
- public renderToTextureActive = false;
99
-
100
- constructor(options: WebGlRendererOptions) {
101
- super(options);
102
-
103
- this.quadBuffer = new ArrayBuffer(this.stage.options.quadBufferSize);
104
- this.fQuadBuffer = new Float32Array(this.quadBuffer);
105
- this.uiQuadBuffer = new Uint32Array(this.quadBuffer);
106
-
107
- this.mode = 'webgl';
108
-
109
- const gl = createWebGLContext(
110
- options.canvas,
111
- options.forceWebGL2,
112
- options.contextSpy,
113
- );
114
- const glw = (this.glw = new WebGlContextWrapper(gl));
115
- glw.viewport(0, 0, options.canvas.width, options.canvas.height);
116
-
117
- this.updateClearColor(this.stage.clearColor);
118
-
119
- glw.setBlend(true);
120
- glw.blendFunc(glw.ONE, glw.ONE_MINUS_SRC_ALPHA);
121
-
122
- createIndexBuffer(glw, this.stage.bufferMemory);
123
-
124
- this.system = {
125
- parameters: getWebGlParameters(this.glw),
126
- extensions: getWebGlExtensions(this.glw),
127
- };
128
- const quadBuffer = glw.createBuffer();
129
- assertTruthy(quadBuffer);
130
- const stride = 8 * Float32Array.BYTES_PER_ELEMENT;
131
- this.quadBufferCollection = new BufferCollection([
132
- {
133
- buffer: quadBuffer,
134
- attributes: {
135
- a_position: {
136
- name: 'a_position',
137
- size: 2, // 2 components per iteration
138
- type: glw.FLOAT, // the data is 32bit floats
139
- normalized: false, // don't normalize the data
140
- stride, // 0 = move forward size * sizeof(type) each iteration to get the next position
141
- offset: 0, // start at the beginning of the buffer
142
- },
143
- a_textureCoords: {
144
- name: 'a_textureCoords',
145
- size: 2,
146
- type: glw.FLOAT,
147
- normalized: false,
148
- stride,
149
- offset: 2 * Float32Array.BYTES_PER_ELEMENT,
150
- },
151
- a_color: {
152
- name: 'a_color',
153
- size: 4,
154
- type: glw.UNSIGNED_BYTE,
155
- normalized: true,
156
- stride,
157
- offset: 4 * Float32Array.BYTES_PER_ELEMENT,
158
- },
159
- a_textureIndex: {
160
- name: 'a_textureIndex',
161
- size: 1,
162
- type: glw.FLOAT,
163
- normalized: false,
164
- stride,
165
- offset: 5 * Float32Array.BYTES_PER_ELEMENT,
166
- },
167
- a_nodeCoords: {
168
- name: 'a_nodeCoords',
169
- size: 2,
170
- type: glw.FLOAT,
171
- normalized: false,
172
- stride,
173
- offset: 6 * Float32Array.BYTES_PER_ELEMENT,
174
- },
175
- },
176
- },
177
- ]);
178
- }
179
-
180
- reset() {
181
- const { glw } = this;
182
- this.curBufferIdx = 0;
183
- this.curRenderOp = null;
184
- this.renderOps.length = 0;
185
- glw.setScissorTest(false);
186
- glw.clear();
187
- }
188
-
189
- createShaderProgram(
190
- shaderType: WebGlShaderType,
191
- props: Record<string, unknown>,
192
- ): WebGlShaderProgram {
193
- return new WebGlShaderProgram(this, shaderType, props);
194
- }
195
-
196
- createShaderNode(
197
- shaderKey: string,
198
- shaderType: WebGlShaderType,
199
- props?: Record<string, unknown>,
200
- program?: WebGlShaderProgram,
201
- ) {
202
- return new WebGlShaderNode(
203
- shaderKey,
204
- shaderType,
205
- program!,
206
- this.stage,
207
- props,
208
- );
209
- }
210
-
211
- override supportsShaderType(shaderType: Readonly<WebGlShaderType>): boolean {
212
- //if shadertype doesnt have a fragment source we cant use it
213
- return shaderType.fragment !== undefined;
214
- }
215
-
216
- createCtxTexture(textureSource: Texture): CoreContextTexture {
217
- if (textureSource instanceof SubTexture) {
218
- return new WebGlCtxSubTexture(
219
- this.glw,
220
- this.stage.txMemManager,
221
- textureSource,
222
- );
223
- } else if (textureSource instanceof RenderTexture) {
224
- return new WebGlCtxRenderTexture(
225
- this.glw,
226
- this.stage.txMemManager,
227
- textureSource,
228
- );
229
- }
230
- return new WebGlCtxTexture(
231
- this.glw,
232
- this.stage.txMemManager,
233
- textureSource,
234
- );
235
- }
236
-
237
- /**
238
- * This function adds a quad (a rectangle composed of two triangles) to the WebGL rendering pipeline.
239
- *
240
- * It takes a set of options that define the quad's properties, such as its dimensions, colors, texture, shader, and transformation matrix.
241
- * The function first updates the shader properties with the current dimensions if necessary, then sets the default texture if none is provided.
242
- * It then checks if a new render operation is needed, based on the current shader and clipping rectangle.
243
- * If a new render operation is needed, it creates one and updates the current render operation.
244
- * The function then adjusts the texture coordinates based on the texture options and adds the texture to the texture manager.
245
- *
246
- * Finally, it calculates the vertices for the quad, taking into account any transformations, and adds them to the quad buffer.
247
- * The function updates the length and number of quads in the current render operation, and updates the current buffer index.
248
- */
249
- addQuad(params: QuadOptions) {
250
- const { fQuadBuffer, uiQuadBuffer } = this;
251
- let texture = params.texture;
252
-
253
- assertTruthy(texture !== null, 'Texture is required');
254
-
255
- let { curBufferIdx: bufferIdx, curRenderOp } = this;
256
-
257
- if (this.reuseRenderOp(params) === false) {
258
- this.newRenderOp(params, bufferIdx);
259
- curRenderOp = this.curRenderOp;
260
- assertTruthy(curRenderOp);
261
- }
262
-
263
- let texCoordX1 = 0;
264
- let texCoordY1 = 0;
265
- let texCoordX2 = 1;
266
- let texCoordY2 = 1;
267
-
268
- if (texture.type === TextureType.subTexture) {
269
- const {
270
- x: tx,
271
- y: ty,
272
- width: tw,
273
- height: th,
274
- } = (texture as SubTexture).props;
275
- const { width: parentW = 0, height: parentH = 0 } = (
276
- texture as SubTexture
277
- ).parentTexture.dimensions || { width: 0, height: 0 };
278
- texCoordX1 = tx / parentW;
279
- texCoordX2 = texCoordX1 + tw / parentW;
280
- texCoordY1 = ty / parentH;
281
- texCoordY2 = texCoordY1 + th / parentH;
282
- texture = (texture as SubTexture).parentTexture;
283
- }
284
-
285
- if (
286
- texture.type === TextureType.image &&
287
- params.textureOptions !== null &&
288
- params.textureOptions.resizeMode !== undefined &&
289
- texture.dimensions !== null
290
- ) {
291
- const resizeMode = params.textureOptions.resizeMode;
292
- const { width: tw, height: th } = texture.dimensions;
293
- if (resizeMode.type === 'cover') {
294
- const scaleX = params.width / tw;
295
- const scaleY = params.height / th;
296
- const scale = Math.max(scaleX, scaleY);
297
- const precision = 1 / scale;
298
- // Determine based on width
299
- if (scale && scaleX && scaleX < scale) {
300
- const desiredSize = precision * params.width;
301
- texCoordX1 = (1 - desiredSize / tw) * (resizeMode.clipX ?? 0.5);
302
- texCoordX2 = texCoordX1 + desiredSize / tw;
303
- }
304
- // Determine based on height
305
- if (scale && scaleY && scaleY < scale) {
306
- const desiredSize = precision * params.height;
307
- texCoordY1 = (1 - desiredSize / th) * (resizeMode.clipY ?? 0.5);
308
- texCoordY2 = texCoordY1 + desiredSize / th;
309
- }
310
- }
311
- }
312
-
313
- // Flip texture coordinates if dictated by texture options
314
- let flipY = 0;
315
- if (params.textureOptions !== null) {
316
- if (params.textureOptions.flipX === true) {
317
- [texCoordX1, texCoordX2] = [texCoordX2, texCoordX1];
318
- }
319
-
320
- // convert to integer for bitwise operation below
321
- flipY = +(params.textureOptions.flipY || false);
322
- }
323
-
324
- // Eitherone should be true
325
- if (flipY ^ +(texture.type === TextureType.renderToTexture)) {
326
- [texCoordY1, texCoordY2] = [texCoordY2, texCoordY1];
327
- }
328
-
329
- const ctxTexture = texture.ctxTexture as WebGlCtxTexture;
330
- assertTruthy(ctxTexture instanceof WebGlCtxTexture);
331
- const textureIdx = this.addTexture(ctxTexture, bufferIdx);
332
-
333
- assertTruthy(this.curRenderOp !== null);
334
- assertTruthy(params.renderCoords);
335
-
336
- // Upper-Left
337
- fQuadBuffer[bufferIdx++] = params.renderCoords.x1; // vertexX
338
- fQuadBuffer[bufferIdx++] = params.renderCoords.y1; // vertexY
339
- fQuadBuffer[bufferIdx++] = texCoordX1; // texCoordX
340
- fQuadBuffer[bufferIdx++] = texCoordY1; // texCoordY
341
- uiQuadBuffer[bufferIdx++] = params.colorTl; // color
342
- fQuadBuffer[bufferIdx++] = textureIdx; // texIndex
343
- fQuadBuffer[bufferIdx++] = 0; //node X coord
344
- fQuadBuffer[bufferIdx++] = 0; //node y coord
345
-
346
- // Upper-Right
347
- fQuadBuffer[bufferIdx++] = params.renderCoords.x2;
348
- fQuadBuffer[bufferIdx++] = params.renderCoords.y2;
349
- fQuadBuffer[bufferIdx++] = texCoordX2;
350
- fQuadBuffer[bufferIdx++] = texCoordY1;
351
- uiQuadBuffer[bufferIdx++] = params.colorTr;
352
- fQuadBuffer[bufferIdx++] = textureIdx;
353
- fQuadBuffer[bufferIdx++] = 1; //node X coord
354
- fQuadBuffer[bufferIdx++] = 0; //node y coord
355
-
356
- // Lower-Left
357
- fQuadBuffer[bufferIdx++] = params.renderCoords.x4;
358
- fQuadBuffer[bufferIdx++] = params.renderCoords.y4;
359
- fQuadBuffer[bufferIdx++] = texCoordX1;
360
- fQuadBuffer[bufferIdx++] = texCoordY2;
361
- uiQuadBuffer[bufferIdx++] = params.colorBl;
362
- fQuadBuffer[bufferIdx++] = textureIdx;
363
- fQuadBuffer[bufferIdx++] = 0; //node X coord
364
- fQuadBuffer[bufferIdx++] = 1; //node y coord
365
-
366
- // Lower-Right
367
- fQuadBuffer[bufferIdx++] = params.renderCoords.x3;
368
- fQuadBuffer[bufferIdx++] = params.renderCoords.y3;
369
- fQuadBuffer[bufferIdx++] = texCoordX2;
370
- fQuadBuffer[bufferIdx++] = texCoordY2;
371
- uiQuadBuffer[bufferIdx++] = params.colorBr;
372
- fQuadBuffer[bufferIdx++] = textureIdx;
373
- fQuadBuffer[bufferIdx++] = 1; //node X coord
374
- fQuadBuffer[bufferIdx++] = 1; //node y coord
375
-
376
- // Update the length of the current render op
377
- this.curRenderOp.length += WORDS_PER_QUAD;
378
- this.curRenderOp.numQuads++;
379
- this.curBufferIdx = bufferIdx;
380
- }
381
-
382
- /**
383
- * Replace the existing RenderOp with a new one that uses the specified Shader
384
- * and starts at the specified buffer index.
385
- *
386
- * @param shader
387
- * @param bufferIdx
388
- */
389
- private newRenderOp(quad: QuadOptions, bufferIdx: number) {
390
- const curRenderOp = new WebGlRenderOp(this, quad, bufferIdx);
391
- this.curRenderOp = curRenderOp;
392
- this.renderOps.push(curRenderOp);
393
- }
394
-
395
- /**
396
- * Add a texture to the current RenderOp. If the texture cannot be added to the
397
- * current RenderOp, a new RenderOp will be created and the texture will be added
398
- * to that one.
399
- *
400
- * If the texture cannot be added to the new RenderOp, an error will be thrown.
401
- *
402
- * @param texture
403
- * @param bufferIdx
404
- * @param recursive
405
- * @returns Assigned Texture Index of the texture in the render op
406
- */
407
- private addTexture(
408
- texture: WebGlCtxTexture,
409
- bufferIdx: number,
410
- recursive?: boolean,
411
- ): number {
412
- assertTruthy(this.curRenderOp);
413
- const textureIdx = this.curRenderOp.addTexture(texture);
414
- // TODO: Refactor to be more DRY
415
- if (textureIdx === 0xffffffff) {
416
- if (recursive) {
417
- throw new Error('Unable to add texture to render op');
418
- }
419
- this.newRenderOp(this.curRenderOp.quad as QuadOptions, bufferIdx);
420
- return this.addTexture(texture, bufferIdx, true);
421
- }
422
- return textureIdx;
423
- }
424
-
425
- /**
426
- * Test if the current Render operation can be reused for the specified parameters.
427
- * @param params
428
- * @returns
429
- */
430
- reuseRenderOp(params: QuadOptions): boolean {
431
- const { shader, parentHasRenderTexture, rtt, clippingRect } = params;
432
-
433
- // Switching shader program will require a new render operation
434
- if (
435
- this.curRenderOp?.shader.shaderKey !==
436
- (shader as WebGlShaderNode).shaderKey
437
- ) {
438
- return false;
439
- }
440
-
441
- // Switching clipping rect will require a new render operation
442
- if (
443
- compareRect(this.curRenderOp.quad.clippingRect, clippingRect) === false
444
- ) {
445
- return false;
446
- }
447
-
448
- // Force new render operation if rendering to texture
449
- // @todo: This needs to be improved, render operations could also be reused
450
- // for rendering to texture
451
- if (parentHasRenderTexture !== undefined || rtt !== undefined) {
452
- return false;
453
- }
454
-
455
- // Check if the shader can batch the shader properties
456
- if (
457
- !this.curRenderOp.shader.program.reuseRenderOp(
458
- params,
459
- this.curRenderOp.quad as QuadOptions,
460
- )
461
- ) {
462
- return false;
463
- }
464
-
465
- // Render operation can be reused
466
- return true;
467
- }
468
-
469
- /**
470
- * add RenderOp to the render pipeline
471
- */
472
- addRenderOp(renderable: WebGlRenderOp) {
473
- this.renderOps.push(renderable);
474
- this.curRenderOp = null;
475
- }
476
-
477
- /**
478
- * Render the current set of RenderOps to render to the specified surface.
479
- *
480
- * TODO: 'screen' is the only supported surface at the moment.
481
- *
482
- * @param surface
483
- */
484
- render(surface: 'screen' | CoreContextTexture = 'screen'): void {
485
- const { glw, quadBuffer } = this;
486
-
487
- const arr = new Float32Array(quadBuffer, 0, this.curBufferIdx);
488
-
489
- const buffer = this.quadBufferCollection.getBuffer('a_position') || null;
490
- glw.arrayBufferData(buffer, arr, glw.STATIC_DRAW);
491
-
492
- for (let i = 0, length = this.renderOps.length; i < length; i++) {
493
- // eslint-disable-next-line @typescript-eslint/no-non-null-assertion
494
- this.renderOps[i]!.draw();
495
- }
496
- this.quadBufferUsage = this.curBufferIdx * arr.BYTES_PER_ELEMENT;
497
-
498
- // Calculate the size of each quad in bytes (4 vertices per quad) times the size of each vertex in bytes
499
- const QUAD_SIZE_IN_BYTES = 4 * (8 * arr.BYTES_PER_ELEMENT); // 8 attributes per vertex
500
- this.numQuadsRendered = this.quadBufferUsage / QUAD_SIZE_IN_BYTES;
501
- }
502
-
503
- getQuadCount(): number {
504
- return this.numQuadsRendered;
505
- }
506
-
507
- renderToTexture(node: CoreNode) {
508
- for (let i = 0; i < this.rttNodes.length; i++) {
509
- if (this.rttNodes[i] === node) {
510
- return;
511
- }
512
- }
513
-
514
- this.insertRTTNodeInOrder(node);
515
- }
516
-
517
- /**
518
- * Inserts an RTT node into `this.rttNodes` while maintaining the correct rendering order based on hierarchy.
519
- *
520
- * Rendering order for RTT nodes is critical when nested RTT nodes exist in a parent-child relationship.
521
- * Specifically:
522
- * - Child RTT nodes must be rendered before their RTT-enabled parents to ensure proper texture composition.
523
- * - If an RTT node is added and it has existing RTT children, it should be rendered after those children.
524
- *
525
- * This function addresses both cases by:
526
- * 1. **Checking Upwards**: It traverses the node's hierarchy upwards to identify any RTT parent
527
- * already in `rttNodes`. If an RTT parent is found, the new node is placed before this parent.
528
- * 2. **Checking Downwards**: It traverses the node’s children recursively to find any RTT-enabled
529
- * children that are already in `rttNodes`. If such children are found, the new node is inserted
530
- * after the last (highest index) RTT child node.
531
- *
532
- * The final calculated insertion index ensures the new node is positioned in `rttNodes` to respect
533
- * both parent-before-child and child-before-parent rendering rules, preserving the correct order
534
- * for the WebGL renderer.
535
- *
536
- * @param node - The RTT-enabled CoreNode to be added to `rttNodes` in the appropriate hierarchical position.
537
- */
538
- private insertRTTNodeInOrder(node: CoreNode) {
539
- let insertIndex = this.rttNodes.length; // Default to the end of the array
540
-
541
- // 1. Traverse upwards to ensure the node is placed before its RTT parent (if any).
542
- let currentNode: CoreNode = node;
543
- while (currentNode) {
544
- if (!currentNode.parent) {
545
- break;
546
- }
547
-
548
- const parentIndex = this.rttNodes.indexOf(currentNode.parent);
549
- if (parentIndex !== -1) {
550
- // Found an RTT parent in the list; set insertIndex to place node before the parent
551
- insertIndex = parentIndex;
552
- break;
553
- }
554
-
555
- currentNode = currentNode.parent;
556
- }
557
-
558
- // 2. Traverse downwards to ensure the node is placed after any RTT children.
559
- // Look through each child recursively to see if any are already in rttNodes.
560
- const maxChildIndex = this.findMaxChildRTTIndex(node);
561
- if (maxChildIndex !== -1) {
562
- // Adjust insertIndex to be after the last child RTT node
563
- insertIndex = Math.max(insertIndex, maxChildIndex + 1);
564
- }
565
-
566
- // 3. Insert the node at the calculated position
567
- this.rttNodes.splice(insertIndex, 0, node);
568
- }
569
-
570
- // Helper function to find the highest index of any RTT children of a node within rttNodes
571
- private findMaxChildRTTIndex(node: CoreNode): number {
572
- let maxIndex = -1;
573
-
574
- const traverseChildren = (currentNode: CoreNode) => {
575
- const currentIndex = this.rttNodes.indexOf(currentNode);
576
- if (currentIndex !== -1) {
577
- maxIndex = Math.max(maxIndex, currentIndex);
578
- }
579
-
580
- // Recursively check all children of the current node
581
- for (const child of currentNode.children) {
582
- traverseChildren(child);
583
- }
584
- };
585
-
586
- // Start traversal directly with the provided node
587
- traverseChildren(node);
588
-
589
- return maxIndex;
590
- }
591
-
592
- renderRTTNodes() {
593
- const { glw } = this;
594
- // Render all associated RTT nodes to their textures
595
- for (let i = 0; i < this.rttNodes.length; i++) {
596
- const node = this.rttNodes[i];
597
-
598
- // Skip nodes that don't have RTT updates
599
- if (node === undefined || node.hasRTTupdates === false) {
600
- continue;
601
- }
602
-
603
- // Skip nodes that are not visible
604
- if (
605
- node.worldAlpha === 0 ||
606
- (node.strictBounds === true &&
607
- node.renderState === CoreNodeRenderState.OutOfBounds)
608
- ) {
609
- continue;
610
- }
611
-
612
- // Skip nodes that do not have a loaded texture
613
- if (node.texture === null || node.texture.state !== 'loaded') {
614
- continue;
615
- }
616
-
617
- // Set the active RTT node to the current node
618
- // So we can prevent rendering children of nested RTT nodes
619
- this.activeRttNode = node;
620
-
621
- assertTruthy(node.texture !== null, 'RTT node missing texture');
622
- const ctxTexture = node.texture.ctxTexture;
623
- assertTruthy(ctxTexture instanceof WebGlCtxRenderTexture);
624
- this.renderToTextureActive = true;
625
-
626
- // Bind the the texture's framebuffer
627
- glw.bindFramebuffer(ctxTexture.framebuffer);
628
-
629
- glw.viewport(0, 0, ctxTexture.w, ctxTexture.h);
630
- // Set the clear color to transparent
631
- glw.clearColor(0, 0, 0, 0);
632
- glw.clear();
633
-
634
- // Render all associated quads to the texture
635
- for (let i = 0; i < node.children.length; i++) {
636
- const child = node.children[i];
637
-
638
- if (child === undefined) {
639
- continue;
640
- }
641
-
642
- this.stage.addQuads(child);
643
- child.hasRTTupdates = false;
644
- }
645
-
646
- // Render all associated quads to the texture
647
- this.render();
648
-
649
- // Reset render operations
650
- this.renderOps.length = 0;
651
- node.hasRTTupdates = false;
652
- }
653
-
654
- const clearColor = this.clearColor.normalized;
655
- // Restore the default clear color
656
- glw.clearColor(clearColor[0], clearColor[1], clearColor[2], clearColor[3]);
657
-
658
- // Bind the default framebuffer
659
- glw.bindFramebuffer(null);
660
-
661
- glw.viewport(0, 0, this.glw.canvas.width, this.glw.canvas.height);
662
- this.renderToTextureActive = false;
663
- }
664
-
665
- removeRTTNode(node: CoreNode) {
666
- const index = this.rttNodes.indexOf(node);
667
- if (index === -1) {
668
- return;
669
- }
670
- this.rttNodes.splice(index, 1);
671
- }
672
-
673
- getBufferInfo(): BufferInfo | null {
674
- const bufferInfo: BufferInfo = {
675
- totalAvailable: this.stage.options.quadBufferSize,
676
- totalUsed: this.quadBufferUsage,
677
- };
678
- return bufferInfo;
679
- }
680
-
681
- getDefaultShaderNode(): WebGlShaderNode {
682
- if (this.defaultShaderNode !== null) {
683
- return this.defaultShaderNode as WebGlShaderNode;
684
- }
685
- this.stage.shManager.registerShaderType('Default', Default);
686
- this.defaultShaderNode = this.stage.shManager.createShader(
687
- 'Default',
688
- ) as WebGlShaderNode;
689
- return this.defaultShaderNode;
690
- }
691
-
692
- /**
693
- * Updates the WebGL context's clear color and clears the color buffer.
694
- *
695
- * @param color - The color to set as the clear color, represented as a 32-bit integer.
696
- */
697
- updateClearColor(color: number) {
698
- if (this.clearColor.raw === color) {
699
- return;
700
- }
701
- const glw = this.glw;
702
- const normalizedColor = getNormalizedRgbaComponents(color);
703
- glw.clearColor(
704
- normalizedColor[0],
705
- normalizedColor[1],
706
- normalizedColor[2],
707
- normalizedColor[3],
708
- );
709
- this.clearColor = {
710
- raw: color,
711
- normalized: normalizedColor,
712
- };
713
- glw.clear();
714
- }
715
- }
1
+ /*
2
+ * If not stated otherwise in this file or this component's LICENSE file the
3
+ * following copyright and licenses apply:
4
+ *
5
+ * Copyright 2023 Comcast Cable Communications Management, LLC.
6
+ *
7
+ * Licensed under the Apache License, Version 2.0 (the License);
8
+ * you may not use this file except in compliance with the License.
9
+ * You may obtain a copy of the License at
10
+ *
11
+ * http://www.apache.org/licenses/LICENSE-2.0
12
+ *
13
+ * Unless required by applicable law or agreed to in writing, software
14
+ * distributed under the License is distributed on an "AS IS" BASIS,
15
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16
+ * See the License for the specific language governing permissions and
17
+ * limitations under the License.
18
+ */
19
+
20
+ import { createWebGLContext } from '../../../utils.js';
21
+ import {
22
+ CoreRenderer,
23
+ type BufferInfo,
24
+ type CoreRendererOptions,
25
+ type QuadOptions,
26
+ } from '../CoreRenderer.js';
27
+ import { WebGlRenderOp } from './WebGlRenderOp.js';
28
+ import type { CoreContextTexture } from '../CoreContextTexture.js';
29
+ import {
30
+ createIndexBuffer,
31
+ type CoreWebGlParameters,
32
+ type CoreWebGlExtensions,
33
+ getWebGlParameters,
34
+ getWebGlExtensions,
35
+ type WebGlColor,
36
+ } from './internal/RendererUtils.js';
37
+ import { WebGlCtxTexture } from './WebGlCtxTexture.js';
38
+ import {
39
+ Texture,
40
+ TextureType,
41
+ type TextureCoords,
42
+ } from '../../textures/Texture.js';
43
+ import { SubTexture } from '../../textures/SubTexture.js';
44
+ import { WebGlCtxSubTexture } from './WebGlCtxSubTexture.js';
45
+ import { BufferCollection } from './internal/BufferCollection.js';
46
+ import { compareRect, getNormalizedRgbaComponents } from '../../lib/utils.js';
47
+ import { WebGlShaderProgram } from './WebGlShaderProgram.js';
48
+ import { WebGlContextWrapper } from '../../lib/WebGlContextWrapper.js';
49
+ import { RenderTexture } from '../../textures/RenderTexture.js';
50
+ import { CoreNodeRenderState, type CoreNode } from '../../CoreNode.js';
51
+ import { WebGlCtxRenderTexture } from './WebGlCtxRenderTexture.js';
52
+ import { Default } from '../../shaders/webgl/Default.js';
53
+ import type { WebGlShaderType } from './WebGlShaderNode.js';
54
+ import { WebGlShaderNode } from './WebGlShaderNode.js';
55
+
56
+ export type WebGlRendererOptions = CoreRendererOptions;
57
+
58
+ interface CoreWebGlSystem {
59
+ parameters: CoreWebGlParameters;
60
+ extensions: CoreWebGlExtensions;
61
+ }
62
+
63
+ export class WebGlRenderer extends CoreRenderer {
64
+ //// WebGL Native Context and Data
65
+ glw: WebGlContextWrapper;
66
+ system: CoreWebGlSystem;
67
+
68
+ //// Persistent data
69
+ quadBuffer: ArrayBuffer;
70
+ fQuadBuffer: Float32Array;
71
+ uiQuadBuffer: Uint32Array;
72
+ renderOps: WebGlRenderOp[] = [];
73
+
74
+ //// Render Op / Buffer Filling State
75
+ curBufferIdx = 0;
76
+ curRenderOp: WebGlRenderOp | null = null;
77
+ override rttNodes: CoreNode[] = [];
78
+ activeRttNode: CoreNode | null = null;
79
+
80
+ defaultTextureCoords: TextureCoords = {
81
+ x1: 0,
82
+ y1: 0,
83
+ x2: 1,
84
+ y2: 1,
85
+ };
86
+
87
+ //// Default Shader
88
+ defaultShaderNode: WebGlShaderNode | null = null;
89
+ quadBufferCollection: BufferCollection;
90
+
91
+ clearColor: WebGlColor = {
92
+ raw: 0x00000000,
93
+ normalized: [0, 0, 0, 0],
94
+ };
95
+
96
+ /**
97
+ * White pixel texture used by default when no texture is specified.
98
+ */
99
+
100
+ quadBufferUsage = 0;
101
+ numQuadsRendered = 0;
102
+ /**
103
+ * Whether the renderer is currently rendering to a texture.
104
+ */
105
+ public renderToTextureActive = false;
106
+
107
+ constructor(options: WebGlRendererOptions) {
108
+ super(options);
109
+
110
+ this.quadBuffer = new ArrayBuffer(this.stage.options.quadBufferSize);
111
+ this.fQuadBuffer = new Float32Array(this.quadBuffer);
112
+ this.uiQuadBuffer = new Uint32Array(this.quadBuffer);
113
+
114
+ this.mode = 'webgl';
115
+
116
+ const gl = createWebGLContext(
117
+ options.canvas,
118
+ options.forceWebGL2,
119
+ options.contextSpy,
120
+ );
121
+ const glw = (this.glw = new WebGlContextWrapper(gl));
122
+ glw.viewport(0, 0, options.canvas.width, options.canvas.height);
123
+
124
+ this.updateClearColor(this.stage.clearColor);
125
+
126
+ glw.setBlend(true);
127
+ glw.blendFunc(glw.ONE, glw.ONE_MINUS_SRC_ALPHA);
128
+
129
+ createIndexBuffer(glw, this.stage.bufferMemory);
130
+
131
+ this.system = {
132
+ parameters: getWebGlParameters(this.glw),
133
+ extensions: getWebGlExtensions(this.glw),
134
+ };
135
+ const quadBuffer = glw.createBuffer();
136
+ const stride = 8 * Float32Array.BYTES_PER_ELEMENT;
137
+ this.quadBufferCollection = new BufferCollection([
138
+ {
139
+ buffer: quadBuffer!,
140
+ attributes: {
141
+ a_position: {
142
+ name: 'a_position',
143
+ size: 2, // 2 components per iteration
144
+ type: glw.FLOAT, // the data is 32bit floats
145
+ normalized: false, // don't normalize the data
146
+ stride, // 0 = move forward size * sizeof(type) each iteration to get the next position
147
+ offset: 0, // start at the beginning of the buffer
148
+ },
149
+ a_textureCoords: {
150
+ name: 'a_textureCoords',
151
+ size: 2,
152
+ type: glw.FLOAT,
153
+ normalized: false,
154
+ stride,
155
+ offset: 2 * Float32Array.BYTES_PER_ELEMENT,
156
+ },
157
+ a_color: {
158
+ name: 'a_color',
159
+ size: 4,
160
+ type: glw.UNSIGNED_BYTE,
161
+ normalized: true,
162
+ stride,
163
+ offset: 4 * Float32Array.BYTES_PER_ELEMENT,
164
+ },
165
+ a_textureIndex: {
166
+ name: 'a_textureIndex',
167
+ size: 1,
168
+ type: glw.FLOAT,
169
+ normalized: false,
170
+ stride,
171
+ offset: 5 * Float32Array.BYTES_PER_ELEMENT,
172
+ },
173
+ a_nodeCoords: {
174
+ name: 'a_nodeCoords',
175
+ size: 2,
176
+ type: glw.FLOAT,
177
+ normalized: false,
178
+ stride,
179
+ offset: 6 * Float32Array.BYTES_PER_ELEMENT,
180
+ },
181
+ },
182
+ },
183
+ ]);
184
+ }
185
+
186
+ reset() {
187
+ const { glw } = this;
188
+ this.curBufferIdx = 0;
189
+ this.curRenderOp = null;
190
+ this.renderOps.length = 0;
191
+ glw.setScissorTest(false);
192
+ glw.clear();
193
+ }
194
+
195
+ createShaderProgram(
196
+ shaderType: WebGlShaderType,
197
+ props: Record<string, unknown>,
198
+ ): WebGlShaderProgram {
199
+ return new WebGlShaderProgram(this, shaderType, props);
200
+ }
201
+
202
+ createShaderNode(
203
+ shaderKey: string,
204
+ shaderType: WebGlShaderType,
205
+ props?: Record<string, unknown>,
206
+ program?: WebGlShaderProgram,
207
+ ) {
208
+ return new WebGlShaderNode(
209
+ shaderKey,
210
+ shaderType,
211
+ program!,
212
+ this.stage,
213
+ props,
214
+ );
215
+ }
216
+
217
+ override supportsShaderType(shaderType: Readonly<WebGlShaderType>): boolean {
218
+ //if shadertype doesnt have a fragment source we cant use it
219
+ return shaderType.fragment !== undefined;
220
+ }
221
+
222
+ createCtxTexture(textureSource: Texture): CoreContextTexture {
223
+ if (textureSource instanceof SubTexture) {
224
+ return new WebGlCtxSubTexture(
225
+ this.glw,
226
+ this.stage.txMemManager,
227
+ textureSource,
228
+ );
229
+ } else if (textureSource instanceof RenderTexture) {
230
+ return new WebGlCtxRenderTexture(
231
+ this.glw,
232
+ this.stage.txMemManager,
233
+ textureSource,
234
+ );
235
+ }
236
+ return new WebGlCtxTexture(
237
+ this.glw,
238
+ this.stage.txMemManager,
239
+ textureSource,
240
+ );
241
+ }
242
+
243
+ /**
244
+ * This function adds a quad (a rectangle composed of two triangles) to the WebGL rendering pipeline.
245
+ *
246
+ * It takes a set of options that define the quad's properties, such as its dimensions, colors, texture, shader, and transformation matrix.
247
+ * The function first updates the shader properties with the current dimensions if necessary, then sets the default texture if none is provided.
248
+ * It then checks if a new render operation is needed, based on the current shader and clipping rectangle.
249
+ * If a new render operation is needed, it creates one and updates the current render operation.
250
+ * The function then adjusts the texture coordinates based on the texture options and adds the texture to the texture manager.
251
+ *
252
+ * Finally, it calculates the vertices for the quad, taking into account any transformations, and adds them to the quad buffer.
253
+ * The function updates the length and number of quads in the current render operation, and updates the current buffer index.
254
+ */
255
+ addQuad(params: QuadOptions) {
256
+ const f = this.fQuadBuffer;
257
+ const u = this.uiQuadBuffer;
258
+ let i = this.curBufferIdx;
259
+
260
+ let ro = this.curRenderOp!;
261
+ const reuse = this.reuseRenderOp(params) === false;
262
+ if (reuse) {
263
+ this.newRenderOp(params, i);
264
+ ro = this.curRenderOp!;
265
+ }
266
+
267
+ let tx = params.texture!;
268
+ if (tx.type === TextureType.subTexture) {
269
+ tx = (tx as SubTexture).parentTexture;
270
+ }
271
+
272
+ const tidx = this.addTexture(tx.ctxTexture as WebGlCtxTexture, i);
273
+
274
+ const rc = params.renderCoords!;
275
+ const tc = params.textureCoords!;
276
+
277
+ const cTl = params.colorTl;
278
+ const cTr = params.colorTr;
279
+ const cBl = params.colorBl;
280
+ const cBr = params.colorBr;
281
+
282
+ // Upper-Left
283
+ f[i] = rc.x1;
284
+ f[i + 1] = rc.y1;
285
+ f[i + 2] = tc.x1;
286
+ f[i + 3] = tc.y1;
287
+ u[i + 4] = cTl;
288
+ f[i + 5] = tidx;
289
+ f[i + 6] = 0;
290
+ f[i + 7] = 0;
291
+
292
+ // Upper-Right
293
+ f[i + 8] = rc.x2;
294
+ f[i + 9] = rc.y2;
295
+ f[i + 10] = tc.x2;
296
+ f[i + 11] = tc.y1;
297
+ u[i + 12] = cTr;
298
+ f[i + 13] = tidx;
299
+ f[i + 14] = 1;
300
+ f[i + 15] = 0;
301
+
302
+ // Lower-Left
303
+ f[i + 16] = rc.x4;
304
+ f[i + 17] = rc.y4;
305
+ f[i + 18] = tc.x1;
306
+ f[i + 19] = tc.y2;
307
+ u[i + 20] = cBl;
308
+ f[i + 21] = tidx;
309
+ f[i + 22] = 0;
310
+ f[i + 23] = 1;
311
+
312
+ // Lower-Right
313
+ f[i + 24] = rc.x3;
314
+ f[i + 25] = rc.y3;
315
+ f[i + 26] = tc.x2;
316
+ f[i + 27] = tc.y2;
317
+ u[i + 28] = cBr;
318
+ f[i + 29] = tidx;
319
+ f[i + 30] = 1;
320
+ f[i + 31] = 1;
321
+
322
+ ro.numQuads++;
323
+ this.curBufferIdx = i + 32;
324
+ }
325
+
326
+ /**
327
+ * Replace the existing RenderOp with a new one that uses the specified Shader
328
+ * and starts at the specified buffer index.
329
+ *
330
+ * @param shader
331
+ * @param bufferIdx
332
+ */
333
+ private newRenderOp(quad: QuadOptions | WebGlRenderOp, bufferIdx: number) {
334
+ const curRenderOp = new WebGlRenderOp(this, quad, bufferIdx);
335
+ this.curRenderOp = curRenderOp;
336
+ this.renderOps.push(curRenderOp);
337
+ }
338
+
339
+ /**
340
+ * Add a texture to the current RenderOp. If the texture cannot be added to the
341
+ * current RenderOp, a new RenderOp will be created and the texture will be added
342
+ * to that one.
343
+ *
344
+ * If the texture cannot be added to the new RenderOp, an error will be thrown.
345
+ *
346
+ * @param texture
347
+ * @param bufferIdx
348
+ * @param recursive
349
+ * @returns Assigned Texture Index of the texture in the render op
350
+ */
351
+ private addTexture(
352
+ texture: WebGlCtxTexture,
353
+ bufferIdx: number,
354
+ recursive?: boolean,
355
+ ): number {
356
+ const textureIdx = this.curRenderOp!.addTexture(texture);
357
+ // TODO: Refactor to be more DRY
358
+ if (textureIdx === 0xffffffff) {
359
+ if (recursive) {
360
+ throw new Error('Unable to add texture to render op');
361
+ }
362
+ this.newRenderOp(this.curRenderOp!, bufferIdx);
363
+ return this.addTexture(texture, bufferIdx, true);
364
+ }
365
+ return textureIdx;
366
+ }
367
+
368
+ /**
369
+ * Test if the current Render operation can be reused for the specified parameters.
370
+ * @param params
371
+ * @returns
372
+ */
373
+ reuseRenderOp(params: QuadOptions): boolean {
374
+ // Switching shader program will require a new render operation
375
+ if (
376
+ this.curRenderOp?.shader.shaderKey !==
377
+ (params.shader as WebGlShaderNode).shaderKey
378
+ ) {
379
+ return false;
380
+ }
381
+
382
+ // Switching clipping rect will require a new render operation
383
+ if (
384
+ compareRect(this.curRenderOp.clippingRect, params.clippingRect) === false
385
+ ) {
386
+ return false;
387
+ }
388
+
389
+ // Force new render operation if rendering to texture
390
+ // @todo: This needs to be improved, render operations could also be reused
391
+ // for rendering to texture
392
+ if (
393
+ params.parentHasRenderTexture !== undefined ||
394
+ params.rtt !== undefined
395
+ ) {
396
+ return false;
397
+ }
398
+
399
+ if (
400
+ this.curRenderOp.shader.shaderKey === 'default' &&
401
+ params.shader?.shaderKey === 'default'
402
+ ) {
403
+ return true;
404
+ }
405
+
406
+ // Check if the shader can batch the shader properties
407
+ if (
408
+ this.curRenderOp.shader.program.reuseRenderOp(
409
+ params,
410
+ this.curRenderOp,
411
+ ) === false
412
+ ) {
413
+ return false;
414
+ }
415
+
416
+ // Render operation can be reused
417
+ return true;
418
+ }
419
+
420
+ /**
421
+ * add RenderOp to the render pipeline
422
+ */
423
+ addRenderOp(renderable: WebGlRenderOp) {
424
+ this.renderOps.push(renderable);
425
+ this.curRenderOp = null;
426
+ }
427
+
428
+ /**
429
+ * Render the current set of RenderOps to render to the specified surface.
430
+ *
431
+ * TODO: 'screen' is the only supported surface at the moment.
432
+ *
433
+ * @param surface
434
+ */
435
+ render(surface: 'screen' | CoreContextTexture = 'screen'): void {
436
+ const { glw, quadBuffer } = this;
437
+
438
+ const arr = new Float32Array(quadBuffer, 0, this.curBufferIdx);
439
+
440
+ const buffer = this.quadBufferCollection.getBuffer('a_position') || null;
441
+ glw.arrayBufferData(buffer, arr, glw.STATIC_DRAW);
442
+
443
+ for (let i = 0, length = this.renderOps.length; i < length; i++) {
444
+ // eslint-disable-next-line @typescript-eslint/no-non-null-assertion
445
+ this.renderOps[i]!.draw();
446
+ }
447
+ this.quadBufferUsage = this.curBufferIdx * arr.BYTES_PER_ELEMENT;
448
+
449
+ // Calculate the size of each quad in bytes (4 vertices per quad) times the size of each vertex in bytes
450
+ const QUAD_SIZE_IN_BYTES = 4 * (8 * arr.BYTES_PER_ELEMENT); // 8 attributes per vertex
451
+ this.numQuadsRendered = this.quadBufferUsage / QUAD_SIZE_IN_BYTES;
452
+ }
453
+
454
+ getQuadCount(): number {
455
+ return this.numQuadsRendered;
456
+ }
457
+
458
+ renderToTexture(node: CoreNode) {
459
+ for (let i = 0; i < this.rttNodes.length; i++) {
460
+ if (this.rttNodes[i] === node) {
461
+ return;
462
+ }
463
+ }
464
+
465
+ this.insertRTTNodeInOrder(node);
466
+ }
467
+
468
+ /**
469
+ * Inserts an RTT node into `this.rttNodes` while maintaining the correct rendering order based on hierarchy.
470
+ *
471
+ * Rendering order for RTT nodes is critical when nested RTT nodes exist in a parent-child relationship.
472
+ * Specifically:
473
+ * - Child RTT nodes must be rendered before their RTT-enabled parents to ensure proper texture composition.
474
+ * - If an RTT node is added and it has existing RTT children, it should be rendered after those children.
475
+ *
476
+ * This function addresses both cases by:
477
+ * 1. **Checking Upwards**: It traverses the node's hierarchy upwards to identify any RTT parent
478
+ * already in `rttNodes`. If an RTT parent is found, the new node is placed before this parent.
479
+ * 2. **Checking Downwards**: It traverses the node’s children recursively to find any RTT-enabled
480
+ * children that are already in `rttNodes`. If such children are found, the new node is inserted
481
+ * after the last (highest index) RTT child node.
482
+ *
483
+ * The final calculated insertion index ensures the new node is positioned in `rttNodes` to respect
484
+ * both parent-before-child and child-before-parent rendering rules, preserving the correct order
485
+ * for the WebGL renderer.
486
+ *
487
+ * @param node - The RTT-enabled CoreNode to be added to `rttNodes` in the appropriate hierarchical position.
488
+ */
489
+ private insertRTTNodeInOrder(node: CoreNode) {
490
+ let insertIndex = this.rttNodes.length; // Default to the end of the array
491
+
492
+ // 1. Traverse upwards to ensure the node is placed before its RTT parent (if any).
493
+ let currentNode: CoreNode = node;
494
+ while (currentNode) {
495
+ if (!currentNode.parent) {
496
+ break;
497
+ }
498
+
499
+ const parentIndex = this.rttNodes.indexOf(currentNode.parent);
500
+ if (parentIndex !== -1) {
501
+ // Found an RTT parent in the list; set insertIndex to place node before the parent
502
+ insertIndex = parentIndex;
503
+ break;
504
+ }
505
+
506
+ currentNode = currentNode.parent;
507
+ }
508
+
509
+ // 2. Traverse downwards to ensure the node is placed after any RTT children.
510
+ // Look through each child recursively to see if any are already in rttNodes.
511
+ const maxChildIndex = this.findMaxChildRTTIndex(node);
512
+ if (maxChildIndex !== -1) {
513
+ // Adjust insertIndex to be after the last child RTT node
514
+ insertIndex = Math.max(insertIndex, maxChildIndex + 1);
515
+ }
516
+
517
+ // 3. Insert the node at the calculated position
518
+ this.rttNodes.splice(insertIndex, 0, node);
519
+ }
520
+
521
+ // Helper function to find the highest index of any RTT children of a node within rttNodes
522
+ private findMaxChildRTTIndex(node: CoreNode): number {
523
+ let maxIndex = -1;
524
+
525
+ const traverseChildren = (currentNode: CoreNode) => {
526
+ const currentIndex = this.rttNodes.indexOf(currentNode);
527
+ if (currentIndex !== -1) {
528
+ maxIndex = Math.max(maxIndex, currentIndex);
529
+ }
530
+
531
+ // Recursively check all children of the current node
532
+ for (const child of currentNode.children) {
533
+ traverseChildren(child);
534
+ }
535
+ };
536
+
537
+ // Start traversal directly with the provided node
538
+ traverseChildren(node);
539
+
540
+ return maxIndex;
541
+ }
542
+
543
+ renderRTTNodes() {
544
+ const { glw } = this;
545
+ // Render all associated RTT nodes to their textures
546
+ for (let i = 0; i < this.rttNodes.length; i++) {
547
+ const node = this.rttNodes[i];
548
+
549
+ // Skip nodes that don't have RTT updates
550
+ if (node === undefined || node.hasRTTupdates === false) {
551
+ continue;
552
+ }
553
+
554
+ // Skip nodes that are not visible
555
+ if (
556
+ node.worldAlpha === 0 ||
557
+ (node.strictBounds === true &&
558
+ node.renderState === CoreNodeRenderState.OutOfBounds)
559
+ ) {
560
+ continue;
561
+ }
562
+
563
+ // Skip nodes that do not have a loaded texture
564
+ if (node.texture === null || node.texture.state !== 'loaded') {
565
+ continue;
566
+ }
567
+
568
+ // Set the active RTT node to the current node
569
+ // So we can prevent rendering children of nested RTT nodes
570
+ this.activeRttNode = node;
571
+ const ctxTexture = node.texture.ctxTexture as WebGlCtxRenderTexture;
572
+ this.renderToTextureActive = true;
573
+
574
+ // Bind the the texture's framebuffer
575
+ glw.bindFramebuffer(ctxTexture.framebuffer);
576
+
577
+ glw.viewport(0, 0, ctxTexture.w, ctxTexture.h);
578
+ // Set the clear color to transparent
579
+ glw.clearColor(0, 0, 0, 0);
580
+ glw.clear();
581
+
582
+ // Render all associated quads to the texture
583
+ for (let i = 0; i < node.children.length; i++) {
584
+ const child = node.children[i];
585
+
586
+ if (child === undefined) {
587
+ continue;
588
+ }
589
+
590
+ this.stage.addQuads(child);
591
+ child.hasRTTupdates = false;
592
+ }
593
+
594
+ // Render all associated quads to the texture
595
+ this.render();
596
+
597
+ // Reset render operations
598
+ this.renderOps.length = 0;
599
+ node.hasRTTupdates = false;
600
+ }
601
+
602
+ const clearColor = this.clearColor.normalized;
603
+ // Restore the default clear color
604
+ glw.clearColor(clearColor[0], clearColor[1], clearColor[2], clearColor[3]);
605
+
606
+ // Bind the default framebuffer
607
+ glw.bindFramebuffer(null);
608
+
609
+ glw.viewport(0, 0, this.glw.canvas.width, this.glw.canvas.height);
610
+ this.renderToTextureActive = false;
611
+ }
612
+
613
+ updateViewport(): void {
614
+ this.glw.viewport(0, 0, this.glw.canvas.width, this.glw.canvas.height);
615
+ }
616
+
617
+ removeRTTNode(node: CoreNode) {
618
+ const index = this.rttNodes.indexOf(node);
619
+ if (index === -1) {
620
+ return;
621
+ }
622
+ this.rttNodes.splice(index, 1);
623
+ }
624
+
625
+ getBufferInfo(): BufferInfo | null {
626
+ const bufferInfo: BufferInfo = {
627
+ totalAvailable: this.stage.options.quadBufferSize,
628
+ totalUsed: this.quadBufferUsage,
629
+ };
630
+ return bufferInfo;
631
+ }
632
+
633
+ getDefaultShaderNode(): WebGlShaderNode {
634
+ if (this.defaultShaderNode !== null) {
635
+ return this.defaultShaderNode as WebGlShaderNode;
636
+ }
637
+ this.stage.shManager.registerShaderType('default', Default);
638
+ this.defaultShaderNode = this.stage.shManager.createShader(
639
+ 'default',
640
+ ) as WebGlShaderNode;
641
+ return this.defaultShaderNode;
642
+ }
643
+
644
+ override getTextureCoords(node: CoreNode): TextureCoords {
645
+ const texture = node.texture;
646
+ if (texture === null) {
647
+ return this.defaultTextureCoords;
648
+ }
649
+
650
+ const textureOptions = node.textureOptions;
651
+ if (
652
+ texture.type === TextureType.subTexture ||
653
+ texture.type === TextureType.image ||
654
+ texture.type === TextureType.renderToTexture ||
655
+ textureOptions !== null
656
+ ) {
657
+ const result = {
658
+ x1: 0,
659
+ y1: 0,
660
+ x2: 1,
661
+ y2: 1,
662
+ };
663
+
664
+ if (texture.type === TextureType.subTexture) {
665
+ const props = (texture as SubTexture).props;
666
+ const { width: parentW = 0, height: parentH = 0 } = (
667
+ texture as SubTexture
668
+ ).parentTexture.dimensions || { width: 0, height: 0 };
669
+ result.x1 = props.x / parentW;
670
+ result.x2 = result.x1 + props.width / parentW;
671
+ result.y1 = props.y / parentH;
672
+ result.y2 = result.y1 + props.height / parentH;
673
+ }
674
+
675
+ if (
676
+ texture.type === TextureType.image &&
677
+ textureOptions !== null &&
678
+ textureOptions.resizeMode !== undefined &&
679
+ texture.dimensions !== null
680
+ ) {
681
+ const resizeMode = textureOptions.resizeMode;
682
+ const dimensions = texture.dimensions;
683
+ if (resizeMode.type === 'cover') {
684
+ const scaleX = node.props.width / dimensions.width;
685
+ const scaleY = node.props.height / dimensions.height;
686
+ const scale = Math.max(scaleX, scaleY);
687
+ const precision = 1 / scale;
688
+ // Determine based on width
689
+ if (scaleX < scale) {
690
+ const desiredSize = precision * node.props.width;
691
+ result.x1 =
692
+ (1 - desiredSize / dimensions.width) * (resizeMode.clipX ?? 0.5);
693
+ result.x2 = result.x1 + desiredSize / dimensions.width;
694
+ }
695
+ // Determine based on height
696
+ if (scaleY < scale) {
697
+ const desiredSize = precision * node.props.height;
698
+ result.y1 =
699
+ (1 - desiredSize / dimensions.height) * (resizeMode.clipY ?? 0.5);
700
+ result.y2 = result.y1 + desiredSize / dimensions.height;
701
+ }
702
+ }
703
+ }
704
+
705
+ // Flip texture coordinates if dictated by texture options
706
+ let flipY = 0;
707
+ if (textureOptions !== null) {
708
+ if (textureOptions.flipX === true) {
709
+ [result.x1, result.x2] = [result.x2, result.x1];
710
+ }
711
+
712
+ // convert to integer for bitwise operation below
713
+ flipY = +(textureOptions.flipY || false);
714
+ }
715
+
716
+ // Eitherone should be true
717
+ if (flipY ^ +(texture.type === TextureType.renderToTexture)) {
718
+ [result.y1, result.y2] = [result.y2, result.y1];
719
+ }
720
+ return result as TextureCoords;
721
+ }
722
+
723
+ return this.defaultTextureCoords;
724
+ }
725
+
726
+ /**
727
+ * Sets the glClearColor to the specified color. *
728
+ * @param color - The color to set as the clear color, represented as a 32-bit integer.
729
+ */
730
+ updateClearColor(color: number) {
731
+ if (this.clearColor.raw === color) {
732
+ return;
733
+ }
734
+ const glw = this.glw;
735
+ const normalizedColor = getNormalizedRgbaComponents(color);
736
+ glw.clearColor(
737
+ normalizedColor[0],
738
+ normalizedColor[1],
739
+ normalizedColor[2],
740
+ normalizedColor[3],
741
+ );
742
+ this.clearColor = {
743
+ raw: color,
744
+ normalized: normalizedColor,
745
+ };
746
+ }
747
+ }