@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,522 +1,567 @@
1
- import {
2
- CoreNode,
3
- type CoreNodeAnimateProps,
4
- type CoreNodeProps,
5
- } from '../core/CoreNode.js';
6
- import { type RendererMainSettings } from './Renderer.js';
7
- import type { AnimationSettings } from '../core/animations/CoreAnimation.js';
8
- import type { IAnimationController } from '../common/IAnimationController.js';
9
- import { isProductionEnvironment } from '../utils.js';
10
- import type { CoreTextNode, CoreTextNodeProps } from '../core/CoreTextNode.js';
11
-
12
- /**
13
- * Inspector
14
- *
15
- * The inspector is a tool that allows you to inspect the state of the renderer
16
- * and the nodes that are being rendered. It is a tool that is used for debugging
17
- * and development purposes.
18
- *
19
- * The inspector will generate a DOM tree that mirrors the state of the renderer
20
- */
21
-
22
- /**
23
- * stylePropertyMap is a map of renderer properties that are mapped to CSS properties
24
- *
25
- * It can either return a string or an object with a prop and value property. Once a
26
- * property is found in the map, the value is set on the style of the div element.
27
- * Erik H made me do it.
28
- */
29
- interface StyleResponse {
30
- prop: string;
31
- value: string;
32
- }
33
- const stylePropertyMap: {
34
- [key: string]: (
35
- value: string | number | boolean,
36
- ) => string | StyleResponse | null;
37
- } = {
38
- alpha: (v) => {
39
- if (v === 1) {
40
- return null;
41
- }
42
-
43
- return { prop: 'opacity', value: `${v}` };
44
- },
45
- x: (x) => {
46
- return { prop: 'left', value: `${x}px` };
47
- },
48
- y: (y) => {
49
- return { prop: 'top', value: `${y}px` };
50
- },
51
- width: (w) => {
52
- if (w === 0) {
53
- return null;
54
- }
55
-
56
- return { prop: 'width', value: `${w}px` };
57
- },
58
- height: (h) => {
59
- if (h === 0) {
60
- return null;
61
- }
62
-
63
- return { prop: 'height', value: `${h}px` };
64
- },
65
- fontSize: (fs) => {
66
- if (fs === 0) {
67
- return null;
68
- }
69
-
70
- return { prop: 'font-size', value: `${fs}px` };
71
- },
72
- lineHeight: (lh) => {
73
- if (lh === 0) {
74
- return null;
75
- }
76
-
77
- return { prop: 'line-height', value: `${lh}px` };
78
- },
79
- zIndex: () => 'z-index',
80
- fontFamily: () => 'font-family',
81
- fontStyle: () => 'font-style',
82
- fontWeight: () => 'font-weight',
83
- fontStretch: () => 'font-stretch',
84
- letterSpacing: () => 'letter-spacing',
85
- textAlign: () => 'text-align',
86
- overflowSuffix: () => 'overflow-suffix',
87
- maxLines: () => 'max-lines',
88
- contain: () => 'contain',
89
- verticalAlign: () => 'vertical-align',
90
- clipping: (v) => {
91
- if (v === false) {
92
- return null;
93
- }
94
-
95
- return { prop: 'overflow', value: v ? 'hidden' : 'visible' };
96
- },
97
- rotation: (v) => {
98
- if (v === 0) {
99
- return null;
100
- }
101
-
102
- return { prop: 'transform', value: `rotate(${v}rad)` };
103
- },
104
- scale: (v) => {
105
- if (v === 1) {
106
- return null;
107
- }
108
-
109
- return { prop: 'transform', value: `scale(${v})` };
110
- },
111
- scaleX: (v) => {
112
- if (v === 1) {
113
- return null;
114
- }
115
-
116
- return { prop: 'transform', value: `scaleX(${v})` };
117
- },
118
- scaleY: (v) => {
119
- if (v === 1) {
120
- return null;
121
- }
122
-
123
- return { prop: 'transform', value: `scaleY(${v})` };
124
- },
125
- color: (v) => {
126
- if (v === 0) {
127
- return null;
128
- }
129
-
130
- return { prop: 'color', value: convertColorToRgba(v as number) };
131
- },
132
- };
133
-
134
- const convertColorToRgba = (color: number) => {
135
- const a = (color & 0xff) / 255;
136
- const b = (color >> 8) & 0xff;
137
- const g = (color >> 16) & 0xff;
138
- const r = (color >> 24) & 0xff;
139
- return `rgba(${r},${g},${b},${a})`;
140
- };
141
-
142
- const domPropertyMap: { [key: string]: string } = {
143
- id: 'test-id',
144
- };
145
-
146
- const gradientColorPropertyMap = [
147
- 'colorTop',
148
- 'colorBottom',
149
- 'colorLeft',
150
- 'colorRight',
151
- 'colorTl',
152
- 'colorTr',
153
- 'colorBl',
154
- 'colorBr',
155
- ];
156
-
157
- const knownProperties = new Set<string>([
158
- ...Object.keys(stylePropertyMap),
159
- ...Object.keys(domPropertyMap),
160
- // ...gradientColorPropertyMap,
161
- 'src',
162
- 'parent',
163
- 'data',
164
- ]);
165
-
166
- export class Inspector {
167
- private root: HTMLElement | null = null;
168
- private canvas: HTMLCanvasElement | null = null;
169
- private height = 1080;
170
- private width = 1920;
171
- private scaleX = 1;
172
- private scaleY = 1;
173
-
174
- constructor(canvas: HTMLCanvasElement, settings: RendererMainSettings) {
175
- if (isProductionEnvironment()) return;
176
-
177
- if (!settings) {
178
- throw new Error('settings is required');
179
- }
180
-
181
- // calc dimensions based on the devicePixelRatio
182
- this.height = Math.ceil(
183
- settings.appHeight ?? 1080 / (settings.deviceLogicalPixelRatio ?? 1),
184
- );
185
-
186
- this.width = Math.ceil(
187
- settings.appWidth ?? 1920 / (settings.deviceLogicalPixelRatio ?? 1),
188
- );
189
-
190
- this.scaleX = settings.deviceLogicalPixelRatio ?? 1;
191
- this.scaleY = settings.deviceLogicalPixelRatio ?? 1;
192
-
193
- this.canvas = canvas;
194
- this.root = document.createElement('div');
195
- this.setRootPosition();
196
- document.body.appendChild(this.root);
197
-
198
- //listen for changes on canvas
199
- const mutationObserver = new MutationObserver(
200
- this.setRootPosition.bind(this),
201
- );
202
- mutationObserver.observe(canvas, {
203
- attributes: true,
204
- childList: false,
205
- subtree: false,
206
- });
207
-
208
- // Create a ResizeObserver to watch for changes in the element's size
209
- const resizeObserver = new ResizeObserver(this.setRootPosition.bind(this));
210
- resizeObserver.observe(canvas);
211
-
212
- //listen for changes on window
213
- window.addEventListener('resize', this.setRootPosition.bind(this));
214
-
215
- console.warn('Inspector is enabled, this will impact performance');
216
- }
217
-
218
- setRootPosition() {
219
- if (this.root === null || this.canvas === null) {
220
- return;
221
- }
222
-
223
- // get the world position of the canvas object, so we can match the inspector to it
224
- const rect = this.canvas.getBoundingClientRect();
225
- const top = document.documentElement.scrollTop + rect.top;
226
- const left = document.documentElement.scrollLeft + rect.left;
227
-
228
- this.root.id = 'root';
229
- this.root.style.left = `${left}px`;
230
- this.root.style.top = `${top}px`;
231
- this.root.style.width = `${this.width}px`;
232
- this.root.style.height = `${this.height}px`;
233
- this.root.style.position = 'absolute';
234
- this.root.style.transformOrigin = '0 0 0';
235
- this.root.style.transform = `scale(${this.scaleX}, ${this.scaleY})`;
236
- this.root.style.overflow = 'hidden';
237
- this.root.style.zIndex = '65534';
238
- }
239
-
240
- createDiv(
241
- id: number,
242
- properties: CoreNodeProps | CoreTextNodeProps,
243
- ): HTMLElement {
244
- const div = document.createElement('div');
245
- div.style.position = 'absolute';
246
- div.id = id.toString();
247
-
248
- // set initial properties
249
- for (const key in properties) {
250
- this.updateNodeProperty(
251
- div,
252
- // really typescript? really?
253
- key as keyof CoreNodeProps,
254
- properties[key as keyof CoreNodeProps],
255
- properties,
256
- );
257
- }
258
-
259
- return div;
260
- }
261
-
262
- createNode(node: CoreNode): CoreNode {
263
- const div = this.createDiv(node.id, node.props);
264
- (div as HTMLElement & { node: CoreNode }).node = node;
265
- (node as CoreNode & { div: HTMLElement }).div = div;
266
-
267
- node.on('inViewport', () => div.setAttribute('state', 'inViewport'));
268
- node.on('inBounds', () => div.setAttribute('state', 'inBounds'));
269
- node.on('outOfBounds', () => div.setAttribute('state', 'outOfBounds'));
270
-
271
- // Monitor only relevant properties by trapping with selective assignment
272
- return this.createProxy(node, div);
273
- }
274
-
275
- createTextNode(node: CoreNode): CoreTextNode {
276
- const div = this.createDiv(node.id, node.props);
277
- (div as HTMLElement & { node: CoreNode }).node = node;
278
- (node as CoreNode & { div: HTMLElement }).div = div;
279
-
280
- return this.createProxy(node, div) as CoreTextNode;
281
- }
282
-
283
- createProxy(
284
- node: CoreNode | CoreTextNode,
285
- div: HTMLElement,
286
- ): CoreNode | CoreTextNode {
287
- // Define traps for each property in knownProperties
288
- knownProperties.forEach((property) => {
289
- let originalProp = Object.getOwnPropertyDescriptor(node, property);
290
-
291
- if (originalProp === undefined) {
292
- // Search the prototype chain for the property descriptor
293
- const proto = Object.getPrototypeOf(node) as CoreNode | CoreTextNode;
294
- originalProp = Object.getOwnPropertyDescriptor(proto, property);
295
- }
296
-
297
- if (originalProp === undefined) {
298
- return;
299
- }
300
-
301
- Object.defineProperty(node, property, {
302
- get() {
303
- // eslint-disable-next-line @typescript-eslint/no-unsafe-return
304
- return originalProp?.get?.call(node);
305
- },
306
- set: (value) => {
307
- originalProp?.set?.call(node, value);
308
- this.updateNodeProperty(
309
- div,
310
- property as keyof CoreNodeProps | keyof CoreTextNodeProps,
311
- value,
312
- node.props,
313
- );
314
- },
315
- configurable: true,
316
- enumerable: true,
317
- });
318
- });
319
-
320
- const originalDestroy = node.destroy;
321
- Object.defineProperty(node, 'destroy', {
322
- value: () => {
323
- this.destroyNode(node.id);
324
- originalDestroy.call(node);
325
- },
326
- });
327
-
328
- const originalAnimate = node.animate;
329
- Object.defineProperty(node, 'animate', {
330
- value: (
331
- props: CoreNodeAnimateProps,
332
- settings: AnimationSettings,
333
- ): IAnimationController => {
334
- const animationController = originalAnimate.call(node, props, settings);
335
-
336
- const originalStart =
337
- animationController.start.bind(animationController);
338
- animationController.start = () => {
339
- this.animateNode(div, props, settings);
340
-
341
- return originalStart();
342
- };
343
-
344
- return animationController;
345
- },
346
- });
347
-
348
- return node;
349
- }
350
-
351
- destroyNode(id: number) {
352
- const div = document.getElementById(id.toString());
353
- div?.remove();
354
- }
355
-
356
- updateNodeProperty(
357
- div: HTMLElement,
358
- property: keyof CoreNodeProps | keyof CoreTextNodeProps,
359
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
360
- value: any,
361
- props: CoreNodeProps | CoreTextNodeProps,
362
- ) {
363
- if (this.root === null || value === undefined || value === null) {
364
- return;
365
- }
366
-
367
- /**
368
- * Special case for parent property
369
- */
370
- if (property === 'parent') {
371
- const parentId: number = value.id;
372
-
373
- // only way to detect if the parent is the root node
374
- // if you are reading this and have a better way, please let me know
375
- if (parentId === 1) {
376
- this.root.appendChild(div);
377
- return;
378
- }
379
-
380
- const parent = document.getElementById(parentId.toString());
381
- parent?.appendChild(div);
382
- return;
383
- }
384
-
385
- // special case for text
386
- if (property === 'text') {
387
- div.innerHTML = String(value);
388
-
389
- // hide text because we can't render SDF fonts
390
- // it would look weird and obstruct the WebGL rendering
391
- div.style.visibility = 'hidden';
392
- return;
393
- }
394
-
395
- // special case for images
396
- // we're not setting any CSS properties to avoid images getting loaded twice
397
- // as the renderer will handle the loading of the image. Setting it to `data-src`
398
- if (property === 'src' && value) {
399
- div.setAttribute(`data-src`, String(value));
400
- return;
401
- }
402
-
403
- // special case for color gradients (normal colors are handled by the stylePropertyMap)
404
- // FIXME the renderer seems to return the same number for all colors
405
- // if (gradientColorPropertyMap.includes(property as string)) {
406
- // const color = convertColorToRgba(value as number);
407
- // div.setAttribute(`data-${property}`, color);
408
- // return;
409
- // }
410
-
411
- if (property === 'rtt' && value) {
412
- div.setAttribute('data-rtt', String(value));
413
- return;
414
- }
415
-
416
- // CSS mappable attribute
417
- if (stylePropertyMap[property]) {
418
- const mappedStyleResponse = stylePropertyMap[property]?.(value);
419
-
420
- if (mappedStyleResponse === null) {
421
- return;
422
- }
423
-
424
- if (typeof mappedStyleResponse === 'string') {
425
- div.style.setProperty(mappedStyleResponse, String(value));
426
- return;
427
- }
428
-
429
- if (typeof mappedStyleResponse === 'object') {
430
- let value = mappedStyleResponse.value;
431
- if (property === 'x') {
432
- const mount = props.mountX;
433
- const width = props.width;
434
-
435
- if (mount) {
436
- value = `${parseInt(value) - width * mount}px`;
437
- }
438
- } else if (property === 'y') {
439
- const mount = props.mountY;
440
- const height = props.height;
441
-
442
- if (mount) {
443
- value = `${parseInt(value) - height * mount}px`;
444
- }
445
- }
446
- div.style.setProperty(mappedStyleResponse.prop, value);
447
- }
448
-
449
- return;
450
- }
451
-
452
- // DOM properties
453
- if (domPropertyMap[property]) {
454
- const domProperty = domPropertyMap[property];
455
- if (!domProperty) {
456
- return;
457
- }
458
-
459
- div.setAttribute(String(domProperty), String(value));
460
- return;
461
- }
462
-
463
- // custom data properties
464
- if (property === 'data') {
465
- for (const key in value) {
466
- // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access
467
- const keyValue: unknown = value[key];
468
- if (keyValue === undefined) {
469
- div.removeAttribute(`data-${key}`);
470
- } else {
471
- div.setAttribute(`data-${key}`, String(keyValue));
472
- }
473
- }
474
- return;
475
- }
476
- }
477
-
478
- // simple animation handler
479
- animateNode(
480
- div: HTMLElement,
481
- props: CoreNodeAnimateProps,
482
- settings: AnimationSettings,
483
- ) {
484
- const {
485
- duration = 1000,
486
- delay = 0,
487
- // easing = 'linear',
488
- // repeat = 0,
489
- // loop = false,
490
- // stopMethod = false,
491
- } = settings;
492
-
493
- const {
494
- x,
495
- y,
496
- width,
497
- height,
498
- alpha = 1,
499
- rotation = 0,
500
- scale = 1,
501
- color,
502
- mountX,
503
- mountY,
504
- } = props;
505
-
506
- // ignoring loops and repeats for now, as that might be a bit too much for the inspector
507
- function animate() {
508
- setTimeout(() => {
509
- div.style.top = `${y - height * mountY}px`;
510
- div.style.left = `${x - width * mountX}px`;
511
- div.style.width = `${width}px`;
512
- div.style.height = `${height}px`;
513
- div.style.opacity = `${alpha}`;
514
- div.style.rotate = `${rotation}rad`;
515
- div.style.scale = `${scale}`;
516
- div.style.color = convertColorToRgba(color);
517
- }, duration);
518
- }
519
-
520
- setTimeout(animate, delay);
521
- }
522
- }
1
+ import {
2
+ CoreNode,
3
+ type CoreNodeAnimateProps,
4
+ type CoreNodeProps,
5
+ } from '../core/CoreNode.js';
6
+ import { type RendererMainSettings } from './Renderer.js';
7
+ import type { AnimationSettings } from '../core/animations/CoreAnimation.js';
8
+ import type { IAnimationController } from '../common/IAnimationController.js';
9
+ import { isProductionEnvironment } from '../utils.js';
10
+ import { CoreTextNode, type CoreTextNodeProps } from '../core/CoreTextNode.js';
11
+
12
+ /**
13
+ * Inspector
14
+ *
15
+ * The inspector is a tool that allows you to inspect the state of the renderer
16
+ * and the nodes that are being rendered. It is a tool that is used for debugging
17
+ * and development purposes.
18
+ *
19
+ * The inspector will generate a DOM tree that mirrors the state of the renderer
20
+ */
21
+
22
+ /**
23
+ * stylePropertyMap is a map of renderer properties that are mapped to CSS properties
24
+ *
25
+ * It can either return a string or an object with a prop and value property. Once a
26
+ * property is found in the map, the value is set on the style of the div element.
27
+ * Erik H made me do it.
28
+ */
29
+ interface StyleResponse {
30
+ prop: string;
31
+ value: string;
32
+ }
33
+ const stylePropertyMap: {
34
+ [key: string]: (
35
+ value: string | number | boolean,
36
+ ) => string | StyleResponse | null;
37
+ } = {
38
+ alpha: (v) => {
39
+ if (v === 1) {
40
+ return null;
41
+ }
42
+
43
+ return { prop: 'opacity', value: `${v}` };
44
+ },
45
+ x: (x) => {
46
+ return { prop: 'left', value: `${x}px` };
47
+ },
48
+ y: (y) => {
49
+ return { prop: 'top', value: `${y}px` };
50
+ },
51
+ width: (w) => {
52
+ if (w === 0) {
53
+ return null;
54
+ }
55
+
56
+ return { prop: 'width', value: `${w}px` };
57
+ },
58
+ height: (h) => {
59
+ if (h === 0) {
60
+ return null;
61
+ }
62
+
63
+ return { prop: 'height', value: `${h}px` };
64
+ },
65
+ fontSize: (fs) => {
66
+ if (fs === 0) {
67
+ return null;
68
+ }
69
+
70
+ return { prop: 'font-size', value: `${fs}px` };
71
+ },
72
+ lineHeight: (lh) => {
73
+ if (lh === 0) {
74
+ return null;
75
+ }
76
+
77
+ return { prop: 'line-height', value: `${lh}px` };
78
+ },
79
+ zIndex: () => 'z-index',
80
+ fontFamily: () => 'font-family',
81
+ fontStyle: () => 'font-style',
82
+ letterSpacing: () => 'letter-spacing',
83
+ textAlign: () => 'text-align',
84
+ overflowSuffix: () => 'overflow-suffix',
85
+ maxLines: () => 'max-lines',
86
+ contain: () => 'contain',
87
+ verticalAlign: () => 'vertical-align',
88
+ clipping: (v) => {
89
+ if (v === false) {
90
+ return null;
91
+ }
92
+
93
+ return { prop: 'overflow', value: v ? 'hidden' : 'visible' };
94
+ },
95
+ rotation: (v) => {
96
+ if (v === 0) {
97
+ return null;
98
+ }
99
+
100
+ return { prop: 'transform', value: `rotate(${v}rad)` };
101
+ },
102
+ scale: (v) => {
103
+ if (v === 1) {
104
+ return null;
105
+ }
106
+
107
+ return { prop: 'transform', value: `scale(${v})` };
108
+ },
109
+ scaleX: (v) => {
110
+ if (v === 1) {
111
+ return null;
112
+ }
113
+
114
+ return { prop: 'transform', value: `scaleX(${v})` };
115
+ },
116
+ scaleY: (v) => {
117
+ if (v === 1) {
118
+ return null;
119
+ }
120
+
121
+ return { prop: 'transform', value: `scaleY(${v})` };
122
+ },
123
+ color: (v) => {
124
+ if (v === 0) {
125
+ return null;
126
+ }
127
+
128
+ return { prop: 'color', value: convertColorToRgba(v as number) };
129
+ },
130
+ };
131
+
132
+ const convertColorToRgba = (color: number) => {
133
+ const a = (color & 0xff) / 255;
134
+ const b = (color >> 8) & 0xff;
135
+ const g = (color >> 16) & 0xff;
136
+ const r = (color >> 24) & 0xff;
137
+ return `rgba(${r},${g},${b},${a})`;
138
+ };
139
+
140
+ const domPropertyMap: { [key: string]: string } = {
141
+ id: 'test-id',
142
+ };
143
+
144
+ const gradientColorPropertyMap = [
145
+ 'colorTop',
146
+ 'colorBottom',
147
+ 'colorLeft',
148
+ 'colorRight',
149
+ 'colorTl',
150
+ 'colorTr',
151
+ 'colorBl',
152
+ 'colorBr',
153
+ ];
154
+
155
+ const knownProperties = new Set<string>([
156
+ ...Object.keys(stylePropertyMap),
157
+ ...Object.keys(domPropertyMap),
158
+ // ...gradientColorPropertyMap,
159
+ 'src',
160
+ 'parent',
161
+ 'data',
162
+ ]);
163
+
164
+ export class Inspector {
165
+ private root: HTMLElement | null = null;
166
+ private canvas: HTMLCanvasElement | null = null;
167
+ private mutationObserver: MutationObserver = new MutationObserver(() => {});
168
+ private resizeObserver: ResizeObserver = new ResizeObserver(() => {});
169
+ private height = 1080;
170
+ private width = 1920;
171
+ private scaleX = 1;
172
+ private scaleY = 1;
173
+
174
+ constructor(canvas: HTMLCanvasElement, settings: RendererMainSettings) {
175
+ if (isProductionEnvironment === true) return;
176
+
177
+ if (!settings) {
178
+ throw new Error('settings is required');
179
+ }
180
+
181
+ // calc dimensions based on the devicePixelRatio
182
+ this.height = Math.ceil(
183
+ settings.appHeight ?? 1080 / (settings.deviceLogicalPixelRatio ?? 1),
184
+ );
185
+
186
+ this.width = Math.ceil(
187
+ settings.appWidth ?? 1920 / (settings.deviceLogicalPixelRatio ?? 1),
188
+ );
189
+
190
+ this.scaleX = settings.deviceLogicalPixelRatio ?? 1;
191
+ this.scaleY = settings.deviceLogicalPixelRatio ?? 1;
192
+
193
+ this.canvas = canvas;
194
+ this.root = document.createElement('div');
195
+ this.setRootPosition();
196
+ document.body.appendChild(this.root);
197
+
198
+ //listen for changes on canvas
199
+ this.mutationObserver = new MutationObserver(
200
+ this.setRootPosition.bind(this),
201
+ );
202
+ this.mutationObserver.observe(canvas, {
203
+ attributes: true,
204
+ childList: false,
205
+ subtree: false,
206
+ });
207
+
208
+ // Create a ResizeObserver to watch for changes in the element's size
209
+ this.resizeObserver = new ResizeObserver(this.setRootPosition.bind(this));
210
+ this.resizeObserver.observe(canvas);
211
+
212
+ //listen for changes on window
213
+ window.addEventListener('resize', this.setRootPosition.bind(this));
214
+
215
+ console.warn('Inspector is enabled, this will impact performance');
216
+ }
217
+
218
+ setRootPosition() {
219
+ if (this.root === null || this.canvas === null) {
220
+ return;
221
+ }
222
+
223
+ // get the world position of the canvas object, so we can match the inspector to it
224
+ const rect = this.canvas.getBoundingClientRect();
225
+ const top = document.documentElement.scrollTop + rect.top;
226
+ const left = document.documentElement.scrollLeft + rect.left;
227
+
228
+ this.root.id = 'root';
229
+ this.root.style.left = `${left}px`;
230
+ this.root.style.top = `${top}px`;
231
+ this.root.style.width = `${this.width}px`;
232
+ this.root.style.height = `${this.height}px`;
233
+ this.root.style.position = 'absolute';
234
+ this.root.style.transformOrigin = '0 0 0';
235
+ this.root.style.transform = `scale(${this.scaleX}, ${this.scaleY})`;
236
+ this.root.style.overflow = 'hidden';
237
+ this.root.style.zIndex = '65534';
238
+ }
239
+
240
+ createDiv(
241
+ id: number,
242
+ properties: CoreNodeProps | CoreTextNodeProps,
243
+ ): HTMLElement {
244
+ const div = document.createElement('div');
245
+ div.style.position = 'absolute';
246
+ div.id = id.toString();
247
+
248
+ // set initial properties
249
+ for (const key in properties) {
250
+ this.updateNodeProperty(
251
+ div,
252
+ // really typescript? really?
253
+ key as keyof CoreNodeProps,
254
+ properties[key as keyof CoreNodeProps],
255
+ properties,
256
+ );
257
+ }
258
+
259
+ return div;
260
+ }
261
+
262
+ createNodes(node: CoreNode): boolean {
263
+ if (this.root === null) {
264
+ return false;
265
+ }
266
+
267
+ const div = this.root.querySelector(`[id="${node.id}"]`);
268
+ if (div === null && node instanceof CoreTextNode) {
269
+ this.createTextNode(node);
270
+ } else if (div === null && node instanceof CoreNode) {
271
+ this.createNode(node);
272
+ }
273
+
274
+ for (const child of node.children) {
275
+ this.createNodes(child);
276
+ }
277
+ return true;
278
+ }
279
+
280
+ createNode(node: CoreNode): CoreNode {
281
+ const div = this.createDiv(node.id, node.props);
282
+ (div as HTMLElement & { node: CoreNode }).node = node;
283
+ (node as CoreNode & { div: HTMLElement }).div = div;
284
+
285
+ node.on('inViewport', () => div.setAttribute('state', 'inViewport'));
286
+ node.on('inBounds', () => div.setAttribute('state', 'inBounds'));
287
+ node.on('outOfBounds', () => div.setAttribute('state', 'outOfBounds'));
288
+
289
+ // Monitor only relevant properties by trapping with selective assignment
290
+ return this.createProxy(node, div);
291
+ }
292
+
293
+ createTextNode(node: CoreNode): CoreTextNode {
294
+ const div = this.createDiv(node.id, node.props);
295
+ (div as HTMLElement & { node: CoreNode }).node = node;
296
+ (node as CoreNode & { div: HTMLElement }).div = div;
297
+
298
+ return this.createProxy(node, div) as CoreTextNode;
299
+ }
300
+
301
+ createProxy(
302
+ node: CoreNode | CoreTextNode,
303
+ div: HTMLElement,
304
+ ): CoreNode | CoreTextNode {
305
+ // Define traps for each property in knownProperties
306
+ knownProperties.forEach((property) => {
307
+ let originalProp = Object.getOwnPropertyDescriptor(node, property);
308
+
309
+ if (originalProp === undefined) {
310
+ // Search the prototype chain for the property descriptor
311
+ const proto = Object.getPrototypeOf(node) as CoreNode | CoreTextNode;
312
+ originalProp = Object.getOwnPropertyDescriptor(proto, property);
313
+ }
314
+
315
+ if (originalProp === undefined) {
316
+ return;
317
+ }
318
+
319
+ Object.defineProperty(node, property, {
320
+ get() {
321
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-return
322
+ return originalProp?.get?.call(node);
323
+ },
324
+ set: (value) => {
325
+ originalProp?.set?.call(node, value);
326
+ this.updateNodeProperty(
327
+ div,
328
+ property as keyof CoreNodeProps | keyof CoreTextNodeProps,
329
+ value,
330
+ node.props,
331
+ );
332
+ },
333
+ configurable: true,
334
+ enumerable: true,
335
+ });
336
+ });
337
+
338
+ const originalDestroy = node.destroy;
339
+ Object.defineProperty(node, 'destroy', {
340
+ value: () => {
341
+ this.destroyNode(node.id);
342
+ originalDestroy.call(node);
343
+ },
344
+ configurable: true,
345
+ });
346
+
347
+ const originalAnimate = node.animate;
348
+ Object.defineProperty(node, 'animate', {
349
+ value: (
350
+ props: CoreNodeAnimateProps,
351
+ settings: AnimationSettings,
352
+ ): IAnimationController => {
353
+ const animationController = originalAnimate.call(node, props, settings);
354
+
355
+ const originalStart =
356
+ animationController.start.bind(animationController);
357
+ animationController.start = () => {
358
+ this.animateNode(div, props, settings);
359
+
360
+ return originalStart();
361
+ };
362
+
363
+ return animationController;
364
+ },
365
+ configurable: true,
366
+ });
367
+
368
+ return node;
369
+ }
370
+
371
+ public destroy() {
372
+ // Remove DOM observers
373
+ this.mutationObserver.disconnect();
374
+ this.resizeObserver.disconnect();
375
+
376
+ // Remove resize listener
377
+ window.removeEventListener('resize', this.setRootPosition.bind(this));
378
+ if (this.root && this.root.parentNode) {
379
+ this.root.remove();
380
+ }
381
+ }
382
+
383
+ destroyNode(id: number) {
384
+ const div = document.getElementById(id.toString());
385
+ div?.remove();
386
+ }
387
+
388
+ updateNodeProperty(
389
+ div: HTMLElement,
390
+ property: keyof CoreNodeProps | keyof CoreTextNodeProps,
391
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
392
+ value: any,
393
+ props: CoreNodeProps | CoreTextNodeProps,
394
+ ) {
395
+ if (this.root === null || value === undefined || value === null) {
396
+ return;
397
+ }
398
+
399
+ /**
400
+ * Special case for parent property
401
+ */
402
+ if (property === 'parent') {
403
+ const parentId: number = value.id;
404
+
405
+ // only way to detect if the parent is the root node
406
+ // if you are reading this and have a better way, please let me know
407
+ if (parentId === 1) {
408
+ this.root.appendChild(div);
409
+ return;
410
+ }
411
+
412
+ const parent = document.getElementById(parentId.toString());
413
+ parent?.appendChild(div);
414
+ return;
415
+ }
416
+
417
+ // special case for text
418
+ if (property === 'text') {
419
+ div.innerHTML = String(value);
420
+
421
+ // hide text because we can't render SDF fonts
422
+ // it would look weird and obstruct the WebGL rendering
423
+ div.style.visibility = 'hidden';
424
+ return;
425
+ }
426
+
427
+ // special case for images
428
+ // we're not setting any CSS properties to avoid images getting loaded twice
429
+ // as the renderer will handle the loading of the image. Setting it to `data-src`
430
+ if (property === 'src' && value) {
431
+ div.setAttribute(`data-src`, String(value));
432
+ return;
433
+ }
434
+
435
+ // special case for color gradients (normal colors are handled by the stylePropertyMap)
436
+ // FIXME the renderer seems to return the same number for all colors
437
+ // if (gradientColorPropertyMap.includes(property as string)) {
438
+ // const color = convertColorToRgba(value as number);
439
+ // div.setAttribute(`data-${property}`, color);
440
+ // return;
441
+ // }
442
+
443
+ if (property === 'rtt' && value) {
444
+ div.setAttribute('data-rtt', String(value));
445
+ return;
446
+ }
447
+
448
+ // CSS mappable attribute
449
+ if (stylePropertyMap[property]) {
450
+ const mappedStyleResponse = stylePropertyMap[property]?.(value);
451
+
452
+ if (mappedStyleResponse === null) {
453
+ return;
454
+ }
455
+
456
+ if (typeof mappedStyleResponse === 'string') {
457
+ div.style.setProperty(mappedStyleResponse, String(value));
458
+ return;
459
+ }
460
+
461
+ if (typeof mappedStyleResponse === 'object') {
462
+ let value = mappedStyleResponse.value;
463
+ if (property === 'x') {
464
+ const mount = props.mountX;
465
+ const width = props.width;
466
+
467
+ if (mount) {
468
+ value = `${parseInt(value) - width * mount}px`;
469
+ }
470
+ } else if (property === 'y') {
471
+ const mount = props.mountY;
472
+ const height = props.height;
473
+
474
+ if (mount) {
475
+ value = `${parseInt(value) - height * mount}px`;
476
+ }
477
+ }
478
+ div.style.setProperty(mappedStyleResponse.prop, value);
479
+ }
480
+
481
+ return;
482
+ }
483
+
484
+ // DOM properties
485
+ if (domPropertyMap[property]) {
486
+ const domProperty = domPropertyMap[property];
487
+ if (!domProperty) {
488
+ return;
489
+ }
490
+
491
+ div.setAttribute(String(domProperty), String(value));
492
+ return;
493
+ }
494
+
495
+ // custom data properties
496
+ if (property === 'data') {
497
+ for (const key in value) {
498
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access
499
+ const keyValue: unknown = value[key];
500
+ if (keyValue === undefined) {
501
+ div.removeAttribute(`data-${key}`);
502
+ } else {
503
+ div.setAttribute(`data-${key}`, String(keyValue));
504
+ }
505
+ }
506
+ return;
507
+ }
508
+ }
509
+
510
+ updateViewport(
511
+ width: number,
512
+ height: number,
513
+ deviceLogicalPixelRatio: number,
514
+ ) {
515
+ this.scaleX = deviceLogicalPixelRatio ?? 1;
516
+ this.scaleY = deviceLogicalPixelRatio ?? 1;
517
+
518
+ this.width = width;
519
+ this.height = height;
520
+ this.setRootPosition();
521
+ }
522
+
523
+ // simple animation handler
524
+ animateNode(
525
+ div: HTMLElement,
526
+ props: CoreNodeAnimateProps,
527
+ settings: AnimationSettings,
528
+ ) {
529
+ const {
530
+ duration = 1000,
531
+ delay = 0,
532
+ // easing = 'linear',
533
+ // repeat = 0,
534
+ // loop = false,
535
+ // stopMethod = false,
536
+ } = settings;
537
+
538
+ const {
539
+ x,
540
+ y,
541
+ width,
542
+ height,
543
+ alpha = 1,
544
+ rotation = 0,
545
+ scale = 1,
546
+ color,
547
+ mountX,
548
+ mountY,
549
+ } = props;
550
+
551
+ // ignoring loops and repeats for now, as that might be a bit too much for the inspector
552
+ function animate() {
553
+ setTimeout(() => {
554
+ div.style.top = `${y - height * mountY}px`;
555
+ div.style.left = `${x - width * mountX}px`;
556
+ div.style.width = `${width}px`;
557
+ div.style.height = `${height}px`;
558
+ div.style.opacity = `${alpha}`;
559
+ div.style.rotate = `${rotation}rad`;
560
+ div.style.scale = `${scale}`;
561
+ div.style.color = convertColorToRgba(color);
562
+ }, duration);
563
+ }
564
+
565
+ setTimeout(animate, delay);
566
+ }
567
+ }