@lightningjs/renderer 3.0.0-beta9 → 3.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (566) hide show
  1. package/LICENSE +202 -202
  2. package/NOTICE +3 -3
  3. package/README.md +230 -147
  4. package/dist/exports/canvas.d.ts +1 -1
  5. package/dist/exports/canvas.js +1 -1
  6. package/dist/exports/canvas.js.map +1 -1
  7. package/dist/exports/index.d.ts +5 -6
  8. package/dist/exports/index.js +3 -5
  9. package/dist/exports/index.js.map +1 -1
  10. package/dist/exports/platform.d.ts +7 -0
  11. package/dist/exports/platform.js +27 -0
  12. package/dist/exports/platform.js.map +1 -0
  13. package/dist/exports/webgl.d.ts +2 -1
  14. package/dist/exports/webgl.js +2 -1
  15. package/dist/exports/webgl.js.map +1 -1
  16. package/dist/src/common/CommonTypes.d.ts +15 -3
  17. package/dist/src/core/AutosizeManager.d.ts +29 -0
  18. package/dist/src/core/AutosizeManager.js +169 -0
  19. package/dist/src/core/AutosizeManager.js.map +1 -0
  20. package/dist/src/core/Autosizer.d.ts +35 -0
  21. package/dist/src/core/Autosizer.js +196 -0
  22. package/dist/src/core/Autosizer.js.map +1 -0
  23. package/dist/src/core/CoreNode.d.ts +106 -58
  24. package/dist/src/core/CoreNode.js +524 -282
  25. package/dist/src/core/CoreNode.js.map +1 -1
  26. package/dist/src/core/CoreTextNode.d.ts +73 -88
  27. package/dist/src/core/CoreTextNode.js +375 -236
  28. package/dist/src/core/CoreTextNode.js.map +1 -1
  29. package/dist/src/core/CoreTextureManager.d.ts +19 -17
  30. package/dist/src/core/CoreTextureManager.js +52 -120
  31. package/dist/src/core/CoreTextureManager.js.map +1 -1
  32. package/dist/src/core/Stage.d.ts +63 -9
  33. package/dist/src/core/Stage.js +233 -133
  34. package/dist/src/core/Stage.js.map +1 -1
  35. package/dist/src/core/TextureError.d.ts +11 -0
  36. package/dist/src/core/TextureError.js +37 -0
  37. package/dist/src/core/TextureError.js.map +1 -0
  38. package/dist/src/core/TextureMemoryManager.d.ts +2 -4
  39. package/dist/src/core/TextureMemoryManager.js +80 -113
  40. package/dist/src/core/TextureMemoryManager.js.map +1 -1
  41. package/dist/src/core/animations/Animation.d.ts +21 -0
  42. package/dist/src/core/animations/Animation.js +194 -0
  43. package/dist/src/core/animations/Animation.js.map +1 -0
  44. package/dist/src/core/animations/CoreAnimation.d.ts +3 -3
  45. package/dist/src/core/animations/CoreAnimation.js +3 -3
  46. package/dist/src/core/animations/CoreAnimation.js.map +1 -1
  47. package/dist/src/core/animations/CoreAnimationController.d.ts +1 -1
  48. package/dist/src/core/animations/CoreAnimationController.js +4 -2
  49. package/dist/src/core/animations/CoreAnimationController.js.map +1 -1
  50. package/dist/src/core/animations/Playback.d.ts +64 -0
  51. package/dist/src/core/animations/Playback.js +169 -0
  52. package/dist/src/core/animations/Playback.js.map +1 -0
  53. package/dist/src/core/animations/Transition.d.ts +27 -0
  54. package/dist/src/core/animations/Transition.js +52 -0
  55. package/dist/src/core/animations/Transition.js.map +1 -0
  56. package/dist/src/core/animations/utils.d.ts +2 -0
  57. package/dist/src/core/animations/utils.js +136 -0
  58. package/dist/src/core/animations/utils.js.map +1 -0
  59. package/dist/src/core/lib/ImageWorker.d.ts +2 -2
  60. package/dist/src/core/lib/ImageWorker.js +30 -11
  61. package/dist/src/core/lib/ImageWorker.js.map +1 -1
  62. package/dist/src/core/lib/WebGlContextWrapper.d.ts +22 -1
  63. package/dist/src/core/lib/WebGlContextWrapper.js +49 -3
  64. package/dist/src/core/lib/WebGlContextWrapper.js.map +1 -1
  65. package/dist/src/core/lib/collectionUtils.d.ts +4 -0
  66. package/dist/src/core/lib/collectionUtils.js +72 -0
  67. package/dist/src/core/lib/collectionUtils.js.map +1 -0
  68. package/dist/src/core/lib/colorCache.d.ts +1 -0
  69. package/dist/src/core/lib/colorCache.js +19 -0
  70. package/dist/src/core/lib/colorCache.js.map +1 -0
  71. package/dist/src/core/lib/colorParser.d.ts +21 -0
  72. package/dist/src/core/lib/colorParser.js +72 -0
  73. package/dist/src/core/lib/colorParser.js.map +1 -0
  74. package/dist/src/core/lib/textureCompression.d.ts +14 -2
  75. package/dist/src/core/lib/textureCompression.js +320 -67
  76. package/dist/src/core/lib/textureCompression.js.map +1 -1
  77. package/dist/src/core/lib/utils.d.ts +6 -6
  78. package/dist/src/core/lib/utils.js +21 -65
  79. package/dist/src/core/lib/utils.js.map +1 -1
  80. package/dist/src/core/platform.d.ts +10 -0
  81. package/dist/src/core/platform.js +81 -0
  82. package/dist/src/core/platform.js.map +1 -0
  83. package/dist/src/core/platforms/GlContextWrapper.d.ts +136 -0
  84. package/{src/core/text-rendering/TextRenderingUtils.ts → dist/src/core/platforms/GlContextWrapper.js} +32 -36
  85. package/dist/src/core/platforms/GlContextWrapper.js.map +1 -0
  86. package/dist/src/core/platforms/Platform.d.ts +78 -12
  87. package/dist/src/core/platforms/Platform.js +18 -0
  88. package/dist/src/core/platforms/Platform.js.map +1 -1
  89. package/dist/src/core/platforms/web/WebGlContextWrapper.d.ts +776 -0
  90. package/dist/src/core/platforms/web/WebGlContextWrapper.js +1208 -0
  91. package/dist/src/core/platforms/web/WebGlContextWrapper.js.map +1 -0
  92. package/dist/src/core/platforms/web/WebPlatform.d.ts +17 -2
  93. package/dist/src/core/platforms/web/WebPlatform.js +158 -13
  94. package/dist/src/core/platforms/web/WebPlatform.js.map +1 -1
  95. package/dist/src/core/platforms/web/WebPlatformChrome50.d.ts +19 -0
  96. package/dist/src/core/platforms/web/WebPlatformChrome50.js +54 -0
  97. package/dist/src/core/platforms/web/WebPlatformChrome50.js.map +1 -0
  98. package/dist/src/core/platforms/web/WebPlatformLegacy.d.ts +20 -0
  99. package/dist/src/core/platforms/web/WebPlatformLegacy.js +105 -0
  100. package/dist/src/core/platforms/web/WebPlatformLegacy.js.map +1 -0
  101. package/dist/src/core/platforms/web/WebPlatformNext.d.ts +21 -0
  102. package/dist/src/core/platforms/web/WebPlatformNext.js +52 -0
  103. package/dist/src/core/platforms/web/WebPlatformNext.js.map +1 -0
  104. package/dist/src/core/platforms/web/lib/ImageWorker.d.ts +21 -0
  105. package/dist/src/core/platforms/web/lib/ImageWorker.js +136 -0
  106. package/dist/src/core/platforms/web/lib/ImageWorker.js.map +1 -0
  107. package/dist/src/core/platforms/web/lib/ImageWorkerDefault.d.ts +6 -0
  108. package/dist/src/core/platforms/web/lib/ImageWorkerDefault.js +92 -0
  109. package/dist/src/core/platforms/web/lib/ImageWorkerDefault.js.map +1 -0
  110. package/dist/src/core/platforms/web/lib/ImageWorkerLegacy.d.ts +1 -0
  111. package/dist/src/core/platforms/web/lib/ImageWorkerLegacy.js +63 -0
  112. package/dist/src/core/platforms/web/lib/ImageWorkerLegacy.js.map +1 -0
  113. package/dist/src/core/platforms/web/lib/ImageWorkerNoOptions.d.ts +7 -0
  114. package/dist/src/core/platforms/web/lib/ImageWorkerNoOptions.js +75 -0
  115. package/dist/src/core/platforms/web/lib/ImageWorkerNoOptions.js.map +1 -0
  116. package/dist/src/core/platforms/web/lib/createImageBitmap.d.ts +1 -0
  117. package/dist/src/core/platforms/web/lib/createImageBitmap.js +27 -0
  118. package/dist/src/core/platforms/web/lib/createImageBitmap.js.map +1 -0
  119. package/dist/src/core/platforms/web/lib/textureCompression.d.ts +26 -0
  120. package/dist/src/core/platforms/web/lib/textureCompression.js +301 -0
  121. package/dist/src/core/platforms/web/lib/textureCompression.js.map +1 -0
  122. package/dist/src/core/platforms/web/lib/textureSvg.d.ts +7 -0
  123. package/dist/src/core/platforms/web/lib/textureSvg.js +51 -0
  124. package/dist/src/core/platforms/web/lib/textureSvg.js.map +1 -0
  125. package/dist/src/core/platforms/web/lib/utils.d.ts +5 -0
  126. package/dist/src/core/platforms/web/lib/utils.js +86 -0
  127. package/dist/src/core/platforms/web/lib/utils.js.map +1 -0
  128. package/dist/src/core/renderers/CoreContextTexture.d.ts +2 -1
  129. package/dist/src/core/renderers/CoreContextTexture.js.map +1 -1
  130. package/dist/src/core/renderers/CoreRenderer.d.ts +4 -40
  131. package/dist/src/core/renderers/CoreRenderer.js +3 -4
  132. package/dist/src/core/renderers/CoreRenderer.js.map +1 -1
  133. package/dist/src/core/renderers/CoreShader.d.ts +9 -0
  134. package/{src/core/text-rendering/renderers/SdfTextRenderer/internal/constants.ts → dist/src/core/renderers/CoreShader.js} +28 -32
  135. package/dist/src/core/renderers/CoreShader.js.map +1 -0
  136. package/dist/src/core/renderers/CoreShaderNode.d.ts +10 -0
  137. package/dist/src/core/renderers/CoreShaderNode.js +19 -2
  138. package/dist/src/core/renderers/CoreShaderNode.js.map +1 -1
  139. package/dist/src/core/renderers/canvas/CanvasCoreRenderer.d.ts +33 -0
  140. package/dist/src/core/renderers/canvas/CanvasCoreRenderer.js +250 -0
  141. package/dist/src/core/renderers/canvas/CanvasCoreRenderer.js.map +1 -0
  142. package/dist/src/core/renderers/canvas/CanvasCoreTexture.d.ts +17 -0
  143. package/dist/src/core/renderers/canvas/CanvasCoreTexture.js +125 -0
  144. package/dist/src/core/renderers/canvas/CanvasCoreTexture.js.map +1 -0
  145. package/dist/src/core/renderers/canvas/CanvasRenderer.d.ts +5 -6
  146. package/dist/src/core/renderers/canvas/CanvasRenderer.js +67 -91
  147. package/dist/src/core/renderers/canvas/CanvasRenderer.js.map +1 -1
  148. package/dist/src/core/renderers/canvas/CanvasShaderNode.d.ts +1 -2
  149. package/dist/src/core/renderers/canvas/CanvasShaderNode.js +5 -4
  150. package/dist/src/core/renderers/canvas/CanvasShaderNode.js.map +1 -1
  151. package/dist/src/core/renderers/canvas/CanvasTexture.d.ts +3 -2
  152. package/dist/src/core/renderers/canvas/CanvasTexture.js +17 -13
  153. package/dist/src/core/renderers/canvas/CanvasTexture.js.map +1 -1
  154. package/dist/src/core/renderers/canvas/internal/C2DShaderUtils.d.ts +13 -0
  155. package/dist/src/core/renderers/canvas/internal/C2DShaderUtils.js +113 -192
  156. package/dist/src/core/renderers/canvas/internal/C2DShaderUtils.js.map +1 -1
  157. package/dist/src/core/renderers/canvas/internal/ColorUtils.d.ts +0 -2
  158. package/dist/src/core/renderers/canvas/internal/ColorUtils.js +0 -14
  159. package/dist/src/core/renderers/canvas/internal/ColorUtils.js.map +1 -1
  160. package/dist/src/core/renderers/canvas/shaders/UnsupportedShader.d.ts +10 -0
  161. package/{src/core/text-rendering/renderers/SdfTextRenderer/internal/util.ts → dist/src/core/renderers/canvas/shaders/UnsupportedShader.js} +43 -40
  162. package/dist/src/core/renderers/canvas/shaders/UnsupportedShader.js.map +1 -0
  163. package/dist/src/core/renderers/webgl/SdfRenderOp.d.ts +33 -0
  164. package/dist/src/core/renderers/webgl/SdfRenderOp.js +98 -0
  165. package/dist/src/core/renderers/webgl/SdfRenderOp.js.map +1 -0
  166. package/dist/src/core/renderers/webgl/WebGlCoreCtxRenderTexture.d.ts +12 -0
  167. package/dist/src/core/renderers/webgl/WebGlCoreCtxRenderTexture.js +58 -0
  168. package/dist/src/core/renderers/webgl/WebGlCoreCtxRenderTexture.js.map +1 -0
  169. package/dist/src/core/renderers/webgl/WebGlCoreCtxSubTexture.d.ts +9 -0
  170. package/dist/src/core/renderers/webgl/WebGlCoreCtxSubTexture.js +38 -0
  171. package/dist/src/core/renderers/webgl/WebGlCoreCtxSubTexture.js.map +1 -0
  172. package/dist/src/core/renderers/webgl/WebGlCoreCtxTexture.d.ts +69 -0
  173. package/dist/src/core/renderers/webgl/WebGlCoreCtxTexture.js +272 -0
  174. package/dist/src/core/renderers/webgl/WebGlCoreCtxTexture.js.map +1 -0
  175. package/dist/src/core/renderers/webgl/WebGlCoreRenderOp.d.ts +34 -0
  176. package/dist/src/core/renderers/webgl/WebGlCoreRenderOp.js +114 -0
  177. package/dist/src/core/renderers/webgl/WebGlCoreRenderOp.js.map +1 -0
  178. package/dist/src/core/renderers/webgl/WebGlCoreRenderer.d.ts +133 -0
  179. package/dist/src/core/renderers/webgl/WebGlCoreRenderer.js +649 -0
  180. package/dist/src/core/renderers/webgl/WebGlCoreRenderer.js.map +1 -0
  181. package/dist/src/core/renderers/webgl/WebGlCoreShader.d.ts +78 -0
  182. package/dist/src/core/renderers/webgl/WebGlCoreShader.js +202 -0
  183. package/dist/src/core/renderers/webgl/WebGlCoreShader.js.map +1 -0
  184. package/dist/src/core/renderers/webgl/WebGlCtxRenderTexture.d.ts +4 -2
  185. package/dist/src/core/renderers/webgl/WebGlCtxRenderTexture.js +14 -6
  186. package/dist/src/core/renderers/webgl/WebGlCtxRenderTexture.js.map +1 -1
  187. package/dist/src/core/renderers/webgl/WebGlCtxSubTexture.d.ts +15 -2
  188. package/dist/src/core/renderers/webgl/WebGlCtxSubTexture.js +34 -5
  189. package/dist/src/core/renderers/webgl/WebGlCtxSubTexture.js.map +1 -1
  190. package/dist/src/core/renderers/webgl/WebGlCtxTexture.d.ts +19 -9
  191. package/dist/src/core/renderers/webgl/WebGlCtxTexture.js +101 -49
  192. package/dist/src/core/renderers/webgl/WebGlCtxTexture.js.map +1 -1
  193. package/dist/src/core/renderers/webgl/WebGlRenderOp.d.ts +3 -2
  194. package/dist/src/core/renderers/webgl/WebGlRenderOp.js +14 -5
  195. package/dist/src/core/renderers/webgl/WebGlRenderOp.js.map +1 -1
  196. package/dist/src/core/renderers/webgl/WebGlRenderer.d.ts +11 -23
  197. package/dist/src/core/renderers/webgl/WebGlRenderer.js +122 -133
  198. package/dist/src/core/renderers/webgl/WebGlRenderer.js.map +1 -1
  199. package/dist/src/core/renderers/webgl/WebGlShaderNode.d.ts +4 -6
  200. package/dist/src/core/renderers/webgl/WebGlShaderNode.js +3 -3
  201. package/dist/src/core/renderers/webgl/WebGlShaderNode.js.map +1 -1
  202. package/dist/src/core/renderers/webgl/WebGlShaderProgram.d.ts +7 -7
  203. package/dist/src/core/renderers/webgl/WebGlShaderProgram.js +56 -37
  204. package/dist/src/core/renderers/webgl/WebGlShaderProgram.js.map +1 -1
  205. package/dist/src/core/renderers/webgl/internal/RendererUtils.d.ts +4 -4
  206. package/dist/src/core/renderers/webgl/internal/RendererUtils.js.map +1 -1
  207. package/dist/src/core/renderers/webgl/internal/ShaderUtils.d.ts +3 -3
  208. package/dist/src/core/renderers/webgl/internal/ShaderUtils.js +38 -37
  209. package/dist/src/core/renderers/webgl/internal/ShaderUtils.js.map +1 -1
  210. package/dist/src/core/renderers/webgl/shaders/DefaultShader.d.ts +9 -0
  211. package/dist/src/core/renderers/webgl/shaders/DefaultShader.js +84 -0
  212. package/dist/src/core/renderers/webgl/shaders/DefaultShader.js.map +1 -0
  213. package/dist/src/core/renderers/webgl/shaders/DefaultShaderBatched.d.ts +10 -0
  214. package/dist/src/core/renderers/webgl/shaders/DefaultShaderBatched.js +108 -0
  215. package/dist/src/core/renderers/webgl/shaders/DefaultShaderBatched.js.map +1 -0
  216. package/dist/src/core/renderers/webgl/shaders/DynamicShader.d.ts +29 -0
  217. package/dist/src/core/renderers/webgl/shaders/DynamicShader.js +408 -0
  218. package/dist/src/core/renderers/webgl/shaders/DynamicShader.js.map +1 -0
  219. package/dist/src/core/renderers/webgl/shaders/RoundedRectangle.d.ts +28 -0
  220. package/dist/src/core/renderers/webgl/shaders/RoundedRectangle.js +126 -0
  221. package/dist/src/core/renderers/webgl/shaders/RoundedRectangle.js.map +1 -0
  222. package/dist/src/core/renderers/webgl/shaders/SdfShader.d.ts +47 -0
  223. package/dist/src/core/renderers/webgl/shaders/SdfShader.js +148 -0
  224. package/dist/src/core/renderers/webgl/shaders/SdfShader.js.map +1 -0
  225. package/dist/src/core/renderers/webgl/shaders/effects/BorderBottomEffect.d.ts +31 -0
  226. package/dist/src/core/renderers/webgl/shaders/effects/BorderBottomEffect.js +71 -0
  227. package/dist/src/core/renderers/webgl/shaders/effects/BorderBottomEffect.js.map +1 -0
  228. package/dist/src/core/renderers/webgl/shaders/effects/BorderEffect.d.ts +30 -0
  229. package/dist/src/core/renderers/webgl/shaders/effects/BorderEffect.js +58 -0
  230. package/dist/src/core/renderers/webgl/shaders/effects/BorderEffect.js.map +1 -0
  231. package/dist/src/core/renderers/webgl/shaders/effects/BorderLeftEffect.d.ts +31 -0
  232. package/dist/src/core/renderers/webgl/shaders/effects/BorderLeftEffect.js +71 -0
  233. package/dist/src/core/renderers/webgl/shaders/effects/BorderLeftEffect.js.map +1 -0
  234. package/dist/src/core/renderers/webgl/shaders/effects/BorderRightEffect.d.ts +31 -0
  235. package/dist/src/core/renderers/webgl/shaders/effects/BorderRightEffect.js +71 -0
  236. package/dist/src/core/renderers/webgl/shaders/effects/BorderRightEffect.js.map +1 -0
  237. package/dist/src/core/renderers/webgl/shaders/effects/BorderTopEffect.d.ts +31 -0
  238. package/dist/src/core/renderers/webgl/shaders/effects/BorderTopEffect.js +71 -0
  239. package/dist/src/core/renderers/webgl/shaders/effects/BorderTopEffect.js.map +1 -0
  240. package/dist/src/core/renderers/webgl/shaders/effects/EffectUtils.d.ts +9 -0
  241. package/dist/src/core/renderers/webgl/shaders/effects/EffectUtils.js +136 -0
  242. package/dist/src/core/renderers/webgl/shaders/effects/EffectUtils.js.map +1 -0
  243. package/dist/src/core/renderers/webgl/shaders/effects/FadeOutEffect.d.ts +36 -0
  244. package/dist/src/core/renderers/webgl/shaders/effects/FadeOutEffect.js +85 -0
  245. package/dist/src/core/renderers/webgl/shaders/effects/FadeOutEffect.js.map +1 -0
  246. package/dist/src/core/renderers/webgl/shaders/effects/GlitchEffect.d.ts +45 -0
  247. package/dist/src/core/renderers/webgl/shaders/effects/GlitchEffect.js +104 -0
  248. package/dist/src/core/renderers/webgl/shaders/effects/GlitchEffect.js.map +1 -0
  249. package/dist/src/core/renderers/webgl/shaders/effects/GrayscaleEffect.d.ts +22 -0
  250. package/dist/src/core/renderers/webgl/shaders/effects/GrayscaleEffect.js +45 -0
  251. package/dist/src/core/renderers/webgl/shaders/effects/GrayscaleEffect.js.map +1 -0
  252. package/dist/src/core/renderers/webgl/shaders/effects/HolePunchEffect.d.ts +58 -0
  253. package/dist/src/core/renderers/webgl/shaders/effects/HolePunchEffect.js +80 -0
  254. package/dist/src/core/renderers/webgl/shaders/effects/HolePunchEffect.js.map +1 -0
  255. package/dist/src/core/renderers/webgl/shaders/effects/LinearGradientEffect.d.ts +35 -0
  256. package/dist/src/core/renderers/webgl/shaders/effects/LinearGradientEffect.js +134 -0
  257. package/dist/src/core/renderers/webgl/shaders/effects/LinearGradientEffect.js.map +1 -0
  258. package/dist/src/core/renderers/webgl/shaders/effects/RadialGradientEffect.d.ts +40 -0
  259. package/dist/src/core/renderers/webgl/shaders/effects/RadialGradientEffect.js +143 -0
  260. package/dist/src/core/renderers/webgl/shaders/effects/RadialGradientEffect.js.map +1 -0
  261. package/dist/src/core/renderers/webgl/shaders/effects/RadialProgressEffect.d.ts +61 -0
  262. package/dist/src/core/renderers/webgl/shaders/effects/RadialProgressEffect.js +127 -0
  263. package/dist/src/core/renderers/webgl/shaders/effects/RadialProgressEffect.js.map +1 -0
  264. package/dist/src/core/renderers/webgl/shaders/effects/RadiusEffect.d.ts +40 -0
  265. package/dist/src/core/renderers/webgl/shaders/effects/RadiusEffect.js +71 -0
  266. package/dist/src/core/renderers/webgl/shaders/effects/RadiusEffect.js.map +1 -0
  267. package/dist/src/core/renderers/webgl/shaders/effects/ShaderEffect.d.ts +115 -0
  268. package/dist/src/core/renderers/webgl/shaders/effects/ShaderEffect.js +61 -0
  269. package/dist/src/core/renderers/webgl/shaders/effects/ShaderEffect.js.map +1 -0
  270. package/dist/src/core/shaders/canvas/Border.d.ts +8 -2
  271. package/dist/src/core/shaders/canvas/Border.js +64 -25
  272. package/dist/src/core/shaders/canvas/Border.js.map +1 -1
  273. package/dist/src/core/shaders/canvas/HolePunch.js +4 -3
  274. package/dist/src/core/shaders/canvas/HolePunch.js.map +1 -1
  275. package/dist/src/core/shaders/canvas/LinearGradient.js +7 -5
  276. package/dist/src/core/shaders/canvas/LinearGradient.js.map +1 -1
  277. package/dist/src/core/shaders/canvas/RadialGradient.js +12 -10
  278. package/dist/src/core/shaders/canvas/RadialGradient.js.map +1 -1
  279. package/dist/src/core/shaders/canvas/Rounded.js +3 -3
  280. package/dist/src/core/shaders/canvas/Rounded.js.map +1 -1
  281. package/dist/src/core/shaders/canvas/RoundedWithBorder.d.ts +6 -3
  282. package/dist/src/core/shaders/canvas/RoundedWithBorder.js +41 -11
  283. package/dist/src/core/shaders/canvas/RoundedWithBorder.js.map +1 -1
  284. package/dist/src/core/shaders/canvas/RoundedWithBorderAndShadow.d.ts +2 -3
  285. package/dist/src/core/shaders/canvas/RoundedWithBorderAndShadow.js +46 -9
  286. package/dist/src/core/shaders/canvas/RoundedWithBorderAndShadow.js.map +1 -1
  287. package/dist/src/core/shaders/canvas/RoundedWithShadow.js +6 -5
  288. package/dist/src/core/shaders/canvas/RoundedWithShadow.js.map +1 -1
  289. package/dist/src/core/shaders/canvas/Shadow.js +4 -2
  290. package/dist/src/core/shaders/canvas/Shadow.js.map +1 -1
  291. package/dist/src/core/shaders/canvas/utils/render.d.ts +1 -1
  292. package/dist/src/core/shaders/canvas/utils/render.js +31 -18
  293. package/dist/src/core/shaders/canvas/utils/render.js.map +1 -1
  294. package/dist/src/core/shaders/templates/BorderTemplate.d.ts +11 -1
  295. package/dist/src/core/shaders/templates/BorderTemplate.js +30 -10
  296. package/dist/src/core/shaders/templates/BorderTemplate.js.map +1 -1
  297. package/dist/src/core/shaders/templates/HolePunchTemplate.d.ts +2 -2
  298. package/dist/src/core/shaders/templates/HolePunchTemplate.js +2 -2
  299. package/dist/src/core/shaders/templates/HolePunchTemplate.js.map +1 -1
  300. package/dist/src/core/shaders/templates/RadialGradientTemplate.d.ts +8 -6
  301. package/dist/src/core/shaders/templates/RadialGradientTemplate.js +2 -2
  302. package/dist/src/core/shaders/templates/RadialGradientTemplate.js.map +1 -1
  303. package/dist/src/core/shaders/webgl/Border.js +138 -84
  304. package/dist/src/core/shaders/webgl/Border.js.map +1 -1
  305. package/dist/src/core/shaders/webgl/Default.js +46 -47
  306. package/dist/src/core/shaders/webgl/Default.js.map +1 -1
  307. package/dist/src/core/shaders/webgl/DefaultBatched.js +61 -61
  308. package/dist/src/core/shaders/webgl/HolePunch.js +34 -34
  309. package/dist/src/core/shaders/webgl/HolePunch.js.map +1 -1
  310. package/dist/src/core/shaders/webgl/LinearGradient.js +60 -36
  311. package/dist/src/core/shaders/webgl/LinearGradient.js.map +1 -1
  312. package/dist/src/core/shaders/webgl/RadialGradient.js +60 -37
  313. package/dist/src/core/shaders/webgl/RadialGradient.js.map +1 -1
  314. package/dist/src/core/shaders/webgl/Rounded.js +74 -72
  315. package/dist/src/core/shaders/webgl/Rounded.js.map +1 -1
  316. package/dist/src/core/shaders/webgl/RoundedWithBorder.js +172 -113
  317. package/dist/src/core/shaders/webgl/RoundedWithBorder.js.map +1 -1
  318. package/dist/src/core/shaders/webgl/RoundedWithBorderAndShadow.js +191 -132
  319. package/dist/src/core/shaders/webgl/RoundedWithBorderAndShadow.js.map +1 -1
  320. package/dist/src/core/shaders/webgl/RoundedWithShadow.js +57 -55
  321. package/dist/src/core/shaders/webgl/RoundedWithShadow.js.map +1 -1
  322. package/dist/src/core/shaders/webgl/SdfShader.d.ts +0 -2
  323. package/dist/src/core/shaders/webgl/SdfShader.js +56 -66
  324. package/dist/src/core/shaders/webgl/SdfShader.js.map +1 -1
  325. package/dist/src/core/shaders/webgl/SdfShadowShader.d.ts +9 -0
  326. package/dist/src/core/shaders/webgl/SdfShadowShader.js +100 -0
  327. package/dist/src/core/shaders/webgl/SdfShadowShader.js.map +1 -0
  328. package/dist/src/core/shaders/webgl/Shadow.js +89 -83
  329. package/dist/src/core/shaders/webgl/Shadow.js.map +1 -1
  330. package/dist/src/core/text-rendering/CanvasFont.d.ts +14 -0
  331. package/dist/src/core/text-rendering/CanvasFont.js +111 -0
  332. package/dist/src/core/text-rendering/CanvasFont.js.map +1 -0
  333. package/dist/src/core/text-rendering/CanvasFontHandler.d.ts +59 -0
  334. package/dist/src/core/text-rendering/CanvasFontHandler.js +224 -0
  335. package/dist/src/core/text-rendering/CanvasFontHandler.js.map +1 -0
  336. package/dist/src/core/text-rendering/CanvasTextRenderer.d.ts +17 -0
  337. package/dist/src/core/text-rendering/CanvasTextRenderer.js +157 -0
  338. package/dist/src/core/text-rendering/CanvasTextRenderer.js.map +1 -0
  339. package/dist/src/core/text-rendering/CoreFont.d.ts +33 -0
  340. package/dist/src/core/text-rendering/CoreFont.js +48 -0
  341. package/dist/src/core/text-rendering/CoreFont.js.map +1 -0
  342. package/dist/src/core/text-rendering/FontManager.d.ts +11 -0
  343. package/dist/src/core/text-rendering/FontManager.js +42 -0
  344. package/dist/src/core/text-rendering/FontManager.js.map +1 -0
  345. package/dist/src/core/text-rendering/SdfFont.d.ts +29 -0
  346. package/dist/src/core/text-rendering/SdfFont.js +142 -0
  347. package/dist/src/core/text-rendering/SdfFont.js.map +1 -0
  348. package/dist/src/core/text-rendering/SdfFontHandler.d.ts +182 -0
  349. package/dist/src/core/text-rendering/SdfFontHandler.js +381 -0
  350. package/dist/src/core/text-rendering/SdfFontHandler.js.map +1 -0
  351. package/dist/src/core/text-rendering/SdfTextRenderer.d.ts +17 -0
  352. package/dist/src/core/text-rendering/SdfTextRenderer.js +301 -0
  353. package/dist/src/core/text-rendering/SdfTextRenderer.js.map +1 -0
  354. package/dist/src/core/text-rendering/TextLayoutEngine.d.ts +18 -0
  355. package/dist/src/core/text-rendering/TextLayoutEngine.js +380 -0
  356. package/dist/src/core/text-rendering/TextLayoutEngine.js.map +1 -0
  357. package/dist/src/core/text-rendering/TextRenderer.d.ts +383 -0
  358. package/{src/core/text-rendering/renderers/SdfTextRenderer/internal/getUnicodeCodepoints.ts → dist/src/core/text-rendering/TextRenderer.js} +20 -38
  359. package/dist/src/core/text-rendering/TextRenderer.js.map +1 -0
  360. package/dist/src/core/text-rendering/TextTextureRendererUtils.js.map +1 -1
  361. package/dist/src/core/text-rendering/Utils.d.ts +30 -0
  362. package/dist/src/core/text-rendering/Utils.js +84 -0
  363. package/dist/src/core/text-rendering/Utils.js.map +1 -0
  364. package/dist/src/core/text-rendering/font-face-types/SdfTrFontFace/SdfTrFontFace.js +2 -2
  365. package/dist/src/core/text-rendering/font-face-types/SdfTrFontFace/SdfTrFontFace.js.map +1 -1
  366. package/dist/src/core/text-rendering/renderers/CanvasTextRenderer.js +0 -5
  367. package/dist/src/core/text-rendering/renderers/CanvasTextRenderer.js.map +1 -1
  368. package/dist/src/core/text-rendering/renderers/LightningTextTextureRenderer.d.ts +1 -7
  369. package/dist/src/core/text-rendering/renderers/LightningTextTextureRenderer.js +2 -50
  370. package/dist/src/core/text-rendering/renderers/LightningTextTextureRenderer.js.map +1 -1
  371. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.d.ts +3 -2
  372. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.js +87 -46
  373. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.js.map +1 -1
  374. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText.d.ts +1 -1
  375. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText.js +8 -66
  376. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText.js.map +1 -1
  377. package/dist/src/core/text-rendering/renderers/TextRenderer.d.ts +4 -14
  378. package/dist/src/core/text-rendering/renderers/TextRenderer.js +0 -3
  379. package/dist/src/core/text-rendering/renderers/TextRenderer.js.map +1 -1
  380. package/dist/src/core/textures/ColorTexture.d.ts +1 -1
  381. package/dist/src/core/textures/ColorTexture.js +3 -4
  382. package/dist/src/core/textures/ColorTexture.js.map +1 -1
  383. package/dist/src/core/textures/ImageTexture.d.ts +33 -14
  384. package/dist/src/core/textures/ImageTexture.js +46 -125
  385. package/dist/src/core/textures/ImageTexture.js.map +1 -1
  386. package/dist/src/core/textures/NoiseTexture.d.ts +3 -3
  387. package/dist/src/core/textures/NoiseTexture.js +8 -8
  388. package/dist/src/core/textures/NoiseTexture.js.map +1 -1
  389. package/dist/src/core/textures/RenderTexture.d.ts +7 -7
  390. package/dist/src/core/textures/RenderTexture.js +12 -12
  391. package/dist/src/core/textures/RenderTexture.js.map +1 -1
  392. package/dist/src/core/textures/SubTexture.d.ts +6 -8
  393. package/dist/src/core/textures/SubTexture.js +22 -40
  394. package/dist/src/core/textures/SubTexture.js.map +1 -1
  395. package/dist/src/core/textures/Texture.d.ts +74 -15
  396. package/dist/src/core/textures/Texture.js +131 -19
  397. package/dist/src/core/textures/Texture.js.map +1 -1
  398. package/dist/src/core/utils.d.ts +2 -1
  399. package/dist/src/core/utils.js +1 -1
  400. package/dist/src/core/utils.js.map +1 -1
  401. package/dist/src/main-api/DynamicShaderController.d.ts +29 -0
  402. package/dist/src/main-api/DynamicShaderController.js +58 -0
  403. package/dist/src/main-api/DynamicShaderController.js.map +1 -0
  404. package/dist/src/main-api/Inspector.d.ts +129 -1
  405. package/dist/src/main-api/Inspector.js +462 -23
  406. package/dist/src/main-api/Inspector.js.map +1 -1
  407. package/dist/src/main-api/Renderer.d.ts +223 -41
  408. package/dist/src/main-api/Renderer.js +107 -62
  409. package/dist/src/main-api/Renderer.js.map +1 -1
  410. package/dist/src/main-api/ShaderController.d.ts +31 -0
  411. package/dist/src/main-api/ShaderController.js +37 -0
  412. package/dist/src/main-api/ShaderController.js.map +1 -0
  413. package/dist/src/utils.d.ts +0 -2
  414. package/dist/src/utils.js +0 -36
  415. package/dist/src/utils.js.map +1 -1
  416. package/dist/tsconfig.dist.tsbuildinfo +1 -1
  417. package/dist/tsconfig.tsbuildinfo +1 -0
  418. package/exports/canvas-shaders.ts +28 -28
  419. package/exports/canvas.ts +45 -45
  420. package/exports/index.ts +90 -90
  421. package/exports/inspector.ts +24 -24
  422. package/exports/platform.ts +31 -0
  423. package/exports/utils.ts +50 -50
  424. package/exports/webgl-shaders.ts +28 -28
  425. package/exports/webgl.ts +52 -50
  426. package/package.json +16 -15
  427. package/src/common/CommonTypes.ts +163 -146
  428. package/src/common/EventEmitter.ts +77 -77
  429. package/src/common/IAnimationController.ts +92 -92
  430. package/src/common/IEventEmitter.ts +28 -28
  431. package/src/core/Autosizer.ts +224 -0
  432. package/src/core/CoreNode.test.ts +365 -202
  433. package/src/core/CoreNode.ts +2785 -2489
  434. package/src/core/CoreShaderManager.ts +188 -188
  435. package/src/core/CoreTextNode.test.ts +311 -0
  436. package/src/core/CoreTextNode.ts +598 -451
  437. package/src/core/CoreTextureManager.ts +484 -548
  438. package/src/core/Stage.ts +927 -800
  439. package/src/core/TextureError.ts +46 -0
  440. package/src/core/TextureMemoryManager.ts +418 -462
  441. package/src/core/animations/AnimationManager.ts +38 -38
  442. package/src/core/animations/CoreAnimation.ts +290 -291
  443. package/src/core/animations/CoreAnimationController.ts +169 -166
  444. package/src/core/lib/ContextSpy.ts +41 -41
  445. package/src/core/lib/Matrix3d.ts +244 -244
  446. package/src/core/lib/RenderCoords.ts +71 -71
  447. package/src/core/lib/collectionUtils.ts +83 -0
  448. package/src/core/lib/colorCache.ts +20 -0
  449. package/src/core/{renderers/canvas/internal/ColorUtils.ts → lib/colorParser.ts} +85 -85
  450. package/src/core/lib/utils.ts +337 -390
  451. package/src/core/platforms/GlContextWrapper.ts +291 -0
  452. package/src/core/platforms/Platform.ts +176 -77
  453. package/src/core/{lib → platforms/web}/WebGlContextWrapper.ts +1547 -1368
  454. package/src/core/platforms/web/WebPlatform.ts +306 -84
  455. package/src/core/platforms/web/WebPlatformChrome50.ts +63 -0
  456. package/src/core/platforms/web/WebPlatformLegacy.ts +150 -0
  457. package/src/core/platforms/web/WebPlatformNext.ts +57 -0
  458. package/src/core/platforms/web/lib/ImageWorker.ts +192 -0
  459. package/src/core/platforms/web/lib/ImageWorkerDefault.ts +117 -0
  460. package/src/core/platforms/web/lib/ImageWorkerLegacy.ts +87 -0
  461. package/src/core/platforms/web/lib/ImageWorkerNoOptions.ts +99 -0
  462. package/src/core/platforms/web/lib/createImageBitmap.ts +40 -0
  463. package/src/core/platforms/web/lib/textureCompression.ts +391 -0
  464. package/src/core/{lib → platforms/web/lib}/textureSvg.ts +66 -78
  465. package/src/core/platforms/web/lib/utils.ts +105 -0
  466. package/src/core/renderers/CoreContextTexture.ts +44 -43
  467. package/src/core/renderers/CoreRenderOp.ts +22 -22
  468. package/src/core/renderers/CoreRenderer.ts +71 -110
  469. package/src/core/renderers/CoreShaderNode.ts +202 -175
  470. package/src/core/renderers/CoreShaderProgram.ts +23 -23
  471. package/src/core/renderers/canvas/CanvasRenderer.ts +258 -302
  472. package/src/core/renderers/canvas/CanvasShaderNode.ts +95 -96
  473. package/src/core/renderers/canvas/CanvasTexture.ts +160 -156
  474. package/src/core/renderers/webgl/SdfRenderOp.ts +106 -0
  475. package/src/core/renderers/webgl/WebGlCtxRenderTexture.ts +89 -86
  476. package/src/core/renderers/webgl/WebGlCtxSubTexture.ts +95 -50
  477. package/src/core/renderers/webgl/WebGlCtxTexture.ts +350 -298
  478. package/src/core/renderers/webgl/WebGlRenderer.ts +726 -747
  479. package/src/core/renderers/webgl/WebGlShaderNode.ts +430 -435
  480. package/src/core/renderers/webgl/WebGlShaderProgram.ts +362 -341
  481. package/src/core/renderers/webgl/internal/BufferCollection.ts +54 -54
  482. package/src/core/renderers/webgl/internal/RendererUtils.ts +151 -155
  483. package/src/core/renderers/webgl/internal/ShaderUtils.ts +283 -281
  484. package/src/core/renderers/webgl/internal/WebGlUtils.ts +35 -35
  485. package/src/core/shaders/canvas/Border.ts +132 -78
  486. package/src/core/shaders/canvas/HolePunch.ts +56 -62
  487. package/src/core/shaders/canvas/LinearGradient.ts +73 -71
  488. package/src/core/shaders/canvas/RadialGradient.ts +96 -99
  489. package/src/core/shaders/canvas/Rounded.ts +55 -55
  490. package/src/core/shaders/canvas/RoundedWithBorder.ts +122 -74
  491. package/src/core/shaders/canvas/RoundedWithBorderAndShadow.ts +136 -90
  492. package/src/core/shaders/canvas/RoundedWithShadow.ts +71 -70
  493. package/src/core/shaders/canvas/Shadow.ts +54 -52
  494. package/src/core/shaders/canvas/utils/render.ts +160 -151
  495. package/src/core/shaders/templates/BorderTemplate.ts +145 -115
  496. package/src/core/shaders/templates/HolePunchTemplate.ts +82 -82
  497. package/src/core/shaders/templates/LinearGradientTemplate.ts +71 -71
  498. package/src/core/shaders/templates/RadialGradientTemplate.ts +83 -81
  499. package/src/core/shaders/templates/RoundedTemplate.ts +98 -98
  500. package/src/core/shaders/templates/RoundedWithBorderAndShadowTemplate.ts +38 -38
  501. package/src/core/shaders/templates/RoundedWithBorderTemplate.ts +35 -35
  502. package/src/core/shaders/templates/RoundedWithShadowTemplate.ts +35 -35
  503. package/src/core/shaders/templates/ShadowTemplate.ts +106 -106
  504. package/src/core/shaders/utils.ts +46 -46
  505. package/src/core/shaders/webgl/Border.ts +169 -116
  506. package/src/core/shaders/webgl/Default.ts +88 -89
  507. package/src/core/shaders/webgl/DefaultBatched.ts +129 -129
  508. package/src/core/shaders/webgl/HolePunch.ts +75 -75
  509. package/src/core/shaders/webgl/LinearGradient.ts +106 -82
  510. package/src/core/shaders/webgl/RadialGradient.ts +108 -85
  511. package/src/core/shaders/webgl/Rounded.ts +115 -117
  512. package/src/core/shaders/webgl/RoundedWithBorder.ts +210 -155
  513. package/src/core/shaders/webgl/RoundedWithBorderAndShadow.ts +234 -175
  514. package/src/core/shaders/webgl/RoundedWithShadow.ts +96 -98
  515. package/src/core/shaders/webgl/SdfShader.ts +122 -134
  516. package/src/core/shaders/webgl/Shadow.ts +121 -115
  517. package/src/core/text-rendering/CanvasFontHandler.ts +304 -0
  518. package/src/core/text-rendering/CanvasTextRenderer.ts +255 -0
  519. package/src/core/text-rendering/SdfFontHandler.ts +584 -0
  520. package/src/core/text-rendering/SdfTextRenderer.ts +403 -0
  521. package/src/core/text-rendering/TextLayoutEngine.ts +672 -0
  522. package/src/core/text-rendering/TextRenderer.ts +444 -0
  523. package/src/core/text-rendering/Utils.ts +99 -0
  524. package/src/core/text-rendering/tests/TextLayoutEngine.test.ts +453 -0
  525. package/src/core/textures/ColorTexture.ts +104 -102
  526. package/src/core/textures/ImageTexture.ts +292 -418
  527. package/src/core/textures/NoiseTexture.ts +106 -104
  528. package/src/core/textures/RenderTexture.ts +87 -85
  529. package/src/core/textures/SubTexture.ts +184 -205
  530. package/src/core/textures/Texture.ts +524 -381
  531. package/src/core/utils.ts +229 -227
  532. package/src/env.d.ts +7 -7
  533. package/src/main-api/INode.ts +100 -100
  534. package/src/main-api/Inspector.ts +1278 -569
  535. package/src/main-api/Renderer.ts +1030 -818
  536. package/src/main-api/utils.ts +45 -45
  537. package/src/utils.ts +220 -267
  538. package/COPYING +0 -1
  539. package/src/core/lib/ImageWorker.ts +0 -286
  540. package/src/core/lib/textureCompression.ts +0 -152
  541. package/src/core/lib/validateImageBitmap.ts +0 -87
  542. package/src/core/renderers/canvas/internal/C2DShaderUtils.ts +0 -220
  543. package/src/core/renderers/webgl/WebGlRenderOp.ts +0 -161
  544. package/src/core/text-rendering/TextTextureRendererUtils.ts +0 -263
  545. package/src/core/text-rendering/TrFontManager.ts +0 -183
  546. package/src/core/text-rendering/font-face-types/SdfTrFontFace/SdfTrFontFace.ts +0 -176
  547. package/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/FontShaper.ts +0 -139
  548. package/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/SdfFontShaper.test.ts +0 -173
  549. package/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/SdfFontShaper.ts +0 -171
  550. package/src/core/text-rendering/font-face-types/TrFontFace.ts +0 -187
  551. package/src/core/text-rendering/font-face-types/WebTrFontFace.ts +0 -94
  552. package/src/core/text-rendering/font-face-types/utils.ts +0 -39
  553. package/src/core/text-rendering/renderers/CanvasTextRenderer.ts +0 -514
  554. package/src/core/text-rendering/renderers/LightningTextTextureRenderer.ts +0 -863
  555. package/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.ts +0 -793
  556. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/PeekableGenerator.test.ts +0 -48
  557. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/PeekableGenerator.ts +0 -66
  558. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/SpecialCodepoints.ts +0 -52
  559. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/getStartConditions.ts +0 -117
  560. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/getUnicodeCodepoints.test.ts +0 -133
  561. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText.ts +0 -497
  562. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/measureText.test.ts +0 -49
  563. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/measureText.ts +0 -52
  564. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/setRenderWindow.test.ts +0 -205
  565. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/setRenderWindow.ts +0 -93
  566. package/src/core/text-rendering/renderers/TextRenderer.ts +0 -567
@@ -0,0 +1,649 @@
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
+ import { assertTruthy, createWebGLContext, hasOwn } from '../../../utils.js';
20
+ import { CoreRenderer, } from '../CoreRenderer.js';
21
+ import { WebGlCoreRenderOp } from './WebGlCoreRenderOp.js';
22
+ import { createIndexBuffer, getWebGlParameters, getWebGlExtensions, } from './internal/RendererUtils.js';
23
+ import { WebGlCoreCtxTexture } from './WebGlCoreCtxTexture.js';
24
+ import { Texture, TextureType } from '../../textures/Texture.js';
25
+ import { SubTexture } from '../../textures/SubTexture.js';
26
+ import { WebGlCoreCtxSubTexture } from './WebGlCoreCtxSubTexture.js';
27
+ import { CoreShaderManager } from '../../CoreShaderManager.js';
28
+ import { BufferCollection } from './internal/BufferCollection.js';
29
+ import { compareRect, getNormalizedRgbaComponents, } from '../../lib/utils.js';
30
+ import { WebGlCoreShader } from './WebGlCoreShader.js';
31
+ import { WebGlContextWrapper } from '../../lib/WebGlContextWrapper.js';
32
+ import { RenderTexture } from '../../textures/RenderTexture.js';
33
+ import { CoreNodeRenderState } from '../../CoreNode.js';
34
+ import { WebGlCoreCtxRenderTexture } from './WebGlCoreCtxRenderTexture.js';
35
+ const WORDS_PER_QUAD = 24;
36
+ export class WebGlCoreRenderer extends CoreRenderer {
37
+ //// WebGL Native Context and Data
38
+ glw;
39
+ system;
40
+ //// Persistent data
41
+ quadBuffer;
42
+ fQuadBuffer;
43
+ uiQuadBuffer;
44
+ renderOps = [];
45
+ //// Render Op / Buffer Filling State
46
+ curBufferIdx = 0;
47
+ curRenderOp = null;
48
+ rttNodes = [];
49
+ activeRttNode = null;
50
+ //// Default Shader
51
+ defShaderCtrl;
52
+ defaultShader;
53
+ quadBufferCollection;
54
+ clearColor = {
55
+ raw: 0x00000000,
56
+ normalized: [0, 0, 0, 0],
57
+ };
58
+ /**
59
+ * White pixel texture used by default when no texture is specified.
60
+ */
61
+ quadBufferUsage = 0;
62
+ numQuadsRendered = 0;
63
+ /**
64
+ * Whether the renderer is currently rendering to a texture.
65
+ */
66
+ renderToTextureActive = false;
67
+ constructor(options) {
68
+ super(options);
69
+ this.quadBuffer = new ArrayBuffer(this.stage.options.quadBufferSize);
70
+ this.fQuadBuffer = new Float32Array(this.quadBuffer);
71
+ this.uiQuadBuffer = new Uint32Array(this.quadBuffer);
72
+ this.mode = 'webgl';
73
+ const { canvas, clearColor, bufferMemory } = options;
74
+ const gl = createWebGLContext(canvas, options.forceWebGL2, options.contextSpy);
75
+ const glw = (this.glw = new WebGlContextWrapper(gl));
76
+ glw.viewport(0, 0, canvas.width, canvas.height);
77
+ this.updateClearColor(clearColor);
78
+ glw.setBlend(true);
79
+ glw.blendFunc(glw.ONE, glw.ONE_MINUS_SRC_ALPHA);
80
+ createIndexBuffer(glw, bufferMemory);
81
+ this.system = {
82
+ parameters: getWebGlParameters(this.glw),
83
+ extensions: getWebGlExtensions(this.glw),
84
+ };
85
+ this.shManager.renderer = this;
86
+ this.defShaderCtrl = this.shManager.loadShader('DefaultShader');
87
+ this.defaultShader = this.defShaderCtrl.shader;
88
+ const quadBuffer = glw.createBuffer();
89
+ assertTruthy(quadBuffer);
90
+ const stride = 8 * Float32Array.BYTES_PER_ELEMENT;
91
+ this.quadBufferCollection = new BufferCollection([
92
+ {
93
+ buffer: quadBuffer,
94
+ attributes: {
95
+ a_position: {
96
+ name: 'a_position',
97
+ size: 2, // 2 components per iteration
98
+ type: glw.FLOAT, // the data is 32bit floats
99
+ normalized: false, // don't normalize the data
100
+ stride, // 0 = move forward size * sizeof(type) each iteration to get the next position
101
+ offset: 0, // start at the beginning of the buffer
102
+ },
103
+ a_textureCoordinate: {
104
+ name: 'a_textureCoordinate',
105
+ size: 2,
106
+ type: glw.FLOAT,
107
+ normalized: false,
108
+ stride,
109
+ offset: 2 * Float32Array.BYTES_PER_ELEMENT,
110
+ },
111
+ a_color: {
112
+ name: 'a_color',
113
+ size: 4,
114
+ type: glw.UNSIGNED_BYTE,
115
+ normalized: true,
116
+ stride,
117
+ offset: 4 * Float32Array.BYTES_PER_ELEMENT,
118
+ },
119
+ a_textureIndex: {
120
+ name: 'a_textureIndex',
121
+ size: 1,
122
+ type: glw.FLOAT,
123
+ normalized: false,
124
+ stride,
125
+ offset: 5 * Float32Array.BYTES_PER_ELEMENT,
126
+ },
127
+ a_nodeCoordinate: {
128
+ name: 'a_nodeCoordinate',
129
+ size: 2,
130
+ type: glw.FLOAT,
131
+ normalized: false,
132
+ stride,
133
+ offset: 6 * Float32Array.BYTES_PER_ELEMENT,
134
+ },
135
+ },
136
+ },
137
+ ]);
138
+ }
139
+ reset() {
140
+ const { glw } = this;
141
+ this.curBufferIdx = 0;
142
+ this.curRenderOp = null;
143
+ this.renderOps.length = 0;
144
+ glw.setScissorTest(false);
145
+ glw.clear();
146
+ }
147
+ getShaderManager() {
148
+ return this.shManager;
149
+ }
150
+ createCtxTexture(textureSource) {
151
+ if (textureSource instanceof SubTexture) {
152
+ return new WebGlCoreCtxSubTexture(this.glw, this.txMemManager, textureSource);
153
+ }
154
+ else if (textureSource instanceof RenderTexture) {
155
+ return new WebGlCoreCtxRenderTexture(this.glw, this.txMemManager, textureSource);
156
+ }
157
+ return new WebGlCoreCtxTexture(this.glw, this.txMemManager, textureSource);
158
+ }
159
+ /**
160
+ * This function adds a quad (a rectangle composed of two triangles) to the WebGL rendering pipeline.
161
+ *
162
+ * It takes a set of options that define the quad's properties, such as its dimensions, colors, texture, shader, and transformation matrix.
163
+ * The function first updates the shader properties with the current dimensions if necessary, then sets the default texture if none is provided.
164
+ * It then checks if a new render operation is needed, based on the current shader and clipping rectangle.
165
+ * If a new render operation is needed, it creates one and updates the current render operation.
166
+ * The function then adjusts the texture coordinates based on the texture options and adds the texture to the texture manager.
167
+ *
168
+ * Finally, it calculates the vertices for the quad, taking into account any transformations, and adds them to the quad buffer.
169
+ * The function updates the length and number of quads in the current render operation, and updates the current buffer index.
170
+ */
171
+ addQuad(params) {
172
+ const { fQuadBuffer, uiQuadBuffer } = this;
173
+ let texture = params.texture;
174
+ assertTruthy(texture !== null, 'Texture is required');
175
+ /**
176
+ * If the shader props contain any automatic properties, update it with the
177
+ * current dimensions and or alpha that will be used to render the quad.
178
+ */
179
+ if (params.shader !== this.defaultShader) {
180
+ if (hasOwn(params.shaderProps, '$dimensions') == true) {
181
+ const dimensions = params.shaderProps.$dimensions;
182
+ dimensions.width = params.width;
183
+ dimensions.height = params.height;
184
+ }
185
+ if (hasOwn(params.shaderProps, '$alpha') === true) {
186
+ params.shaderProps.$alpha = params.alpha;
187
+ }
188
+ }
189
+ let { curBufferIdx: bufferIdx, curRenderOp } = this;
190
+ const targetDims = { width: params.width, height: params.height };
191
+ if (this.reuseRenderOp(params) === false) {
192
+ this.newRenderOp(params.shader, params.shaderProps, params.alpha, targetDims, params.clippingRect, bufferIdx, params.rtt, params.parentHasRenderTexture, params.framebufferDimensions);
193
+ curRenderOp = this.curRenderOp;
194
+ assertTruthy(curRenderOp);
195
+ }
196
+ let ctxTexture = undefined;
197
+ let texCoordX1 = 0;
198
+ let texCoordY1 = 0;
199
+ let texCoordX2 = 1;
200
+ let texCoordY2 = 1;
201
+ if (texture.type === TextureType.subTexture) {
202
+ const { x: tx, y: ty, width: tw, height: th, } = texture.props;
203
+ const { width: parentW = 0, height: parentH = 0 } = texture.parentTexture.dimensions || { width: 0, height: 0 };
204
+ texCoordX1 = tx / parentW;
205
+ texCoordX2 = texCoordX1 + tw / parentW;
206
+ texCoordY1 = ty / parentH;
207
+ texCoordY2 = texCoordY1 + th / parentH;
208
+ texture = texture.parentTexture;
209
+ ctxTexture = texture.ctxTexture;
210
+ }
211
+ else {
212
+ ctxTexture = texture.ctxTexture;
213
+ if (ctxTexture === undefined) {
214
+ ctxTexture = this.stage.defaultTexture?.ctxTexture;
215
+ console.warn('WebGL Renderer: Texture does not have a ctxTexture, using default texture instead');
216
+ }
217
+ texCoordX1 = ctxTexture.txCoordX1;
218
+ texCoordY1 = ctxTexture.txCoordY1;
219
+ texCoordX2 = ctxTexture.txCoordX2;
220
+ texCoordY2 = ctxTexture.txCoordY2;
221
+ }
222
+ if (texture.type === TextureType.image &&
223
+ params.textureOptions !== null &&
224
+ params.textureOptions.resizeMode !== undefined &&
225
+ texture.dimensions !== null) {
226
+ const resizeMode = params.textureOptions.resizeMode;
227
+ const { width: tw, height: th } = texture.dimensions;
228
+ if (resizeMode.type === 'cover') {
229
+ const scaleX = params.width / tw;
230
+ const scaleY = params.height / th;
231
+ const scale = Math.max(scaleX, scaleY);
232
+ const precision = 1 / scale;
233
+ // Determine based on width
234
+ if (scale && scaleX && scaleX < scale) {
235
+ const desiredSize = precision * params.width;
236
+ texCoordX1 = (1 - desiredSize / tw) * (resizeMode.clipX ?? 0.5);
237
+ texCoordX2 = texCoordX1 + desiredSize / tw;
238
+ }
239
+ // Determine based on height
240
+ if (scale && scaleY && scaleY < scale) {
241
+ const desiredSize = precision * params.height;
242
+ texCoordY1 = (1 - desiredSize / th) * (resizeMode.clipY ?? 0.5);
243
+ texCoordY2 = texCoordY1 + desiredSize / th;
244
+ }
245
+ }
246
+ }
247
+ // Flip texture coordinates if dictated by texture options
248
+ let flipY = 0;
249
+ if (params.textureOptions !== null) {
250
+ if (params.textureOptions.flipX === true) {
251
+ [texCoordX1, texCoordX2] = [texCoordX2, texCoordX1];
252
+ }
253
+ // convert to integer for bitwise operation below
254
+ flipY = +(params.textureOptions.flipY || false);
255
+ }
256
+ // Eitherone should be true
257
+ if (flipY ^ +(texture.type === TextureType.renderToTexture)) {
258
+ [texCoordY1, texCoordY2] = [texCoordY2, texCoordY1];
259
+ }
260
+ const textureIdx = this.addTexture(ctxTexture, bufferIdx);
261
+ assertTruthy(this.curRenderOp !== null);
262
+ if (params.renderCoords) {
263
+ // Upper-Left
264
+ fQuadBuffer[bufferIdx++] = params.renderCoords.x1; // vertexX
265
+ fQuadBuffer[bufferIdx++] = params.renderCoords.y1; // vertexY
266
+ fQuadBuffer[bufferIdx++] = texCoordX1; // texCoordX
267
+ fQuadBuffer[bufferIdx++] = texCoordY1; // texCoordY
268
+ uiQuadBuffer[bufferIdx++] = params.colorTl; // color
269
+ fQuadBuffer[bufferIdx++] = textureIdx; // texIndex
270
+ fQuadBuffer[bufferIdx++] = 0;
271
+ fQuadBuffer[bufferIdx++] = 0;
272
+ // Upper-Right
273
+ fQuadBuffer[bufferIdx++] = params.renderCoords.x2;
274
+ fQuadBuffer[bufferIdx++] = params.renderCoords.y2;
275
+ fQuadBuffer[bufferIdx++] = texCoordX2;
276
+ fQuadBuffer[bufferIdx++] = texCoordY1;
277
+ uiQuadBuffer[bufferIdx++] = params.colorTr;
278
+ fQuadBuffer[bufferIdx++] = textureIdx;
279
+ fQuadBuffer[bufferIdx++] = 1;
280
+ fQuadBuffer[bufferIdx++] = 0;
281
+ // Lower-Left
282
+ fQuadBuffer[bufferIdx++] = params.renderCoords.x4;
283
+ fQuadBuffer[bufferIdx++] = params.renderCoords.y4;
284
+ fQuadBuffer[bufferIdx++] = texCoordX1;
285
+ fQuadBuffer[bufferIdx++] = texCoordY2;
286
+ uiQuadBuffer[bufferIdx++] = params.colorBl;
287
+ fQuadBuffer[bufferIdx++] = textureIdx;
288
+ fQuadBuffer[bufferIdx++] = 0;
289
+ fQuadBuffer[bufferIdx++] = 1;
290
+ // Lower-Right
291
+ fQuadBuffer[bufferIdx++] = params.renderCoords.x3;
292
+ fQuadBuffer[bufferIdx++] = params.renderCoords.y3;
293
+ fQuadBuffer[bufferIdx++] = texCoordX2;
294
+ fQuadBuffer[bufferIdx++] = texCoordY2;
295
+ uiQuadBuffer[bufferIdx++] = params.colorBr;
296
+ fQuadBuffer[bufferIdx++] = textureIdx;
297
+ fQuadBuffer[bufferIdx++] = 1;
298
+ fQuadBuffer[bufferIdx++] = 1;
299
+ }
300
+ else if (params.tb !== 0 || params.tc !== 0) {
301
+ // Upper-Left
302
+ fQuadBuffer[bufferIdx++] = params.tx; // vertexX
303
+ fQuadBuffer[bufferIdx++] = params.ty; // vertexY
304
+ fQuadBuffer[bufferIdx++] = texCoordX1; // texCoordX
305
+ fQuadBuffer[bufferIdx++] = texCoordY1; // texCoordY
306
+ uiQuadBuffer[bufferIdx++] = params.colorTl; // color
307
+ fQuadBuffer[bufferIdx++] = textureIdx; // texIndex
308
+ fQuadBuffer[bufferIdx++] = 0;
309
+ fQuadBuffer[bufferIdx++] = 0;
310
+ // Upper-Right
311
+ fQuadBuffer[bufferIdx++] = params.tx + params.width * params.ta;
312
+ fQuadBuffer[bufferIdx++] = params.ty + params.width * params.tc;
313
+ fQuadBuffer[bufferIdx++] = texCoordX2;
314
+ fQuadBuffer[bufferIdx++] = texCoordY1;
315
+ uiQuadBuffer[bufferIdx++] = params.colorTr;
316
+ fQuadBuffer[bufferIdx++] = textureIdx;
317
+ fQuadBuffer[bufferIdx++] = 1;
318
+ fQuadBuffer[bufferIdx++] = 0;
319
+ // Lower-Left
320
+ fQuadBuffer[bufferIdx++] = params.tx + params.height * params.tb;
321
+ fQuadBuffer[bufferIdx++] = params.ty + params.height * params.td;
322
+ fQuadBuffer[bufferIdx++] = texCoordX1;
323
+ fQuadBuffer[bufferIdx++] = texCoordY2;
324
+ uiQuadBuffer[bufferIdx++] = params.colorBl;
325
+ fQuadBuffer[bufferIdx++] = textureIdx;
326
+ fQuadBuffer[bufferIdx++] = 0;
327
+ fQuadBuffer[bufferIdx++] = 1;
328
+ // Lower-Right
329
+ fQuadBuffer[bufferIdx++] =
330
+ params.tx + params.width * params.ta + params.height * params.tb;
331
+ fQuadBuffer[bufferIdx++] =
332
+ params.ty + params.width * params.tc + params.height * params.td;
333
+ fQuadBuffer[bufferIdx++] = texCoordX2;
334
+ fQuadBuffer[bufferIdx++] = texCoordY2;
335
+ uiQuadBuffer[bufferIdx++] = params.colorBr;
336
+ fQuadBuffer[bufferIdx++] = textureIdx;
337
+ fQuadBuffer[bufferIdx++] = 1;
338
+ fQuadBuffer[bufferIdx++] = 1;
339
+ }
340
+ else {
341
+ // Calculate the right corner of the quad
342
+ // multiplied by the scale
343
+ const rightCornerX = params.tx + params.width * params.ta;
344
+ const rightCornerY = params.ty + params.height * params.td;
345
+ // Upper-Left
346
+ fQuadBuffer[bufferIdx++] = params.tx; // vertexX
347
+ fQuadBuffer[bufferIdx++] = params.ty; // vertexY
348
+ fQuadBuffer[bufferIdx++] = texCoordX1; // texCoordX
349
+ fQuadBuffer[bufferIdx++] = texCoordY1; // texCoordY
350
+ uiQuadBuffer[bufferIdx++] = params.colorTl; // color
351
+ fQuadBuffer[bufferIdx++] = textureIdx; // texIndex
352
+ fQuadBuffer[bufferIdx++] = 0;
353
+ fQuadBuffer[bufferIdx++] = 0;
354
+ // Upper-Right
355
+ fQuadBuffer[bufferIdx++] = rightCornerX;
356
+ fQuadBuffer[bufferIdx++] = params.ty;
357
+ fQuadBuffer[bufferIdx++] = texCoordX2;
358
+ fQuadBuffer[bufferIdx++] = texCoordY1;
359
+ uiQuadBuffer[bufferIdx++] = params.colorTr;
360
+ fQuadBuffer[bufferIdx++] = textureIdx;
361
+ fQuadBuffer[bufferIdx++] = 1;
362
+ fQuadBuffer[bufferIdx++] = 0;
363
+ // Lower-Left
364
+ fQuadBuffer[bufferIdx++] = params.tx;
365
+ fQuadBuffer[bufferIdx++] = rightCornerY;
366
+ fQuadBuffer[bufferIdx++] = texCoordX1;
367
+ fQuadBuffer[bufferIdx++] = texCoordY2;
368
+ uiQuadBuffer[bufferIdx++] = params.colorBl;
369
+ fQuadBuffer[bufferIdx++] = textureIdx;
370
+ fQuadBuffer[bufferIdx++] = 0;
371
+ fQuadBuffer[bufferIdx++] = 1;
372
+ // Lower-Right
373
+ fQuadBuffer[bufferIdx++] = rightCornerX;
374
+ fQuadBuffer[bufferIdx++] = rightCornerY;
375
+ fQuadBuffer[bufferIdx++] = texCoordX2;
376
+ fQuadBuffer[bufferIdx++] = texCoordY2;
377
+ uiQuadBuffer[bufferIdx++] = params.colorBr;
378
+ fQuadBuffer[bufferIdx++] = textureIdx;
379
+ fQuadBuffer[bufferIdx++] = 1;
380
+ fQuadBuffer[bufferIdx++] = 1;
381
+ }
382
+ // Update the length of the current render op
383
+ this.curRenderOp.numQuads++;
384
+ this.curBufferIdx = bufferIdx;
385
+ }
386
+ /**
387
+ * Replace the existing RenderOp with a new one that uses the specified Shader
388
+ * and starts at the specified buffer index.
389
+ *
390
+ * @param shader
391
+ * @param bufferIdx
392
+ */
393
+ newRenderOp(shader, shaderProps, alpha, dimensions, clippingRect, bufferIdx, renderToTexture, parentHasRenderTexture, framebufferDimensions) {
394
+ const curRenderOp = new WebGlCoreRenderOp(this.glw, this.options, this.quadBufferCollection, shader, shaderProps, alpha, clippingRect, dimensions, bufferIdx, 0, // Z-Index is only used for explictly added Render Ops
395
+ renderToTexture, parentHasRenderTexture, framebufferDimensions);
396
+ this.curRenderOp = curRenderOp;
397
+ this.renderOps.push(curRenderOp);
398
+ }
399
+ /**
400
+ * Add a texture to the current RenderOp. If the texture cannot be added to the
401
+ * current RenderOp, a new RenderOp will be created and the texture will be added
402
+ * to that one.
403
+ *
404
+ * If the texture cannot be added to the new RenderOp, an error will be thrown.
405
+ *
406
+ * @param texture
407
+ * @param bufferIdx
408
+ * @param recursive
409
+ * @returns Assigned Texture Index of the texture in the render op
410
+ */
411
+ addTexture(texture, bufferIdx, recursive) {
412
+ const { curRenderOp } = this;
413
+ assertTruthy(curRenderOp);
414
+ const textureIdx = curRenderOp.addTexture(texture);
415
+ // TODO: Refactor to be more DRY
416
+ if (textureIdx === 0xffffffff) {
417
+ if (recursive) {
418
+ throw new Error('Unable to add texture to render op');
419
+ }
420
+ this.newRenderOp(curRenderOp.shader, curRenderOp.shaderProps, curRenderOp.alpha, curRenderOp.dimensions, curRenderOp.clippingRect, bufferIdx);
421
+ return this.addTexture(texture, bufferIdx, true);
422
+ }
423
+ return textureIdx;
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) {
431
+ const { shader, shaderProps, parentHasRenderTexture, rtt, clippingRect } = params;
432
+ // Switching shader program will require a new render operation
433
+ if (this.curRenderOp?.shader !== shader) {
434
+ return false;
435
+ }
436
+ // Switching clipping rect will require a new render operation
437
+ if (compareRect(this.curRenderOp.clippingRect, clippingRect) === false) {
438
+ return false;
439
+ }
440
+ // Force new render operation if rendering to texture
441
+ // @todo: This needs to be improved, render operations could also be reused
442
+ // for rendering to texture
443
+ if (parentHasRenderTexture === true || rtt === true) {
444
+ return false;
445
+ }
446
+ // Check if the shader can batch the shader properties
447
+ if (this.curRenderOp.shader !== this.defaultShader &&
448
+ this.curRenderOp.shader.canBatchShaderProps(this.curRenderOp.shaderProps, shaderProps) === false) {
449
+ return false;
450
+ }
451
+ // Render operation can be reused
452
+ return true;
453
+ }
454
+ /**
455
+ * add RenderOp to the render pipeline
456
+ */
457
+ addRenderOp(renderable) {
458
+ this.renderOps.push(renderable);
459
+ this.curRenderOp = null;
460
+ }
461
+ /**
462
+ * Render the current set of RenderOps to render to the specified surface.
463
+ *
464
+ * TODO: 'screen' is the only supported surface at the moment.
465
+ *
466
+ * @param surface
467
+ */
468
+ render(surface = 'screen') {
469
+ const { glw, quadBuffer } = this;
470
+ const arr = new Float32Array(quadBuffer, 0, this.curBufferIdx);
471
+ const buffer = this.quadBufferCollection.getBuffer('a_position') || null;
472
+ glw.arrayBufferData(buffer, arr, glw.STATIC_DRAW);
473
+ for (let i = 0, length = this.renderOps.length; i < length; i++) {
474
+ // eslint-disable-next-line @typescript-eslint/no-non-null-assertion
475
+ this.renderOps[i].draw();
476
+ }
477
+ this.quadBufferUsage = this.curBufferIdx * arr.BYTES_PER_ELEMENT;
478
+ // Calculate the size of each quad in bytes (4 vertices per quad) times the size of each vertex in bytes
479
+ const QUAD_SIZE_IN_BYTES = 4 * (8 * arr.BYTES_PER_ELEMENT); // 8 attributes per vertex
480
+ this.numQuadsRendered = this.quadBufferUsage / QUAD_SIZE_IN_BYTES;
481
+ }
482
+ getQuadCount() {
483
+ return this.numQuadsRendered;
484
+ }
485
+ renderToTexture(node) {
486
+ for (let i = 0; i < this.rttNodes.length; i++) {
487
+ if (this.rttNodes[i] === node) {
488
+ return;
489
+ }
490
+ }
491
+ this.insertRTTNodeInOrder(node);
492
+ }
493
+ /**
494
+ * Inserts an RTT node into `this.rttNodes` while maintaining the correct rendering order based on hierarchy.
495
+ *
496
+ * Rendering order for RTT nodes is critical when nested RTT nodes exist in a parent-child relationship.
497
+ * Specifically:
498
+ * - Child RTT nodes must be rendered before their RTT-enabled parents to ensure proper texture composition.
499
+ * - If an RTT node is added and it has existing RTT children, it should be rendered after those children.
500
+ *
501
+ * This function addresses both cases by:
502
+ * 1. **Checking Upwards**: It traverses the node's hierarchy upwards to identify any RTT parent
503
+ * already in `rttNodes`. If an RTT parent is found, the new node is placed before this parent.
504
+ * 2. **Checking Downwards**: It traverses the node’s children recursively to find any RTT-enabled
505
+ * children that are already in `rttNodes`. If such children are found, the new node is inserted
506
+ * after the last (highest index) RTT child node.
507
+ *
508
+ * The final calculated insertion index ensures the new node is positioned in `rttNodes` to respect
509
+ * both parent-before-child and child-before-parent rendering rules, preserving the correct order
510
+ * for the WebGL renderer.
511
+ *
512
+ * @param node - The RTT-enabled CoreNode to be added to `rttNodes` in the appropriate hierarchical position.
513
+ */
514
+ insertRTTNodeInOrder(node) {
515
+ let insertIndex = this.rttNodes.length; // Default to the end of the array
516
+ // 1. Traverse upwards to ensure the node is placed before its RTT parent (if any).
517
+ let currentNode = node;
518
+ while (currentNode) {
519
+ if (!currentNode.parent) {
520
+ break;
521
+ }
522
+ const parentIndex = this.rttNodes.indexOf(currentNode.parent);
523
+ if (parentIndex !== -1) {
524
+ // Found an RTT parent in the list; set insertIndex to place node before the parent
525
+ insertIndex = parentIndex;
526
+ break;
527
+ }
528
+ currentNode = currentNode.parent;
529
+ }
530
+ // 2. Traverse downwards to ensure the node is placed after any RTT children.
531
+ // Look through each child recursively to see if any are already in rttNodes.
532
+ const maxChildIndex = this.findMaxChildRTTIndex(node);
533
+ if (maxChildIndex !== -1) {
534
+ // Adjust insertIndex to be after the last child RTT node
535
+ insertIndex = Math.max(insertIndex, maxChildIndex + 1);
536
+ }
537
+ // 3. Insert the node at the calculated position
538
+ this.rttNodes.splice(insertIndex, 0, node);
539
+ }
540
+ // Helper function to find the highest index of any RTT children of a node within rttNodes
541
+ findMaxChildRTTIndex(node) {
542
+ let maxIndex = -1;
543
+ const traverseChildren = (currentNode) => {
544
+ const currentIndex = this.rttNodes.indexOf(currentNode);
545
+ if (currentIndex !== -1) {
546
+ maxIndex = Math.max(maxIndex, currentIndex);
547
+ }
548
+ // Recursively check all children of the current node
549
+ for (const child of currentNode.children) {
550
+ traverseChildren(child);
551
+ }
552
+ };
553
+ // Start traversal directly with the provided node
554
+ traverseChildren(node);
555
+ return maxIndex;
556
+ }
557
+ renderRTTNodes() {
558
+ const { glw } = this;
559
+ const { txManager } = this.stage;
560
+ // Render all associated RTT nodes to their textures
561
+ for (let i = 0; i < this.rttNodes.length; i++) {
562
+ const node = this.rttNodes[i];
563
+ // Skip nodes that don't have RTT updates
564
+ if (node === undefined || node.hasRTTupdates === false) {
565
+ continue;
566
+ }
567
+ // Skip nodes that are not visible
568
+ if (node.worldAlpha === 0 ||
569
+ (node.strictBounds === true &&
570
+ node.renderState === CoreNodeRenderState.OutOfBounds)) {
571
+ continue;
572
+ }
573
+ // Skip nodes that do not have a loaded texture
574
+ if (node.texture === null || node.texture.state !== 'loaded') {
575
+ continue;
576
+ }
577
+ // Set the active RTT node to the current node
578
+ // So we can prevent rendering children of nested RTT nodes
579
+ this.activeRttNode = node;
580
+ assertTruthy(node.texture, 'RTT node missing texture');
581
+ const ctxTexture = node.texture.ctxTexture;
582
+ assertTruthy(ctxTexture instanceof WebGlCoreCtxRenderTexture);
583
+ this.renderToTextureActive = true;
584
+ // Bind the the texture's framebuffer
585
+ glw.bindFramebuffer(ctxTexture.framebuffer);
586
+ glw.viewport(0, 0, ctxTexture.w, ctxTexture.h);
587
+ // Set the clear color to transparent
588
+ glw.clearColor(0, 0, 0, 0);
589
+ glw.clear();
590
+ // Render all associated quads to the texture
591
+ for (let i = 0; i < node.children.length; i++) {
592
+ const child = node.children[i];
593
+ if (child === undefined) {
594
+ continue;
595
+ }
596
+ this.stage.addQuads(child);
597
+ child.hasRTTupdates = false;
598
+ }
599
+ // Render all associated quads to the texture
600
+ this.render();
601
+ // Reset render operations
602
+ this.renderOps.length = 0;
603
+ node.hasRTTupdates = false;
604
+ }
605
+ const clearColor = this.clearColor.normalized;
606
+ // Restore the default clear color
607
+ glw.clearColor(clearColor[0], clearColor[1], clearColor[2], clearColor[3]);
608
+ // Bind the default framebuffer
609
+ glw.bindFramebuffer(null);
610
+ glw.viewport(0, 0, this.glw.canvas.width, this.glw.canvas.height);
611
+ this.renderToTextureActive = false;
612
+ }
613
+ removeRTTNode(node) {
614
+ const index = this.rttNodes.indexOf(node);
615
+ if (index === -1) {
616
+ return;
617
+ }
618
+ this.rttNodes.splice(index, 1);
619
+ }
620
+ getBufferInfo() {
621
+ const bufferInfo = {
622
+ totalAvailable: this.stage.options.quadBufferSize,
623
+ totalUsed: this.quadBufferUsage,
624
+ };
625
+ return bufferInfo;
626
+ }
627
+ getDefShaderCtr() {
628
+ return this.defShaderCtrl;
629
+ }
630
+ /**
631
+ * Updates the WebGL context's clear color and clears the color buffer.
632
+ *
633
+ * @param color - The color to set as the clear color, represented as a 32-bit integer.
634
+ */
635
+ updateClearColor(color) {
636
+ if (this.clearColor.raw === color) {
637
+ return;
638
+ }
639
+ const glw = this.glw;
640
+ const normalizedColor = getNormalizedRgbaComponents(color);
641
+ glw.clearColor(normalizedColor[0], normalizedColor[1], normalizedColor[2], normalizedColor[3]);
642
+ this.clearColor = {
643
+ raw: color,
644
+ normalized: normalizedColor,
645
+ };
646
+ glw.clear();
647
+ }
648
+ }
649
+ //# sourceMappingURL=WebGlCoreRenderer.js.map