@lightningjs/renderer 2.12.1 → 3.0.0-beta1

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 (323) hide show
  1. package/dist/exports/canvas-shaders.d.ts +10 -0
  2. package/dist/exports/canvas-shaders.js +27 -0
  3. package/dist/exports/canvas-shaders.js.map +1 -0
  4. package/dist/exports/canvas.d.ts +7 -1
  5. package/dist/exports/canvas.js +7 -1
  6. package/dist/exports/canvas.js.map +1 -1
  7. package/dist/exports/index.d.ts +15 -8
  8. package/dist/exports/index.js +7 -4
  9. package/dist/exports/index.js.map +1 -1
  10. package/dist/exports/webgl-shaders.d.ts +11 -0
  11. package/dist/exports/webgl-shaders.js +28 -0
  12. package/dist/exports/webgl-shaders.js.map +1 -0
  13. package/dist/exports/webgl.d.ts +9 -1
  14. package/dist/exports/webgl.js +9 -1
  15. package/dist/exports/webgl.js.map +1 -1
  16. package/dist/src/core/CoreNode.d.ts +19 -5
  17. package/dist/src/core/CoreNode.js +117 -24
  18. package/dist/src/core/CoreNode.js.map +1 -1
  19. package/dist/src/core/CoreShaderManager.d.ts +29 -71
  20. package/dist/src/core/CoreShaderManager.js +110 -97
  21. package/dist/src/core/CoreShaderManager.js.map +1 -1
  22. package/dist/src/core/CoreTextNode.js +1 -1
  23. package/dist/src/core/CoreTextNode.js.map +1 -1
  24. package/dist/src/core/CoreTextureManager.d.ts +13 -7
  25. package/dist/src/core/CoreTextureManager.js +92 -105
  26. package/dist/src/core/CoreTextureManager.js.map +1 -1
  27. package/dist/src/core/Stage.d.ts +15 -16
  28. package/dist/src/core/Stage.js +45 -32
  29. package/dist/src/core/Stage.js.map +1 -1
  30. package/dist/src/core/TextureMemoryManager.d.ts +16 -6
  31. package/dist/src/core/TextureMemoryManager.js +75 -17
  32. package/dist/src/core/TextureMemoryManager.js.map +1 -1
  33. package/dist/src/core/animations/CoreAnimation.d.ts +0 -1
  34. package/dist/src/core/animations/CoreAnimation.js +6 -52
  35. package/dist/src/core/animations/CoreAnimation.js.map +1 -1
  36. package/dist/src/core/lib/ImageWorker.d.ts +1 -1
  37. package/dist/src/core/lib/ImageWorker.js +13 -11
  38. package/dist/src/core/lib/ImageWorker.js.map +1 -1
  39. package/dist/src/core/lib/WebGlContextWrapper.d.ts +67 -54
  40. package/dist/src/core/lib/WebGlContextWrapper.js +126 -157
  41. package/dist/src/core/lib/WebGlContextWrapper.js.map +1 -1
  42. package/dist/src/core/lib/textureCompression.js +0 -1
  43. package/dist/src/core/lib/textureCompression.js.map +1 -1
  44. package/dist/src/core/lib/utils.d.ts +4 -0
  45. package/dist/src/core/lib/utils.js +26 -0
  46. package/dist/src/core/lib/utils.js.map +1 -1
  47. package/dist/src/core/lib/validateImageBitmap.d.ts +6 -0
  48. package/dist/src/core/lib/validateImageBitmap.js +68 -0
  49. package/dist/src/core/lib/validateImageBitmap.js.map +1 -0
  50. package/dist/src/core/platform.js +4 -3
  51. package/dist/src/core/platform.js.map +1 -1
  52. package/dist/src/core/renderers/CoreRenderer.d.ts +11 -21
  53. package/dist/src/core/renderers/CoreRenderer.js +0 -6
  54. package/dist/src/core/renderers/CoreRenderer.js.map +1 -1
  55. package/dist/src/core/renderers/CoreShaderNode.d.ts +59 -0
  56. package/dist/src/core/renderers/CoreShaderNode.js +107 -0
  57. package/dist/src/core/renderers/CoreShaderNode.js.map +1 -0
  58. package/dist/src/core/renderers/CoreShaderProgram.d.ts +4 -0
  59. package/{src/core/renderers/CoreShader.ts → dist/src/core/renderers/CoreShaderProgram.js} +2 -23
  60. package/dist/src/core/renderers/CoreShaderProgram.js.map +1 -0
  61. package/dist/src/core/renderers/canvas/CanvasRenderer.d.ts +36 -0
  62. package/dist/src/core/renderers/canvas/CanvasRenderer.js +212 -0
  63. package/dist/src/core/renderers/canvas/CanvasRenderer.js.map +1 -0
  64. package/dist/src/core/renderers/canvas/CanvasShaderNode.d.ts +21 -0
  65. package/dist/src/core/renderers/canvas/CanvasShaderNode.js +60 -0
  66. package/dist/src/core/renderers/canvas/CanvasShaderNode.js.map +1 -0
  67. package/dist/src/core/renderers/canvas/CanvasTexture.d.ts +16 -0
  68. package/dist/src/core/renderers/canvas/CanvasTexture.js +123 -0
  69. package/dist/src/core/renderers/canvas/CanvasTexture.js.map +1 -0
  70. package/dist/src/core/renderers/canvas/internal/C2DShaderUtils.d.ts +0 -13
  71. package/dist/src/core/renderers/canvas/internal/C2DShaderUtils.js +192 -113
  72. package/dist/src/core/renderers/canvas/internal/C2DShaderUtils.js.map +1 -1
  73. package/dist/src/core/renderers/canvas/internal/ColorUtils.d.ts +2 -0
  74. package/dist/src/core/renderers/canvas/internal/ColorUtils.js +14 -0
  75. package/dist/src/core/renderers/canvas/internal/ColorUtils.js.map +1 -1
  76. package/dist/src/core/renderers/webgl/WebGlCoreCtxTexture.js +7 -12
  77. package/dist/src/core/renderers/webgl/WebGlCoreCtxTexture.js.map +1 -1
  78. package/dist/src/core/renderers/webgl/WebGlCtxRenderTexture.d.ts +12 -0
  79. package/dist/src/core/renderers/webgl/WebGlCtxRenderTexture.js +55 -0
  80. package/dist/src/core/renderers/webgl/WebGlCtxRenderTexture.js.map +1 -0
  81. package/dist/src/core/renderers/webgl/WebGlCtxSubTexture.d.ts +9 -0
  82. package/dist/src/core/renderers/webgl/WebGlCtxSubTexture.js +38 -0
  83. package/dist/src/core/renderers/webgl/WebGlCtxSubTexture.js.map +1 -0
  84. package/dist/src/core/renderers/webgl/WebGlCtxTexture.d.ts +57 -0
  85. package/dist/src/core/renderers/webgl/WebGlCtxTexture.js +227 -0
  86. package/dist/src/core/renderers/webgl/WebGlCtxTexture.js.map +1 -0
  87. package/dist/src/core/renderers/webgl/WebGlRenderOp.d.ts +36 -0
  88. package/dist/src/core/renderers/webgl/WebGlRenderOp.js +107 -0
  89. package/dist/src/core/renderers/webgl/WebGlRenderOp.js.map +1 -0
  90. package/dist/src/core/renderers/webgl/WebGlRenderer.d.ts +134 -0
  91. package/dist/src/core/renderers/webgl/WebGlRenderer.js +546 -0
  92. package/dist/src/core/renderers/webgl/WebGlRenderer.js.map +1 -0
  93. package/dist/src/core/renderers/webgl/WebGlShaderNode.d.ts +221 -0
  94. package/dist/src/core/renderers/webgl/WebGlShaderNode.js +334 -0
  95. package/dist/src/core/renderers/webgl/WebGlShaderNode.js.map +1 -0
  96. package/dist/src/core/renderers/webgl/WebGlShaderProgram.d.ts +35 -0
  97. package/dist/src/core/renderers/webgl/WebGlShaderProgram.js +195 -0
  98. package/dist/src/core/renderers/webgl/WebGlShaderProgram.js.map +1 -0
  99. package/dist/src/core/renderers/webgl/internal/ShaderUtils.d.ts +32 -5
  100. package/dist/src/core/renderers/webgl/internal/ShaderUtils.js +50 -0
  101. package/dist/src/core/renderers/webgl/internal/ShaderUtils.js.map +1 -1
  102. package/dist/src/core/shaders/canvas/Border.d.ts +9 -0
  103. package/dist/src/core/shaders/canvas/Border.js +57 -0
  104. package/dist/src/core/shaders/canvas/Border.js.map +1 -0
  105. package/dist/src/core/shaders/canvas/HolePunch.d.ts +7 -0
  106. package/dist/src/core/shaders/canvas/HolePunch.js +38 -0
  107. package/dist/src/core/shaders/canvas/HolePunch.js.map +1 -0
  108. package/dist/src/core/shaders/canvas/LinearGradient.d.ts +10 -0
  109. package/dist/src/core/shaders/canvas/LinearGradient.js +46 -0
  110. package/dist/src/core/shaders/canvas/LinearGradient.js.map +1 -0
  111. package/dist/src/core/shaders/canvas/RadialGradient.d.ts +11 -0
  112. package/dist/src/core/shaders/canvas/RadialGradient.js +68 -0
  113. package/dist/src/core/shaders/canvas/RadialGradient.js.map +1 -0
  114. package/dist/src/core/shaders/canvas/Rounded.d.ts +7 -0
  115. package/dist/src/core/shaders/canvas/Rounded.js +33 -0
  116. package/dist/src/core/shaders/canvas/Rounded.js.map +1 -0
  117. package/dist/src/core/shaders/canvas/RoundedWithBorder.d.ts +7 -0
  118. package/dist/src/core/shaders/canvas/RoundedWithBorder.js +35 -0
  119. package/dist/src/core/shaders/canvas/RoundedWithBorder.js.map +1 -0
  120. package/dist/src/core/shaders/canvas/RoundedWithBorderAndShadow.d.ts +8 -0
  121. package/dist/src/core/shaders/canvas/RoundedWithBorderAndShadow.js +39 -0
  122. package/dist/src/core/shaders/canvas/RoundedWithBorderAndShadow.js.map +1 -0
  123. package/dist/src/core/shaders/canvas/RoundedWithShadow.d.ts +7 -0
  124. package/dist/src/core/shaders/canvas/RoundedWithShadow.js +38 -0
  125. package/dist/src/core/shaders/canvas/RoundedWithShadow.js.map +1 -0
  126. package/dist/src/core/shaders/canvas/Shadow.d.ts +8 -0
  127. package/dist/src/core/shaders/canvas/Shadow.js +31 -0
  128. package/dist/src/core/shaders/canvas/Shadow.js.map +1 -0
  129. package/dist/src/core/shaders/canvas/utils/render.d.ts +5 -0
  130. package/dist/src/core/shaders/canvas/utils/render.js +84 -0
  131. package/dist/src/core/shaders/canvas/utils/render.js.map +1 -0
  132. package/dist/src/core/shaders/templates/BorderTemplate.d.ts +37 -0
  133. package/dist/src/core/shaders/templates/BorderTemplate.js +73 -0
  134. package/dist/src/core/shaders/templates/BorderTemplate.js.map +1 -0
  135. package/dist/src/core/shaders/templates/HolePunchTemplate.d.ts +46 -0
  136. package/dist/src/core/shaders/templates/HolePunchTemplate.js +35 -0
  137. package/dist/src/core/shaders/templates/HolePunchTemplate.js.map +1 -0
  138. package/dist/src/core/shaders/templates/LinearGradientTemplate.d.ts +23 -0
  139. package/dist/src/core/shaders/templates/LinearGradientTemplate.js +47 -0
  140. package/dist/src/core/shaders/templates/LinearGradientTemplate.js.map +1 -0
  141. package/dist/src/core/shaders/templates/RadialGradientTemplate.d.ts +31 -0
  142. package/dist/src/core/shaders/templates/RadialGradientTemplate.js +49 -0
  143. package/dist/src/core/shaders/templates/RadialGradientTemplate.js.map +1 -0
  144. package/dist/src/core/shaders/templates/RoundedTemplate.d.ts +29 -0
  145. package/dist/src/core/shaders/templates/RoundedTemplate.js +67 -0
  146. package/dist/src/core/shaders/templates/RoundedTemplate.js.map +1 -0
  147. package/dist/src/core/shaders/templates/RoundedWithBorderAndShadowTemplate.d.ts +7 -0
  148. package/dist/src/core/shaders/templates/RoundedWithBorderAndShadowTemplate.js +24 -0
  149. package/dist/src/core/shaders/templates/RoundedWithBorderAndShadowTemplate.js.map +1 -0
  150. package/dist/src/core/shaders/templates/RoundedWithBorderTemplate.d.ts +6 -0
  151. package/dist/src/core/shaders/templates/RoundedWithBorderTemplate.js +23 -0
  152. package/dist/src/core/shaders/templates/RoundedWithBorderTemplate.js.map +1 -0
  153. package/dist/src/core/shaders/templates/RoundedWithShadowTemplate.d.ts +6 -0
  154. package/dist/src/core/shaders/templates/RoundedWithShadowTemplate.js +23 -0
  155. package/dist/src/core/shaders/templates/RoundedWithShadowTemplate.js.map +1 -0
  156. package/dist/src/core/shaders/templates/ShadowTemplate.d.ts +34 -0
  157. package/dist/src/core/shaders/templates/ShadowTemplate.js +66 -0
  158. package/dist/src/core/shaders/templates/ShadowTemplate.js.map +1 -0
  159. package/dist/src/core/shaders/templates/shaderUtils.d.ts +5 -0
  160. package/dist/src/core/shaders/templates/shaderUtils.js +41 -0
  161. package/dist/src/core/shaders/templates/shaderUtils.js.map +1 -0
  162. package/dist/src/core/shaders/webgl/Border.d.ts +3 -0
  163. package/dist/src/core/shaders/webgl/Border.js +87 -0
  164. package/dist/src/core/shaders/webgl/Border.js.map +1 -0
  165. package/dist/src/core/shaders/webgl/Default.d.ts +2 -0
  166. package/dist/src/core/shaders/webgl/Default.js +86 -0
  167. package/dist/src/core/shaders/webgl/Default.js.map +1 -0
  168. package/dist/src/core/shaders/webgl/DefaultBatched.d.ts +2 -0
  169. package/dist/src/core/shaders/webgl/DefaultBatched.js +104 -0
  170. package/dist/src/core/shaders/webgl/DefaultBatched.js.map +1 -0
  171. package/dist/src/core/shaders/webgl/HolePunch.d.ts +3 -0
  172. package/dist/src/core/shaders/webgl/HolePunch.js +64 -0
  173. package/dist/src/core/shaders/webgl/HolePunch.js.map +1 -0
  174. package/dist/src/core/shaders/webgl/LinearGradient.d.ts +3 -0
  175. package/dist/src/core/shaders/webgl/LinearGradient.js +75 -0
  176. package/dist/src/core/shaders/webgl/LinearGradient.js.map +1 -0
  177. package/dist/src/core/shaders/webgl/RadialGradient.d.ts +3 -0
  178. package/dist/src/core/shaders/webgl/RadialGradient.js +73 -0
  179. package/dist/src/core/shaders/webgl/RadialGradient.js.map +1 -0
  180. package/dist/src/core/shaders/webgl/Rounded.d.ts +7 -0
  181. package/dist/src/core/shaders/webgl/Rounded.js +86 -0
  182. package/dist/src/core/shaders/webgl/Rounded.js.map +1 -0
  183. package/dist/src/core/shaders/webgl/RoundedWithBorder.d.ts +3 -0
  184. package/dist/src/core/shaders/webgl/RoundedWithBorder.js +97 -0
  185. package/dist/src/core/shaders/webgl/RoundedWithBorder.js.map +1 -0
  186. package/dist/src/core/shaders/webgl/RoundedWithBorderAndShadow.d.ts +3 -0
  187. package/dist/src/core/shaders/webgl/RoundedWithBorderAndShadow.js +112 -0
  188. package/dist/src/core/shaders/webgl/RoundedWithBorderAndShadow.js.map +1 -0
  189. package/dist/src/core/shaders/webgl/RoundedWithShadow.d.ts +3 -0
  190. package/dist/src/core/shaders/webgl/RoundedWithShadow.js +84 -0
  191. package/dist/src/core/shaders/webgl/RoundedWithShadow.js.map +1 -0
  192. package/dist/src/core/shaders/webgl/SdfShader.d.ts +32 -0
  193. package/dist/src/core/shaders/webgl/SdfShader.js +116 -0
  194. package/dist/src/core/shaders/webgl/SdfShader.js.map +1 -0
  195. package/dist/src/core/shaders/webgl/Shadow.d.ts +3 -0
  196. package/dist/src/core/shaders/webgl/Shadow.js +110 -0
  197. package/dist/src/core/shaders/webgl/Shadow.js.map +1 -0
  198. package/dist/src/core/text-rendering/TextTextureRendererUtils.js.map +1 -1
  199. package/dist/src/core/text-rendering/font-face-types/SdfTrFontFace/SdfTrFontFace.js +2 -2
  200. package/dist/src/core/text-rendering/font-face-types/SdfTrFontFace/SdfTrFontFace.js.map +1 -1
  201. package/dist/src/core/text-rendering/renderers/LightningTextTextureRenderer.d.ts +6 -0
  202. package/dist/src/core/text-rendering/renderers/LightningTextTextureRenderer.js.map +1 -1
  203. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.d.ts +2 -3
  204. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.js +34 -30
  205. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.js.map +1 -1
  206. package/dist/src/core/text-rendering/renderers/TextRenderer.d.ts +1 -4
  207. package/dist/src/core/text-rendering/renderers/TextRenderer.js.map +1 -1
  208. package/dist/src/core/textures/ImageTexture.js +10 -16
  209. package/dist/src/core/textures/ImageTexture.js.map +1 -1
  210. package/dist/src/core/textures/Texture.d.ts +1 -1
  211. package/dist/src/main-api/INode.d.ts +9 -9
  212. package/dist/src/main-api/Inspector.js +16 -2
  213. package/dist/src/main-api/Inspector.js.map +1 -1
  214. package/dist/src/main-api/Renderer.d.ts +35 -92
  215. package/dist/src/main-api/Renderer.js +11 -57
  216. package/dist/src/main-api/Renderer.js.map +1 -1
  217. package/dist/src/utils.d.ts +6 -0
  218. package/dist/src/utils.js +18 -0
  219. package/dist/src/utils.js.map +1 -1
  220. package/dist/tsconfig.dist.tsbuildinfo +1 -1
  221. package/exports/canvas-shaders.ts +28 -0
  222. package/exports/canvas.ts +7 -1
  223. package/exports/index.ts +17 -17
  224. package/exports/webgl-shaders.ts +28 -0
  225. package/exports/webgl.ts +13 -1
  226. package/package.json +3 -1
  227. package/src/core/CoreNode.test.ts +157 -153
  228. package/src/core/CoreNode.ts +173 -38
  229. package/src/core/CoreShaderManager.ts +127 -226
  230. package/src/core/CoreTextNode.ts +1 -8
  231. package/src/core/CoreTextureManager.ts +127 -126
  232. package/src/core/Stage.ts +62 -44
  233. package/src/core/TextureMemoryManager.ts +108 -27
  234. package/src/core/animations/CoreAnimation.ts +8 -64
  235. package/src/core/lib/ImageWorker.ts +20 -12
  236. package/src/core/lib/WebGlContextWrapper.ts +228 -236
  237. package/src/core/lib/textureCompression.ts +3 -3
  238. package/src/core/lib/utils.ts +51 -0
  239. package/src/core/lib/validateImageBitmap.ts +76 -0
  240. package/src/core/platform.ts +6 -3
  241. package/src/core/renderers/CoreRenderer.ts +19 -27
  242. package/src/core/renderers/CoreShaderNode.ts +171 -0
  243. package/src/core/renderers/{canvas/shaders/UnsupportedShader.ts → CoreShaderProgram.ts} +3 -28
  244. package/src/core/renderers/canvas/CanvasRenderer.ts +299 -0
  245. package/src/core/renderers/canvas/CanvasShaderNode.ts +99 -0
  246. package/src/core/renderers/canvas/{CanvasCoreTexture.ts → CanvasTexture.ts} +1 -1
  247. package/src/core/renderers/canvas/internal/C2DShaderUtils.ts +2 -13
  248. package/src/core/renderers/canvas/internal/ColorUtils.ts +16 -0
  249. package/src/core/renderers/webgl/{WebGlCoreCtxRenderTexture.ts → WebGlCtxRenderTexture.ts} +2 -2
  250. package/src/core/renderers/webgl/{WebGlCoreCtxSubTexture.ts → WebGlCtxSubTexture.ts} +2 -2
  251. package/src/core/renderers/webgl/{WebGlCoreCtxTexture.ts → WebGlCtxTexture.ts} +12 -14
  252. package/src/core/renderers/webgl/{WebGlCoreRenderOp.ts → WebGlRenderOp.ts} +56 -36
  253. package/src/core/renderers/webgl/{WebGlCoreRenderer.ts → WebGlRenderer.ts} +143 -243
  254. package/src/core/renderers/webgl/WebGlShaderNode.ts +433 -0
  255. package/src/core/renderers/webgl/WebGlShaderProgram.ts +310 -0
  256. package/src/core/renderers/webgl/internal/ShaderUtils.ts +143 -5
  257. package/src/core/shaders/canvas/Border.ts +78 -0
  258. package/src/core/shaders/canvas/HolePunch.ts +62 -0
  259. package/src/core/shaders/canvas/LinearGradient.ts +69 -0
  260. package/src/core/shaders/canvas/RadialGradient.ts +113 -0
  261. package/src/core/shaders/canvas/Rounded.ts +55 -0
  262. package/src/core/shaders/canvas/RoundedWithBorder.ts +68 -0
  263. package/src/core/shaders/canvas/RoundedWithBorderAndShadow.ts +88 -0
  264. package/src/core/shaders/canvas/RoundedWithShadow.ts +69 -0
  265. package/src/core/shaders/canvas/Shadow.ts +52 -0
  266. package/src/core/shaders/canvas/utils/render.ts +151 -0
  267. package/src/core/shaders/templates/BorderTemplate.ts +115 -0
  268. package/src/core/shaders/templates/HolePunchTemplate.ts +82 -0
  269. package/src/core/shaders/templates/LinearGradientTemplate.ts +71 -0
  270. package/src/core/shaders/templates/RadialGradientTemplate.ts +81 -0
  271. package/src/core/shaders/templates/RoundedTemplate.ts +98 -0
  272. package/src/core/shaders/templates/RoundedWithBorderAndShadowTemplate.ts +38 -0
  273. package/src/core/shaders/templates/RoundedWithBorderTemplate.ts +35 -0
  274. package/src/core/shaders/templates/RoundedWithShadowTemplate.ts +35 -0
  275. package/src/core/shaders/templates/ShadowTemplate.ts +106 -0
  276. package/src/core/shaders/templates/shaderUtils.ts +47 -0
  277. package/src/core/shaders/webgl/Border.ts +96 -0
  278. package/src/core/shaders/webgl/Default.ts +89 -0
  279. package/src/core/shaders/webgl/DefaultBatched.ts +129 -0
  280. package/src/core/shaders/webgl/HolePunch.ts +78 -0
  281. package/src/core/shaders/webgl/LinearGradient.ts +81 -0
  282. package/src/core/shaders/webgl/RadialGradient.ts +84 -0
  283. package/src/core/shaders/webgl/Rounded.ts +117 -0
  284. package/src/core/shaders/webgl/RoundedWithBorder.ts +114 -0
  285. package/src/core/shaders/webgl/RoundedWithBorderAndShadow.ts +133 -0
  286. package/src/core/shaders/webgl/RoundedWithShadow.ts +98 -0
  287. package/src/core/shaders/webgl/SdfShader.ts +137 -0
  288. package/src/core/shaders/webgl/Shadow.ts +115 -0
  289. package/src/core/text-rendering/TextTextureRendererUtils.ts +1 -1
  290. package/src/core/text-rendering/font-face-types/SdfTrFontFace/SdfTrFontFace.ts +2 -2
  291. package/src/core/text-rendering/renderers/LightningTextTextureRenderer.ts +12 -5
  292. package/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.ts +44 -56
  293. package/src/core/text-rendering/renderers/TextRenderer.ts +2 -9
  294. package/src/core/textures/ImageTexture.ts +11 -17
  295. package/src/core/textures/Texture.ts +1 -1
  296. package/src/main-api/INode.ts +11 -13
  297. package/src/main-api/Inspector.ts +19 -2
  298. package/src/main-api/Renderer.ts +59 -130
  299. package/src/utils.ts +19 -0
  300. package/src/core/renderers/canvas/CanvasCoreRenderer.ts +0 -375
  301. package/src/core/renderers/webgl/WebGlCoreShader.ts +0 -362
  302. package/src/core/renderers/webgl/shaders/DefaultShader.ts +0 -93
  303. package/src/core/renderers/webgl/shaders/DefaultShaderBatched.ts +0 -132
  304. package/src/core/renderers/webgl/shaders/DynamicShader.ts +0 -580
  305. package/src/core/renderers/webgl/shaders/RoundedRectangle.ts +0 -167
  306. package/src/core/renderers/webgl/shaders/SdfShader.ts +0 -204
  307. package/src/core/renderers/webgl/shaders/effects/BorderBottomEffect.ts +0 -101
  308. package/src/core/renderers/webgl/shaders/effects/BorderEffect.ts +0 -87
  309. package/src/core/renderers/webgl/shaders/effects/BorderLeftEffect.ts +0 -101
  310. package/src/core/renderers/webgl/shaders/effects/BorderRightEffect.ts +0 -101
  311. package/src/core/renderers/webgl/shaders/effects/BorderTopEffect.ts +0 -101
  312. package/src/core/renderers/webgl/shaders/effects/EffectUtils.ts +0 -159
  313. package/src/core/renderers/webgl/shaders/effects/FadeOutEffect.ts +0 -127
  314. package/src/core/renderers/webgl/shaders/effects/GlitchEffect.ts +0 -148
  315. package/src/core/renderers/webgl/shaders/effects/GrayscaleEffect.ts +0 -67
  316. package/src/core/renderers/webgl/shaders/effects/HolePunchEffect.ts +0 -157
  317. package/src/core/renderers/webgl/shaders/effects/LinearGradientEffect.ts +0 -171
  318. package/src/core/renderers/webgl/shaders/effects/RadialGradientEffect.ts +0 -168
  319. package/src/core/renderers/webgl/shaders/effects/RadialProgressEffect.ts +0 -187
  320. package/src/core/renderers/webgl/shaders/effects/RadiusEffect.ts +0 -110
  321. package/src/core/renderers/webgl/shaders/effects/ShaderEffect.ts +0 -196
  322. package/src/main-api/DynamicShaderController.ts +0 -104
  323. package/src/main-api/ShaderController.ts +0 -80
@@ -16,154 +16,68 @@
16
16
  * See the License for the specific language governing permissions and
17
17
  * limitations under the License.
18
18
  */
19
- import type { ExtractProps } from './CoreTextureManager.js';
20
- import type { CoreRenderer } from './renderers/CoreRenderer.js';
21
- import type { CoreShader } from './renderers/CoreShader.js';
22
-
23
- import { DefaultShader } from './renderers/webgl/shaders/DefaultShader.js';
24
- import { DefaultShaderBatched } from './renderers/webgl/shaders/DefaultShaderBatched.js';
19
+ import { deepClone } from '../utils.js';
25
20
  import {
26
- DynamicShader,
27
- type DynamicShaderProps,
28
- } from './renderers/webgl/shaders/DynamicShader.js';
29
- import { RoundedRectangle } from './renderers/webgl/shaders/RoundedRectangle.js';
30
- import { SdfShader } from './renderers/webgl/shaders/SdfShader.js';
31
-
32
- import { RadiusEffect } from './renderers/webgl/shaders/effects/RadiusEffect.js';
33
- import { BorderEffect } from './renderers/webgl/shaders/effects/BorderEffect.js';
34
- import {
35
- LinearGradientEffect,
36
- type LinearGradientEffectProps,
37
- } from './renderers/webgl/shaders/effects/LinearGradientEffect.js';
38
- import {
39
- GrayscaleEffect,
40
- type GrayscaleEffectProps,
41
- } from './renderers/webgl/shaders/effects/GrayscaleEffect.js';
42
- import { BorderRightEffect } from './renderers/webgl/shaders/effects/BorderRightEffect.js';
43
- import { BorderTopEffect } from './renderers/webgl/shaders/effects/BorderTopEffect.js';
44
- import { BorderBottomEffect } from './renderers/webgl/shaders/effects/BorderBottomEffect.js';
45
- import { BorderLeftEffect } from './renderers/webgl/shaders/effects/BorderLeftEffect.js';
46
- import {
47
- GlitchEffect,
48
- type GlitchEffectProps,
49
- } from './renderers/webgl/shaders/effects/GlitchEffect.js';
50
- import {
51
- FadeOutEffect,
52
- type FadeOutEffectProps,
53
- } from './renderers/webgl/shaders/effects/FadeOutEffect.js';
54
- import {
55
- RadialGradientEffect,
56
- type RadialGradientEffectProps,
57
- } from './renderers/webgl/shaders/effects/RadialGradientEffect.js';
58
- import type { WebGlCoreRenderer } from './renderers/webgl/WebGlCoreRenderer.js';
59
- import {
60
- RadialProgressEffect,
61
- type RadialProgressEffectProps,
62
- } from './renderers/webgl/shaders/effects/RadialProgressEffect.js';
63
- import {
64
- HolePunchEffect,
65
- type HolePunchEffectProps,
66
- } from './renderers/webgl/shaders/effects/HolePunchEffect.js';
67
- import { WebGlCoreShader } from './renderers/webgl/WebGlCoreShader.js';
68
- import { UnsupportedShader } from './renderers/canvas/shaders/UnsupportedShader.js';
69
- import { ShaderController } from '../main-api/ShaderController.js';
70
- import {
71
- DynamicShaderController,
72
- type DynamicEffects,
73
- } from '../main-api/DynamicShaderController.js';
74
-
75
- export type { FadeOutEffectProps };
76
- export type { LinearGradientEffectProps };
77
- export type { RadialGradientEffectProps };
78
- export type { GrayscaleEffectProps };
79
- export type { GlitchEffectProps };
80
- export type { RadialProgressEffectProps };
81
- export type { HolePunchEffectProps };
21
+ CoreShaderNode,
22
+ resolveShaderProps,
23
+ type CoreShaderType,
24
+ } from './renderers/CoreShaderNode.js';
25
+ import type { CoreShaderProgram } from './renderers/CoreShaderProgram.js';
26
+ import type { Stage } from './Stage.js';
82
27
 
83
28
  export interface ShaderMap {
84
- DefaultShader: typeof DefaultShader;
85
- DefaultShaderBatched: typeof DefaultShaderBatched;
86
- RoundedRectangle: typeof RoundedRectangle;
87
- DynamicShader: typeof DynamicShader;
88
- SdfShader: typeof SdfShader;
89
- UnsupportedShader: typeof UnsupportedShader;
29
+ [key: string]: CoreShaderType<any>;
90
30
  }
91
31
 
92
- export interface EffectMap {
93
- radius: typeof RadiusEffect;
94
- border: typeof BorderEffect;
95
- borderBottom: typeof BorderBottomEffect;
96
- borderLeft: typeof BorderLeftEffect;
97
- borderRight: typeof BorderRightEffect;
98
- borderTop: typeof BorderTopEffect;
99
- fadeOut: typeof FadeOutEffect;
100
- linearGradient: typeof LinearGradientEffect;
101
- radialGradient: typeof RadialGradientEffect;
102
- grayscale: typeof GrayscaleEffect;
103
- glitch: typeof GlitchEffect;
104
- radialProgress: typeof RadialProgressEffect;
105
- holePunch: typeof HolePunchEffect;
106
- }
32
+ export type ExtractProps<Props> = {
33
+ [K in keyof Props]: Props[K] extends { default: infer D } ? D : Props[K];
34
+ };
107
35
 
108
- export type EffectProps =
109
- | FadeOutEffectProps
110
- | LinearGradientEffectProps
111
- | RadialGradientEffectProps
112
- | GrayscaleEffectProps
113
- | GlitchEffectProps
114
- | RadialProgressEffectProps
115
- | HolePunchEffectProps;
36
+ export type PartialShaderProps<Props> = Partial<ExtractProps<Props>>;
37
+ export type ExtractShaderProps<T extends keyof ShaderMap> = ExtractProps<
38
+ ShaderMap[T]['props']
39
+ >;
40
+ export type OptionalShaderProps<T extends keyof ShaderMap> = PartialShaderProps<
41
+ ShaderMap[T]['props']
42
+ >;
116
43
 
117
44
  export class CoreShaderManager {
118
- protected shCache: Map<string, InstanceType<ShaderMap[keyof ShaderMap]>> =
119
- new Map();
120
- protected shConstructors: Partial<ShaderMap> = {};
121
- protected attachedShader: CoreShader | null = null;
122
- protected effectConstructors: Partial<EffectMap> = {};
123
- renderer!: CoreRenderer;
45
+ protected shTypes: Record<string, CoreShaderType> = {};
46
+ protected shCache: Map<string, CoreShaderProgram> = new Map();
124
47
 
125
- constructor() {
126
- this.registerShaderType('DefaultShader', DefaultShader);
127
- this.registerShaderType('DefaultShaderBatched', DefaultShaderBatched);
128
- this.registerShaderType('RoundedRectangle', RoundedRectangle);
129
- this.registerShaderType('DynamicShader', DynamicShader);
130
- this.registerShaderType('SdfShader', SdfShader);
48
+ /**
49
+ * valuesCache is used to store calculations that can be shared between shader nodes.
50
+ */
51
+ protected valuesCache: Map<string, Record<string, unknown>> = new Map();
52
+ protected valuesCacheUsage: Map<string, number> = new Map();
131
53
 
132
- this.registerEffectType('border', BorderEffect);
133
- this.registerEffectType('borderBottom', BorderBottomEffect);
134
- this.registerEffectType('borderLeft', BorderLeftEffect);
135
- this.registerEffectType('borderRight', BorderRightEffect);
136
- this.registerEffectType('borderTop', BorderTopEffect);
137
- this.registerEffectType('fadeOut', FadeOutEffect);
138
- this.registerEffectType('linearGradient', LinearGradientEffect);
139
- this.registerEffectType('radialGradient', RadialGradientEffect);
140
- this.registerEffectType('grayscale', GrayscaleEffect);
141
- this.registerEffectType('glitch', GlitchEffect);
142
- this.registerEffectType('radius', RadiusEffect);
143
- this.registerEffectType('radialProgress', RadialProgressEffect);
144
- this.registerEffectType('holePunch', HolePunchEffect);
145
- }
54
+ protected attachedShader: CoreShaderProgram | null = null;
146
55
 
147
- registerShaderType<Type extends keyof ShaderMap>(
148
- shType: Type,
149
- shClass: ShaderMap[Type],
150
- ): void {
151
- this.shConstructors[shType] = shClass;
152
- }
56
+ constructor(readonly stage: Stage) {}
153
57
 
154
- registerEffectType<Type extends keyof EffectMap>(
155
- effectType: Type,
156
- effectClass: EffectMap[Type],
58
+ registerShaderType<Name extends keyof ShaderMap>(
59
+ name: Name,
60
+ shType: ShaderMap[Name],
157
61
  ): void {
158
- this.effectConstructors[effectType] = effectClass;
159
- }
160
-
161
- getRegisteredEffects(): Partial<EffectMap> {
162
- return this.effectConstructors;
163
- }
164
-
165
- getRegisteredShaders(): Partial<ShaderMap> {
166
- return this.shConstructors;
62
+ /**
63
+ * block name duplicates
64
+ */
65
+ if (this.shTypes[name as string] !== undefined) {
66
+ console.warn(
67
+ `ShaderType already exists with the name: ${name}. Breaking off registration.`,
68
+ );
69
+ return;
70
+ }
71
+ /**
72
+ * Check renderer if shader type is supported.
73
+ */
74
+ if (this.stage.renderer.supportsShaderType(shType) === false) {
75
+ console.warn(
76
+ `The renderer being used does not support this shader type. Breaking off registration.`,
77
+ );
78
+ return;
79
+ }
80
+ this.shTypes[name as string] = deepClone(shType);
167
81
  }
168
82
 
169
83
  /**
@@ -173,120 +87,107 @@ export class CoreShaderManager {
173
87
  * @param props
174
88
  * @returns
175
89
  */
176
- loadShader<Type extends keyof ShaderMap>(
177
- shType: Type,
178
- props?: ExtractProps<ShaderMap[Type]>,
179
- ): ShaderController<Type> {
180
- if (!this.renderer) {
181
- throw new Error(`Renderer is not been defined`);
182
- }
183
- const ShaderClass = this.shConstructors[shType];
184
- if (!ShaderClass) {
185
- throw new Error(`Shader type "${shType as string}" is not registered`);
186
- }
187
-
188
- if (
189
- this.renderer.mode === 'canvas' &&
190
- ShaderClass.prototype instanceof WebGlCoreShader
191
- ) {
192
- return this._createShaderCtr(
193
- shType,
194
- new UnsupportedShader(shType) as InstanceType<ShaderMap[Type]>,
195
- props as ExtractProps<ShaderMap[Type]>,
90
+ createShader<Name extends keyof ShaderMap>(
91
+ name: Name,
92
+ props?: Record<string, unknown>,
93
+ ): CoreShaderNode | null {
94
+ const shType = this.shTypes[name as string] as ShaderMap[Name];
95
+ if (shType === undefined) {
96
+ console.warn(
97
+ `ShaderType not found falling back on renderer default shader`,
196
98
  );
99
+ return this.stage.defShaderNode;
197
100
  }
198
-
199
- if (shType === 'DynamicShader') {
200
- return this.loadDynamicShader(
201
- props as DynamicShaderProps,
202
- ) as unknown as ShaderController<Type>;
101
+ let shaderKey = name as string;
102
+ if (shType.props !== undefined) {
103
+ /**
104
+ * if props is undefined create empty obj to fill
105
+ */
106
+ props = props || {};
107
+ /**
108
+ * resolve shader values
109
+ */
110
+ resolveShaderProps(props, shType.props);
111
+ if (shType.getCacheMarkers !== undefined) {
112
+ shaderKey += `-${shType.getCacheMarkers(props)}`;
113
+ }
203
114
  }
204
115
 
205
- const resolvedProps = ShaderClass.resolveDefaults(
206
- props as Record<string, unknown>,
207
- );
208
- const cacheKey =
209
- ShaderClass.makeCacheKey(resolvedProps) || ShaderClass.name;
210
- if (cacheKey && this.shCache.has(cacheKey)) {
211
- return this._createShaderCtr(
212
- shType,
213
- this.shCache.get(cacheKey) as InstanceType<ShaderMap[Type]>,
214
- resolvedProps as ExtractProps<ShaderMap[Type]>,
215
- );
116
+ if (this.stage.renderer.mode === 'canvas') {
117
+ return this.stage.renderer.createShaderNode(shaderKey, shType, props);
216
118
  }
217
119
 
218
- // @ts-expect-error ShaderClass WILL accept a Renderer
219
- const shader = new ShaderClass(this.renderer, props) as InstanceType<
220
- ShaderMap[Type]
221
- >;
222
- if (cacheKey) {
223
- this.shCache.set(cacheKey, shader);
120
+ /**
121
+ * get shaderProgram by cacheKey
122
+ */
123
+ let shProgram = this.shCache.get(shaderKey);
124
+
125
+ /**
126
+ * if shaderProgram was not found create a new one
127
+ */
128
+ if (shProgram === undefined) {
129
+ shProgram = this.stage.renderer.createShaderProgram(shType, props)!;
130
+ this.shCache.set(shaderKey, shProgram);
224
131
  }
225
- return this._createShaderCtr(
132
+
133
+ return this.stage.renderer.createShaderNode(
134
+ shaderKey,
226
135
  shType,
227
- shader,
228
- resolvedProps as ExtractProps<ShaderMap[Type]>,
136
+ props,
137
+ shProgram,
229
138
  );
230
139
  }
231
140
 
232
- loadDynamicShader<
233
- T extends DynamicEffects<[...{ name?: string; type: keyof EffectMap }[]]>,
234
- >(props: DynamicShaderProps): DynamicShaderController<T> {
235
- if (!this.renderer) {
236
- throw new Error(`Renderer is not been defined`);
237
- }
238
- const resolvedProps = DynamicShader.resolveDefaults(
239
- props as Record<string, unknown>,
240
- this.effectConstructors,
241
- );
242
- const cacheKey = DynamicShader.makeCacheKey(
243
- resolvedProps,
244
- this.effectConstructors,
245
- );
246
- if (cacheKey && this.shCache.has(cacheKey)) {
247
- return this._createDynShaderCtr(
248
- this.shCache.get(cacheKey) as InstanceType<ShaderMap['DynamicShader']>,
249
- resolvedProps,
250
- );
251
- }
252
- const shader = new DynamicShader(
253
- this.renderer as WebGlCoreRenderer,
254
- props,
255
- this.effectConstructors,
256
- );
257
- if (cacheKey) {
258
- this.shCache.set(cacheKey, shader);
259
- }
141
+ mutateShaderValueUsage(key: string, mutation: number) {
142
+ let usage = this.valuesCacheUsage.get(key) || 0;
143
+ this.valuesCacheUsage.set(key, usage + mutation);
144
+ }
260
145
 
261
- return this._createDynShaderCtr(shader, resolvedProps);
146
+ getShaderValues(key: string) {
147
+ const values = this.valuesCache.get(key);
148
+ if (values === undefined) {
149
+ return undefined;
150
+ }
151
+ this.mutateShaderValueUsage(key, 1);
152
+ return values;
262
153
  }
263
154
 
264
- private _createShaderCtr<Type extends keyof ShaderMap>(
265
- type: Type,
266
- shader: InstanceType<ShaderMap[Type]>,
267
- props: ExtractProps<ShaderMap[Type]>,
268
- ): ShaderController<Type> {
269
- return new ShaderController(type, shader, props, this.renderer.stage);
155
+ setShaderValues(key: string, values: Record<string, unknown>) {
156
+ this.valuesCache.set(key, values);
157
+ this.mutateShaderValueUsage(key, 1);
270
158
  }
271
159
 
272
- private _createDynShaderCtr<
273
- T extends DynamicEffects<[...{ name?: string; type: keyof EffectMap }[]]>,
274
- >(
275
- shader: InstanceType<ShaderMap['DynamicShader']>,
276
- props: ExtractProps<ShaderMap['DynamicShader']>,
277
- ): DynamicShaderController<T> {
278
- shader.bindUniformMethods(props);
279
- return new DynamicShaderController(shader, props, this);
160
+ cleanup() {
161
+ const values = [...this.valuesCacheUsage.entries()].sort(
162
+ (entryA, entryB) => {
163
+ if (entryA[1] < entryB[1]) {
164
+ return -1;
165
+ } else if (entryA[1] > entryB[1]) {
166
+ return 1;
167
+ }
168
+ return 0;
169
+ },
170
+ );
171
+
172
+ for (let i = 0; i < values.length; i++) {
173
+ if (values[i]![1] > 0) {
174
+ break;
175
+ }
176
+ this.valuesCacheUsage.delete(values[i]![0]);
177
+ this.valuesCache.delete(values[i]![0]);
178
+ }
280
179
  }
281
180
 
282
- useShader(shader: CoreShader): void {
181
+ useShader(shader: CoreShaderProgram): void {
283
182
  if (this.attachedShader === shader) {
284
183
  return;
285
184
  }
286
- if (this.attachedShader) {
185
+ if (this.attachedShader && this.attachedShader.detach) {
287
186
  this.attachedShader.detach();
288
187
  }
289
- shader.attach();
188
+ if (shader.attach) {
189
+ shader.attach();
190
+ }
290
191
  this.attachedShader = shader;
291
192
  }
292
193
  }
@@ -418,14 +418,7 @@ export class CoreTextNode extends CoreNode implements CoreTextNodeProps {
418
418
 
419
419
  assertTruthy(this.globalTransform);
420
420
 
421
- this.textRenderer.renderQuads(
422
- this.trState,
423
- this.globalTransform,
424
- this.clippingRect,
425
- this.worldAlpha,
426
- this.parentHasRenderTexture,
427
- this.framebufferDimensions,
428
- );
421
+ this.textRenderer.renderQuads(this);
429
422
  }
430
423
 
431
424
  /**