@lightningjs/renderer 2.14.0 → 2.14.2

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 (292) hide show
  1. package/COPYING +1 -0
  2. package/LICENSE +202 -202
  3. package/NOTICE +3 -3
  4. package/README.md +147 -147
  5. package/dist/exports/canvas-shaders.d.ts +10 -0
  6. package/dist/exports/canvas-shaders.js +27 -0
  7. package/dist/exports/canvas-shaders.js.map +1 -0
  8. package/dist/exports/webgl-shaders.d.ts +11 -0
  9. package/dist/exports/webgl-shaders.js +28 -0
  10. package/dist/exports/webgl-shaders.js.map +1 -0
  11. package/dist/src/core/CoreNode.js +6 -0
  12. package/dist/src/core/CoreNode.js.map +1 -1
  13. package/dist/src/core/animations/CoreAnimationController.js +4 -3
  14. package/dist/src/core/animations/CoreAnimationController.js.map +1 -1
  15. package/dist/src/core/platforms/Platform.d.ts +37 -0
  16. package/dist/src/core/platforms/Platform.js +22 -0
  17. package/dist/src/core/platforms/Platform.js.map +1 -0
  18. package/dist/src/core/platforms/web/WebPlatform.d.ts +9 -0
  19. package/dist/src/core/platforms/web/WebPlatform.js +58 -0
  20. package/dist/src/core/platforms/web/WebPlatform.js.map +1 -0
  21. package/dist/src/core/renderers/CoreShaderNode.d.ts +58 -0
  22. package/dist/src/core/renderers/CoreShaderNode.js +104 -0
  23. package/dist/src/core/renderers/CoreShaderNode.js.map +1 -0
  24. package/dist/src/core/renderers/CoreShaderProgram.d.ts +4 -0
  25. package/dist/src/core/renderers/CoreShaderProgram.js +20 -0
  26. package/dist/src/core/renderers/CoreShaderProgram.js.map +1 -0
  27. package/dist/src/core/renderers/canvas/CanvasRenderer.d.ts +36 -0
  28. package/dist/src/core/renderers/canvas/CanvasRenderer.js +212 -0
  29. package/dist/src/core/renderers/canvas/CanvasRenderer.js.map +1 -0
  30. package/dist/src/core/renderers/canvas/CanvasShaderNode.d.ts +21 -0
  31. package/dist/src/core/renderers/canvas/CanvasShaderNode.js +60 -0
  32. package/dist/src/core/renderers/canvas/CanvasShaderNode.js.map +1 -0
  33. package/dist/src/core/renderers/canvas/CanvasTexture.d.ts +16 -0
  34. package/dist/src/core/renderers/canvas/CanvasTexture.js +124 -0
  35. package/dist/src/core/renderers/canvas/CanvasTexture.js.map +1 -0
  36. package/dist/src/core/renderers/webgl/WebGlCoreRenderer.js +5 -2
  37. package/dist/src/core/renderers/webgl/WebGlCoreRenderer.js.map +1 -1
  38. package/dist/src/core/renderers/webgl/WebGlCoreShader.js +3 -1
  39. package/dist/src/core/renderers/webgl/WebGlCoreShader.js.map +1 -1
  40. package/dist/src/core/renderers/webgl/WebGlCtxRenderTexture.d.ts +12 -0
  41. package/dist/src/core/renderers/webgl/WebGlCtxRenderTexture.js +55 -0
  42. package/dist/src/core/renderers/webgl/WebGlCtxRenderTexture.js.map +1 -0
  43. package/dist/src/core/renderers/webgl/WebGlCtxSubTexture.d.ts +9 -0
  44. package/dist/src/core/renderers/webgl/WebGlCtxSubTexture.js +38 -0
  45. package/dist/src/core/renderers/webgl/WebGlCtxSubTexture.js.map +1 -0
  46. package/dist/src/core/renderers/webgl/WebGlCtxTexture.d.ts +57 -0
  47. package/dist/src/core/renderers/webgl/WebGlCtxTexture.js +227 -0
  48. package/dist/src/core/renderers/webgl/WebGlCtxTexture.js.map +1 -0
  49. package/dist/src/core/renderers/webgl/WebGlRenderOp.d.ts +44 -0
  50. package/dist/src/core/renderers/webgl/WebGlRenderOp.js +118 -0
  51. package/dist/src/core/renderers/webgl/WebGlRenderOp.js.map +1 -0
  52. package/dist/src/core/renderers/webgl/WebGlRenderer.d.ts +135 -0
  53. package/dist/src/core/renderers/webgl/WebGlRenderer.js +571 -0
  54. package/dist/src/core/renderers/webgl/WebGlRenderer.js.map +1 -0
  55. package/dist/src/core/renderers/webgl/WebGlShaderNode.d.ts +222 -0
  56. package/dist/src/core/renderers/webgl/WebGlShaderNode.js +334 -0
  57. package/dist/src/core/renderers/webgl/WebGlShaderNode.js.map +1 -0
  58. package/dist/src/core/renderers/webgl/WebGlShaderProgram.d.ts +35 -0
  59. package/dist/src/core/renderers/webgl/WebGlShaderProgram.js +201 -0
  60. package/dist/src/core/renderers/webgl/WebGlShaderProgram.js.map +1 -0
  61. package/dist/src/core/renderers/webgl/shaders/DefaultShader.js +45 -45
  62. package/dist/src/core/renderers/webgl/shaders/DefaultShaderBatched.js +61 -61
  63. package/dist/src/core/renderers/webgl/shaders/DynamicShader.js +93 -93
  64. package/dist/src/core/renderers/webgl/shaders/RoundedRectangle.js +63 -63
  65. package/dist/src/core/renderers/webgl/shaders/SdfShader.js +62 -62
  66. package/dist/src/core/renderers/webgl/shaders/effects/BorderBottomEffect.js +15 -15
  67. package/dist/src/core/renderers/webgl/shaders/effects/BorderEffect.js +6 -6
  68. package/dist/src/core/renderers/webgl/shaders/effects/BorderLeftEffect.js +15 -15
  69. package/dist/src/core/renderers/webgl/shaders/effects/BorderRightEffect.js +15 -15
  70. package/dist/src/core/renderers/webgl/shaders/effects/BorderTopEffect.js +15 -15
  71. package/dist/src/core/renderers/webgl/shaders/effects/FadeOutEffect.js +42 -42
  72. package/dist/src/core/renderers/webgl/shaders/effects/GlitchEffect.js +44 -44
  73. package/dist/src/core/renderers/webgl/shaders/effects/GrayscaleEffect.js +3 -3
  74. package/dist/src/core/renderers/webgl/shaders/effects/HolePunchEffect.js +22 -22
  75. package/dist/src/core/renderers/webgl/shaders/effects/LinearGradientEffect.js +28 -28
  76. package/dist/src/core/renderers/webgl/shaders/effects/RadialGradientEffect.js +10 -10
  77. package/dist/src/core/renderers/webgl/shaders/effects/RadialProgressEffect.js +37 -37
  78. package/dist/src/core/renderers/webgl/shaders/effects/RadiusEffect.js +19 -19
  79. package/dist/src/core/shaders/canvas/Border.d.ts +9 -0
  80. package/dist/src/core/shaders/canvas/Border.js +57 -0
  81. package/dist/src/core/shaders/canvas/Border.js.map +1 -0
  82. package/dist/src/core/shaders/canvas/HolePunch.d.ts +7 -0
  83. package/dist/src/core/shaders/canvas/HolePunch.js +38 -0
  84. package/dist/src/core/shaders/canvas/HolePunch.js.map +1 -0
  85. package/dist/src/core/shaders/canvas/LinearGradient.d.ts +10 -0
  86. package/dist/src/core/shaders/canvas/LinearGradient.js +46 -0
  87. package/dist/src/core/shaders/canvas/LinearGradient.js.map +1 -0
  88. package/dist/src/core/shaders/canvas/RadialGradient.d.ts +11 -0
  89. package/dist/src/core/shaders/canvas/RadialGradient.js +68 -0
  90. package/dist/src/core/shaders/canvas/RadialGradient.js.map +1 -0
  91. package/dist/src/core/shaders/canvas/Rounded.d.ts +7 -0
  92. package/dist/src/core/shaders/canvas/Rounded.js +33 -0
  93. package/dist/src/core/shaders/canvas/Rounded.js.map +1 -0
  94. package/dist/src/core/shaders/canvas/RoundedWithBorder.d.ts +7 -0
  95. package/dist/src/core/shaders/canvas/RoundedWithBorder.js +41 -0
  96. package/dist/src/core/shaders/canvas/RoundedWithBorder.js.map +1 -0
  97. package/dist/src/core/shaders/canvas/RoundedWithBorderAndShadow.d.ts +8 -0
  98. package/dist/src/core/shaders/canvas/RoundedWithBorderAndShadow.js +39 -0
  99. package/dist/src/core/shaders/canvas/RoundedWithBorderAndShadow.js.map +1 -0
  100. package/dist/src/core/shaders/canvas/RoundedWithShadow.d.ts +7 -0
  101. package/dist/src/core/shaders/canvas/RoundedWithShadow.js +38 -0
  102. package/dist/src/core/shaders/canvas/RoundedWithShadow.js.map +1 -0
  103. package/dist/src/core/shaders/canvas/Shadow.d.ts +8 -0
  104. package/dist/src/core/shaders/canvas/Shadow.js +31 -0
  105. package/dist/src/core/shaders/canvas/Shadow.js.map +1 -0
  106. package/dist/src/core/shaders/canvas/utils/render.d.ts +5 -0
  107. package/dist/src/core/shaders/canvas/utils/render.js +84 -0
  108. package/dist/src/core/shaders/canvas/utils/render.js.map +1 -0
  109. package/dist/src/core/shaders/templates/BorderTemplate.d.ts +37 -0
  110. package/dist/src/core/shaders/templates/BorderTemplate.js +73 -0
  111. package/dist/src/core/shaders/templates/BorderTemplate.js.map +1 -0
  112. package/dist/src/core/shaders/templates/HolePunchTemplate.d.ts +46 -0
  113. package/dist/src/core/shaders/templates/HolePunchTemplate.js +35 -0
  114. package/dist/src/core/shaders/templates/HolePunchTemplate.js.map +1 -0
  115. package/dist/src/core/shaders/templates/LinearGradientTemplate.d.ts +23 -0
  116. package/dist/src/core/shaders/templates/LinearGradientTemplate.js +47 -0
  117. package/dist/src/core/shaders/templates/LinearGradientTemplate.js.map +1 -0
  118. package/dist/src/core/shaders/templates/RadialGradientTemplate.d.ts +31 -0
  119. package/dist/src/core/shaders/templates/RadialGradientTemplate.js +49 -0
  120. package/dist/src/core/shaders/templates/RadialGradientTemplate.js.map +1 -0
  121. package/dist/src/core/shaders/templates/RoundedTemplate.d.ts +29 -0
  122. package/dist/src/core/shaders/templates/RoundedTemplate.js +67 -0
  123. package/dist/src/core/shaders/templates/RoundedTemplate.js.map +1 -0
  124. package/dist/src/core/shaders/templates/RoundedWithBorderAndShadowTemplate.d.ts +7 -0
  125. package/dist/src/core/shaders/templates/RoundedWithBorderAndShadowTemplate.js +24 -0
  126. package/dist/src/core/shaders/templates/RoundedWithBorderAndShadowTemplate.js.map +1 -0
  127. package/dist/src/core/shaders/templates/RoundedWithBorderTemplate.d.ts +6 -0
  128. package/dist/src/core/shaders/templates/RoundedWithBorderTemplate.js +23 -0
  129. package/dist/src/core/shaders/templates/RoundedWithBorderTemplate.js.map +1 -0
  130. package/dist/src/core/shaders/templates/RoundedWithShadowTemplate.d.ts +6 -0
  131. package/dist/src/core/shaders/templates/RoundedWithShadowTemplate.js +23 -0
  132. package/dist/src/core/shaders/templates/RoundedWithShadowTemplate.js.map +1 -0
  133. package/dist/src/core/shaders/templates/ShadowTemplate.d.ts +34 -0
  134. package/dist/src/core/shaders/templates/ShadowTemplate.js +66 -0
  135. package/dist/src/core/shaders/templates/ShadowTemplate.js.map +1 -0
  136. package/dist/src/core/shaders/templates/shaderUtils.d.ts +5 -0
  137. package/dist/src/core/shaders/templates/shaderUtils.js +41 -0
  138. package/dist/src/core/shaders/templates/shaderUtils.js.map +1 -0
  139. package/dist/src/core/shaders/webgl/Border.d.ts +3 -0
  140. package/dist/src/core/shaders/webgl/Border.js +110 -0
  141. package/dist/src/core/shaders/webgl/Border.js.map +1 -0
  142. package/dist/src/core/shaders/webgl/Default.d.ts +2 -0
  143. package/dist/src/core/shaders/webgl/Default.js +86 -0
  144. package/dist/src/core/shaders/webgl/Default.js.map +1 -0
  145. package/dist/src/core/shaders/webgl/DefaultBatched.d.ts +2 -0
  146. package/dist/src/core/shaders/webgl/DefaultBatched.js +104 -0
  147. package/dist/src/core/shaders/webgl/DefaultBatched.js.map +1 -0
  148. package/dist/src/core/shaders/webgl/HolePunch.d.ts +3 -0
  149. package/dist/src/core/shaders/webgl/HolePunch.js +64 -0
  150. package/dist/src/core/shaders/webgl/HolePunch.js.map +1 -0
  151. package/dist/src/core/shaders/webgl/LinearGradient.d.ts +3 -0
  152. package/dist/src/core/shaders/webgl/LinearGradient.js +75 -0
  153. package/dist/src/core/shaders/webgl/LinearGradient.js.map +1 -0
  154. package/dist/src/core/shaders/webgl/RadialGradient.d.ts +3 -0
  155. package/dist/src/core/shaders/webgl/RadialGradient.js +73 -0
  156. package/dist/src/core/shaders/webgl/RadialGradient.js.map +1 -0
  157. package/dist/src/core/shaders/webgl/Rounded.d.ts +7 -0
  158. package/dist/src/core/shaders/webgl/Rounded.js +86 -0
  159. package/dist/src/core/shaders/webgl/Rounded.js.map +1 -0
  160. package/dist/src/core/shaders/webgl/RoundedWithBorder.d.ts +3 -0
  161. package/dist/src/core/shaders/webgl/RoundedWithBorder.js +129 -0
  162. package/dist/src/core/shaders/webgl/RoundedWithBorder.js.map +1 -0
  163. package/dist/src/core/shaders/webgl/RoundedWithBorderAndShadow.d.ts +3 -0
  164. package/dist/src/core/shaders/webgl/RoundedWithBorderAndShadow.js +149 -0
  165. package/dist/src/core/shaders/webgl/RoundedWithBorderAndShadow.js.map +1 -0
  166. package/dist/src/core/shaders/webgl/RoundedWithShadow.d.ts +3 -0
  167. package/dist/src/core/shaders/webgl/RoundedWithShadow.js +84 -0
  168. package/dist/src/core/shaders/webgl/RoundedWithShadow.js.map +1 -0
  169. package/dist/src/core/shaders/webgl/SdfShader.d.ts +32 -0
  170. package/dist/src/core/shaders/webgl/SdfShader.js +116 -0
  171. package/dist/src/core/shaders/webgl/SdfShader.js.map +1 -0
  172. package/dist/src/core/shaders/webgl/Shadow.d.ts +3 -0
  173. package/dist/src/core/shaders/webgl/Shadow.js +110 -0
  174. package/dist/src/core/shaders/webgl/Shadow.js.map +1 -0
  175. package/dist/src/core/temp.js +77 -0
  176. package/dist/src/core/temp.js.map +1 -0
  177. package/dist/tsconfig.dist.tsbuildinfo +1 -1
  178. package/exports/canvas.ts +39 -39
  179. package/exports/index.ts +89 -89
  180. package/exports/inspector.ts +24 -24
  181. package/exports/utils.ts +44 -44
  182. package/exports/webgl.ts +38 -38
  183. package/package.json +1 -1
  184. package/scripts/please-use-pnpm.js +13 -13
  185. package/src/common/CommonTypes.ts +146 -146
  186. package/src/common/EventEmitter.ts +77 -77
  187. package/src/common/IAnimationController.ts +92 -92
  188. package/src/common/IEventEmitter.ts +28 -28
  189. package/src/core/CoreNode.test.ts +202 -202
  190. package/src/core/CoreNode.ts +2468 -2462
  191. package/src/core/CoreShaderManager.ts +292 -292
  192. package/src/core/CoreTextNode.ts +455 -455
  193. package/src/core/CoreTextureManager.ts +558 -558
  194. package/src/core/Stage.ts +743 -743
  195. package/src/core/TextureMemoryManager.ts +404 -404
  196. package/src/core/animations/AnimationManager.ts +38 -38
  197. package/src/core/animations/CoreAnimation.ts +347 -347
  198. package/src/core/animations/CoreAnimationController.ts +166 -164
  199. package/src/core/lib/ContextSpy.ts +41 -41
  200. package/src/core/lib/ImageWorker.ts +280 -280
  201. package/src/core/lib/Matrix3d.ts +244 -244
  202. package/src/core/lib/RenderCoords.ts +86 -86
  203. package/src/core/lib/WebGlContextWrapper.ts +1332 -1332
  204. package/src/core/lib/textureCompression.ts +152 -152
  205. package/src/core/lib/textureSvg.ts +78 -78
  206. package/src/core/lib/utils.ts +384 -384
  207. package/src/core/lib/validateImageBitmap.ts +76 -76
  208. package/src/core/platform.ts +63 -63
  209. package/src/core/renderers/CoreContextTexture.ts +43 -43
  210. package/src/core/renderers/CoreRenderOp.ts +22 -22
  211. package/src/core/renderers/CoreRenderer.ts +115 -115
  212. package/src/core/renderers/CoreShader.ts +41 -41
  213. package/src/core/renderers/canvas/CanvasCoreRenderer.ts +375 -375
  214. package/src/core/renderers/canvas/CanvasCoreTexture.ts +153 -153
  215. package/src/core/renderers/canvas/internal/C2DShaderUtils.ts +231 -231
  216. package/src/core/renderers/canvas/internal/ColorUtils.ts +69 -69
  217. package/src/core/renderers/canvas/shaders/UnsupportedShader.ts +48 -48
  218. package/src/core/renderers/webgl/WebGlCoreCtxRenderTexture.ts +86 -86
  219. package/src/core/renderers/webgl/WebGlCoreCtxSubTexture.ts +50 -50
  220. package/src/core/renderers/webgl/WebGlCoreCtxTexture.ts +301 -301
  221. package/src/core/renderers/webgl/WebGlCoreRenderOp.ts +125 -125
  222. package/src/core/renderers/webgl/WebGlCoreRenderer.ts +821 -815
  223. package/src/core/renderers/webgl/WebGlCoreShader.ts +365 -362
  224. package/src/core/renderers/webgl/internal/BufferCollection.ts +54 -54
  225. package/src/core/renderers/webgl/internal/RendererUtils.ts +155 -155
  226. package/src/core/renderers/webgl/internal/ShaderUtils.ts +143 -143
  227. package/src/core/renderers/webgl/internal/WebGlUtils.ts +35 -35
  228. package/src/core/renderers/webgl/shaders/DefaultShader.ts +93 -93
  229. package/src/core/renderers/webgl/shaders/DefaultShaderBatched.ts +132 -132
  230. package/src/core/renderers/webgl/shaders/DynamicShader.ts +580 -580
  231. package/src/core/renderers/webgl/shaders/RoundedRectangle.ts +167 -167
  232. package/src/core/renderers/webgl/shaders/SdfShader.ts +204 -204
  233. package/src/core/renderers/webgl/shaders/effects/BorderBottomEffect.ts +101 -101
  234. package/src/core/renderers/webgl/shaders/effects/BorderEffect.ts +87 -87
  235. package/src/core/renderers/webgl/shaders/effects/BorderLeftEffect.ts +101 -101
  236. package/src/core/renderers/webgl/shaders/effects/BorderRightEffect.ts +101 -101
  237. package/src/core/renderers/webgl/shaders/effects/BorderTopEffect.ts +101 -101
  238. package/src/core/renderers/webgl/shaders/effects/EffectUtils.ts +159 -159
  239. package/src/core/renderers/webgl/shaders/effects/FadeOutEffect.ts +127 -127
  240. package/src/core/renderers/webgl/shaders/effects/GlitchEffect.ts +148 -148
  241. package/src/core/renderers/webgl/shaders/effects/GrayscaleEffect.ts +67 -67
  242. package/src/core/renderers/webgl/shaders/effects/HolePunchEffect.ts +157 -157
  243. package/src/core/renderers/webgl/shaders/effects/LinearGradientEffect.ts +171 -171
  244. package/src/core/renderers/webgl/shaders/effects/RadialGradientEffect.ts +168 -168
  245. package/src/core/renderers/webgl/shaders/effects/RadialProgressEffect.ts +187 -187
  246. package/src/core/renderers/webgl/shaders/effects/RadiusEffect.ts +110 -110
  247. package/src/core/renderers/webgl/shaders/effects/ShaderEffect.ts +196 -196
  248. package/src/core/text-rendering/TextRenderingUtils.ts +36 -36
  249. package/src/core/text-rendering/TextTextureRendererUtils.ts +263 -263
  250. package/src/core/text-rendering/TrFontManager.ts +183 -183
  251. package/src/core/text-rendering/font-face-types/SdfTrFontFace/SdfTrFontFace.ts +176 -176
  252. package/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/FontShaper.ts +139 -139
  253. package/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/SdfFontShaper.test.ts +173 -173
  254. package/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/SdfFontShaper.ts +171 -171
  255. package/src/core/text-rendering/font-face-types/TrFontFace.ts +187 -187
  256. package/src/core/text-rendering/font-face-types/WebTrFontFace.ts +94 -94
  257. package/src/core/text-rendering/font-face-types/utils.ts +39 -39
  258. package/src/core/text-rendering/renderers/CanvasTextRenderer.ts +509 -509
  259. package/src/core/text-rendering/renderers/LightningTextTextureRenderer.ts +808 -808
  260. package/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.ts +853 -853
  261. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/PeekableGenerator.test.ts +48 -48
  262. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/PeekableGenerator.ts +66 -66
  263. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/SpecialCodepoints.ts +52 -52
  264. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/constants.ts +32 -32
  265. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/getStartConditions.ts +117 -117
  266. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/getUnicodeCodepoints.test.ts +133 -133
  267. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/getUnicodeCodepoints.ts +38 -38
  268. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText.ts +408 -408
  269. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/measureText.test.ts +49 -49
  270. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/measureText.ts +52 -52
  271. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/setRenderWindow.test.ts +205 -205
  272. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/setRenderWindow.ts +93 -93
  273. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/util.ts +40 -40
  274. package/src/core/text-rendering/renderers/TextRenderer.ts +557 -557
  275. package/src/core/textures/ColorTexture.ts +102 -102
  276. package/src/core/textures/ImageTexture.ts +399 -399
  277. package/src/core/textures/NoiseTexture.ts +104 -104
  278. package/src/core/textures/RenderTexture.ts +85 -85
  279. package/src/core/textures/SubTexture.ts +205 -205
  280. package/src/core/textures/Texture.ts +367 -367
  281. package/src/core/utils.ts +227 -227
  282. package/src/env.d.ts +7 -7
  283. package/src/main-api/DynamicShaderController.ts +104 -104
  284. package/src/main-api/INode.ts +101 -101
  285. package/src/main-api/Inspector.ts +522 -522
  286. package/src/main-api/Renderer.ts +751 -751
  287. package/src/main-api/ShaderController.ts +80 -80
  288. package/src/main-api/utils.ts +45 -45
  289. package/src/utils.ts +248 -248
  290. package/dist/src/core/renderers/webgl/WebGlCoreShader.destroy.js +0 -2
  291. package/dist/src/core/renderers/webgl/WebGlCoreShader.destroy.js.map +0 -1
  292. /package/dist/src/core/{renderers/webgl/WebGlCoreShader.destroy.d.ts → temp.d.ts} +0 -0
@@ -0,0 +1,149 @@
1
+ /*
2
+ * Copyright 2023 Comcast Cable Communications Management, LLC
3
+ * Licensed under the Apache License, Version 2.0 (the "License");
4
+ * you may not use this file except in compliance with the License.
5
+ * You may obtain a copy of the License at
6
+ *
7
+ * http://www.apache.org/licenses/LICENSE-2.0
8
+ *
9
+ * Unless required by applicable law or agreed to in writing, software
10
+ * distributed under the License is distributed on an "AS IS" BASIS,
11
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
+ * See the License for the specific language governing permissions and
13
+ * limitations under the License.
14
+ *
15
+ * SPDX-License-Identifier: Apache-2.0
16
+ */
17
+ import { calcFactoredRadiusArray } from '../../lib/utils.js';
18
+ import { RoundedWithBorderAndShadowTemplate, } from '../templates/RoundedWithBorderAndShadowTemplate.js';
19
+ export const RoundedWithBorderAndShadow = {
20
+ props: RoundedWithBorderAndShadowTemplate.props,
21
+ update(node) {
22
+ this.uniformRGBA('u_borderColor', this.props['border-color']);
23
+ this.uniform4fa('u_borderWidth', this.props['border-width']);
24
+ this.uniformRGBA('u_shadowColor', this.props['shadow-color']);
25
+ this.uniform4fa('u_shadow', this.props['shadow-projection']);
26
+ this.uniform4fa('u_radius', calcFactoredRadiusArray(this.props.radius, node.width, node.height));
27
+ },
28
+ vertex: `
29
+ # ifdef GL_FRAGMENT_PRECISION_HIGH
30
+ precision highp float;
31
+ # else
32
+ precision mediump float;
33
+ # endif
34
+
35
+ attribute vec2 a_position;
36
+ attribute vec2 a_textureCoords;
37
+ attribute vec4 a_color;
38
+ attribute vec2 a_nodeCoords;
39
+
40
+ uniform vec2 u_resolution;
41
+ uniform float u_pixelRatio;
42
+ uniform float u_rtt;
43
+ uniform vec2 u_dimensions;
44
+
45
+ uniform vec4 u_shadow;
46
+ uniform vec4 u_radius;
47
+ uniform vec4 u_borderWidth;
48
+
49
+ varying vec4 v_color;
50
+ varying vec2 v_textureCoords;
51
+ varying vec2 v_nodeCoords;
52
+
53
+ varying vec4 v_innerRadius;
54
+ varying vec2 v_innerSize;
55
+ varying vec2 v_halfDimensions;
56
+
57
+ void main() {
58
+ vec2 screenSpace = vec2(2.0 / u_resolution.x, -2.0 / u_resolution.y);
59
+ vec2 outerEdge = clamp(a_nodeCoords * 2.0 - vec2(1.0), -1.0, 1.0);
60
+
61
+ vec2 shadowEdge = outerEdge * ((u_shadow.w * 2.0)+ u_shadow.z) + u_shadow.xy;
62
+ vec2 normVertexPos = a_position * u_pixelRatio;
63
+
64
+ vec2 vertexPos = (a_position + outerEdge + shadowEdge) * u_pixelRatio;
65
+ gl_Position = vec4(vertexPos.x * screenSpace.x - 1.0, -sign(screenSpace.y) * (vertexPos.y * -abs(screenSpace.y)) + 1.0, 0.0, 1.0);
66
+
67
+ v_halfDimensions = u_dimensions * 0.5;
68
+
69
+ v_innerRadius = vec4(
70
+ max(0.0, u_radius.x - max(u_borderWidth.x, u_borderWidth.w) - 0.5),
71
+ max(0.0, u_radius.y - max(u_borderWidth.x, u_borderWidth.y) - 0.5),
72
+ max(0.0, u_radius.z - max(u_borderWidth.z, u_borderWidth.y) - 0.5),
73
+ max(0.0, u_radius.w - max(u_borderWidth.z, u_borderWidth.w) - 0.5)
74
+ );
75
+
76
+ v_innerSize = (vec2(u_dimensions.x - (u_borderWidth[3] + u_borderWidth[1]) - 1.0, u_dimensions.y - (u_borderWidth[0] + u_borderWidth[2])) - 2.0) * 0.5;
77
+
78
+ v_color = a_color;
79
+ v_nodeCoords = a_nodeCoords + (screenSpace + shadowEdge) / (u_dimensions);
80
+ v_textureCoords = a_textureCoords + (screenSpace + shadowEdge) / (u_dimensions);
81
+ }
82
+ `,
83
+ fragment: `
84
+ # ifdef GL_FRAGMENT_PRECISION_HIGH
85
+ precision highp float;
86
+ # else
87
+ precision mediump float;
88
+ # endif
89
+
90
+ uniform vec2 u_resolution;
91
+ uniform float u_pixelRatio;
92
+ uniform float u_alpha;
93
+ uniform vec2 u_dimensions;
94
+ uniform sampler2D u_texture;
95
+ uniform float u_rtt;
96
+
97
+ uniform vec4 u_radius;
98
+ uniform vec4 u_borderWidth;
99
+ uniform vec4 u_borderColor;
100
+ uniform vec4 u_shadowColor;
101
+ uniform vec4 u_shadow;
102
+
103
+ varying vec4 v_color;
104
+ varying vec2 v_textureCoords;
105
+ varying vec2 v_nodeCoords;
106
+
107
+ varying vec2 v_halfDimensions;
108
+ varying vec4 v_innerRadius;
109
+ varying vec2 v_innerSize;
110
+
111
+ float roundedBox(vec2 p, vec2 s, vec4 r) {
112
+ r.xy = (p.x > 0.0) ? r.yz : r.xw;
113
+ r.x = (p.y > 0.0) ? r.y : r.x;
114
+ vec2 q = abs(p) - s + r.x;
115
+ return (min(max(q.x, q.y), 0.0) + length(max(q, 0.0))) - r.x;
116
+ }
117
+
118
+ float shadowBox(vec2 p, vec2 s, vec4 r) {
119
+ r.xy = (p.x > 0.0) ? r.yz : r.xw;
120
+ r.x = (p.y > 0.0) ? r.y : r.x;
121
+ vec2 q = abs(p) - s + r.x;
122
+ float dist = min(max(q.x, q.y), 0.0) + length(max(q, 0.0)) - r.x;
123
+ return 1.0 - smoothstep(-u_shadow.w, u_shadow.w + u_shadow.z, dist);
124
+ }
125
+
126
+ void main() {
127
+ vec4 color = texture2D(u_texture, v_textureCoords) * v_color;
128
+
129
+ vec2 boxUv = v_nodeCoords.xy * u_dimensions - v_halfDimensions;
130
+ float outerDist = roundedBox(boxUv, v_halfDimensions - 1.0, u_radius);
131
+
132
+ float outerAlpha = 1.0 - smoothstep(0.0, 1.0, outerDist);
133
+
134
+ boxUv.x += u_borderWidth.y > u_borderWidth.w ? (u_borderWidth.y - u_borderWidth.w) * 0.5 : -(u_borderWidth.w - u_borderWidth.y) * 0.5;
135
+ boxUv.y += u_borderWidth.z > u_borderWidth.x ? ((u_borderWidth.z - u_borderWidth.x) * 0.5 + 0.5) : -(u_borderWidth.x - u_borderWidth.z) * 0.5;
136
+
137
+ float innerDist = roundedBox(boxUv, v_innerSize, v_innerRadius);
138
+ float innerAlpha = 1.0 - smoothstep(0.0, 1.0, innerDist);
139
+
140
+ float shadowAlpha = shadowBox(boxUv - u_shadow.xy, v_halfDimensions + u_shadow.w, u_radius + u_shadow.z);
141
+
142
+ vec4 shadow = mix(vec4(0.0), u_shadowColor, shadowAlpha);
143
+ vec4 resColor = mix(u_borderColor, color, innerAlpha);
144
+ resColor = mix(shadow, resColor, outerAlpha);
145
+ gl_FragColor = resColor * u_alpha;
146
+ }
147
+ `,
148
+ };
149
+ //# sourceMappingURL=RoundedWithBorderAndShadow.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"RoundedWithBorderAndShadow.js","sourceRoot":"","sources":["../../../../../src/core/shaders/webgl/RoundedWithBorderAndShadow.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;GAeG;AAGH,OAAO,EAAE,uBAAuB,EAAE,MAAM,oBAAoB,CAAC;AAG7D,OAAO,EACL,kCAAkC,GAEnC,MAAM,oDAAoD,CAAC;AAE5D,MAAM,CAAC,MAAM,0BAA0B,GACrC;IACE,KAAK,EAAE,kCAAkC,CAAC,KAAK;IAC/C,MAAM,CAAC,IAAc;QACnB,IAAI,CAAC,WAAW,CAAC,eAAe,EAAE,IAAI,CAAC,KAAM,CAAC,cAAc,CAAC,CAAC,CAAC;QAC/D,IAAI,CAAC,UAAU,CAAC,eAAe,EAAE,IAAI,CAAC,KAAM,CAAC,cAAc,CAAS,CAAC,CAAC;QAEtE,IAAI,CAAC,WAAW,CAAC,eAAe,EAAE,IAAI,CAAC,KAAM,CAAC,cAAc,CAAC,CAAC,CAAC;QAC/D,IAAI,CAAC,UAAU,CAAC,UAAU,EAAE,IAAI,CAAC,KAAM,CAAC,mBAAmB,CAAC,CAAC,CAAC;QAE9D,IAAI,CAAC,UAAU,CACb,UAAU,EACV,uBAAuB,CACrB,IAAI,CAAC,KAAM,CAAC,MAAc,EAC1B,IAAI,CAAC,KAAK,EACV,IAAI,CAAC,MAAM,CACZ,CACF,CAAC;IACJ,CAAC;IACD,MAAM,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAsDT;IACC,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAgEX;CACA,CAAC"}
@@ -0,0 +1,3 @@
1
+ import type { WebGlShaderType } from '../../renderers/webgl/WebGlShaderNode.js';
2
+ import { type RoundedWithShadowProps } from '../templates/RoundedWithShadowTemplate.js';
3
+ export declare const RoundedWithShadow: WebGlShaderType<RoundedWithShadowProps>;
@@ -0,0 +1,84 @@
1
+ /*
2
+ * Copyright 2023 Comcast Cable Communications Management, LLC
3
+ * Licensed under the Apache License, Version 2.0 (the "License");
4
+ * you may not use this file except in compliance with the License.
5
+ * You may obtain a copy of the License at
6
+ *
7
+ * http://www.apache.org/licenses/LICENSE-2.0
8
+ *
9
+ * Unless required by applicable law or agreed to in writing, software
10
+ * distributed under the License is distributed on an "AS IS" BASIS,
11
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
+ * See the License for the specific language governing permissions and
13
+ * limitations under the License.
14
+ *
15
+ * SPDX-License-Identifier: Apache-2.0
16
+ */
17
+ import { calcFactoredRadiusArray } from '../../lib/utils.js';
18
+ import { RoundedWithShadowTemplate, } from '../templates/RoundedWithShadowTemplate.js';
19
+ import { Shadow } from './Shadow.js';
20
+ export const RoundedWithShadow = {
21
+ props: RoundedWithShadowTemplate.props,
22
+ update(node) {
23
+ this.uniformRGBA('u_shadow_color', this.props['shadow-color']);
24
+ this.uniform4fa('u_shadow', this.props['shadow-projection']);
25
+ this.uniform4fa('u_radius', calcFactoredRadiusArray(this.props.radius, node.width, node.height));
26
+ },
27
+ vertex: Shadow.vertex,
28
+ fragment: `
29
+ # ifdef GL_FRAGMENT_PRECISION_HIGH
30
+ precision highp float;
31
+ # else
32
+ precision mediump float;
33
+ # endif
34
+
35
+ uniform vec2 u_resolution;
36
+ uniform float u_pixelRatio;
37
+ uniform float u_alpha;
38
+ uniform vec2 u_dimensions;
39
+ uniform sampler2D u_texture;
40
+
41
+ uniform vec4 u_shadow_color;
42
+ uniform vec4 u_shadow;
43
+ uniform vec4 u_radius;
44
+
45
+ uniform int u_asymWidth;
46
+
47
+ varying vec4 v_color;
48
+ varying vec2 v_textureCoords;
49
+ varying vec2 v_nodeCoords;
50
+
51
+ float roundedBox(vec2 p, vec2 s, vec4 r) {
52
+ r.xy = (p.x > 0.0) ? r.yz : r.xw;
53
+ r.x = (p.y > 0.0) ? r.y : r.x;
54
+ vec2 q = abs(p) - s + r.x;
55
+ return (min(max(q.x, q.y), 0.0) + length(max(q, 0.0))) - r.x;
56
+ }
57
+
58
+ float shadowBox(vec2 p, vec2 s, vec4 r) {
59
+ r.xy = (p.x > 0.0) ? r.yz : r.xw;
60
+ r.x = (p.y > 0.0) ? r.y : r.x;
61
+ vec2 q = abs(p) - s + r.x;
62
+ float dist = min(max(q.x, q.y), 0.0) + length(max(q, 0.0)) - r.x;
63
+ return 1.0 - smoothstep(-(u_shadow.w), (u_shadow.w + u_shadow.z), dist);
64
+ }
65
+
66
+ void main() {
67
+ vec4 color = texture2D(u_texture, v_textureCoords) * v_color;
68
+ vec2 halfDimensions = (u_dimensions * 0.5);
69
+
70
+ vec2 boxUv = v_nodeCoords.xy * u_dimensions - halfDimensions;
71
+ float boxDist = roundedBox(boxUv, halfDimensions, u_radius);
72
+
73
+ float roundedAlpha = 1.0 - smoothstep(0.0, u_pixelRatio, boxDist);
74
+
75
+ float shadowAlpha = shadowBox(boxUv - u_shadow.xy, halfDimensions + u_shadow.w, u_radius + u_shadow.z);
76
+
77
+ vec4 resColor = vec4(0.0);
78
+ resColor = mix(resColor, u_shadow_color, shadowAlpha);
79
+ resColor = mix(resColor, color, min(color.a, roundedAlpha));
80
+ gl_FragColor = resColor * u_alpha;
81
+ }
82
+ `,
83
+ };
84
+ //# sourceMappingURL=RoundedWithShadow.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"RoundedWithShadow.js","sourceRoot":"","sources":["../../../../../src/core/shaders/webgl/RoundedWithShadow.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;GAeG;AAGH,OAAO,EAAE,uBAAuB,EAAE,MAAM,oBAAoB,CAAC;AAG7D,OAAO,EACL,yBAAyB,GAE1B,MAAM,2CAA2C,CAAC;AACnD,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AAErC,MAAM,CAAC,MAAM,iBAAiB,GAA4C;IACxE,KAAK,EAAE,yBAAyB,CAAC,KAAK;IACtC,MAAM,CAAC,IAAc;QACnB,IAAI,CAAC,WAAW,CAAC,gBAAgB,EAAE,IAAI,CAAC,KAAM,CAAC,cAAc,CAAE,CAAC,CAAC;QACjE,IAAI,CAAC,UAAU,CAAC,UAAU,EAAE,IAAI,CAAC,KAAM,CAAC,mBAAmB,CAAE,CAAC,CAAC;QAC/D,IAAI,CAAC,UAAU,CACb,UAAU,EACV,uBAAuB,CACrB,IAAI,CAAC,KAAM,CAAC,MAAc,EAC1B,IAAI,CAAC,KAAK,EACV,IAAI,CAAC,MAAM,CACZ,CACF,CAAC;IACJ,CAAC;IACD,MAAM,EAAE,MAAM,CAAC,MAAgB;IAC/B,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAsDT;CACF,CAAC"}
@@ -0,0 +1,32 @@
1
+ import type { WebGlShaderType } from '../../renderers/webgl/WebGlShaderNode.js';
2
+ /**
3
+ * Properties of the {@link SdfShader}
4
+ */
5
+ export interface SdfShaderProps {
6
+ transform: Float32Array;
7
+ scrollY: number;
8
+ /**
9
+ * Color in RGBA format
10
+ *
11
+ * @remarks
12
+ * Color channels must NOT be premultiplied by alpha for best blending results.
13
+ */
14
+ color: number;
15
+ size: number;
16
+ distanceRange: number;
17
+ debug: boolean;
18
+ }
19
+ /**
20
+ * SdfShader supports multi-channel and single-channel signed distance field textures.
21
+ *
22
+ * @remarks
23
+ * This Shader is used by the {@link SdfTextRenderer}. Do not use thie Shader
24
+ * directly. Instead create a Text Node and assign a SDF font family to it.
25
+ *
26
+ * @internalRemarks
27
+ * The only thing this shader does to support multi-channel SDFs is to
28
+ * add a median function to the fragment shader. If this one function call
29
+ * ends up being a performance bottleneck we can always look at ways to
30
+ * remove it.
31
+ */
32
+ export declare const Sdf: WebGlShaderType<SdfShaderProps>;
@@ -0,0 +1,116 @@
1
+ /*
2
+ * If not stated otherwise in this file or this component's LICENSE file the
3
+ * following copyright and licenses apply:
4
+ *
5
+ * Copyright 2023 Comcast Cable Communications Management, LLC.
6
+ *
7
+ * Licensed under the Apache License, Version 2.0 (the License);
8
+ * you may not use this file except in compliance with the License.
9
+ * You may obtain a copy of the License at
10
+ *
11
+ * http://www.apache.org/licenses/LICENSE-2.0
12
+ *
13
+ * Unless required by applicable law or agreed to in writing, software
14
+ * distributed under the License is distributed on an "AS IS" BASIS,
15
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16
+ * See the License for the specific language governing permissions and
17
+ * limitations under the License.
18
+ */
19
+ import { getNormalizedRgbaComponents } from '../../lib/utils.js';
20
+ const IDENTITY_MATRIX_3x3 = new Float32Array([1, 0, 0, 0, 1, 0, 0, 0, 1]);
21
+ /**
22
+ * SdfShader supports multi-channel and single-channel signed distance field textures.
23
+ *
24
+ * @remarks
25
+ * This Shader is used by the {@link SdfTextRenderer}. Do not use thie Shader
26
+ * directly. Instead create a Text Node and assign a SDF font family to it.
27
+ *
28
+ * @internalRemarks
29
+ * The only thing this shader does to support multi-channel SDFs is to
30
+ * add a median function to the fragment shader. If this one function call
31
+ * ends up being a performance bottleneck we can always look at ways to
32
+ * remove it.
33
+ */
34
+ export const Sdf = {
35
+ props: {
36
+ transform: IDENTITY_MATRIX_3x3,
37
+ scrollY: 0,
38
+ color: 0xffffffff,
39
+ size: 16,
40
+ distanceRange: 1.0,
41
+ debug: false,
42
+ },
43
+ onSdfBind(props) {
44
+ this.uniformMatrix3fv('u_transform', props.transform);
45
+ this.uniform1f('u_scrollY', props.scrollY);
46
+ this.uniform4fa('u_color', getNormalizedRgbaComponents(props.color));
47
+ this.uniform1f('u_size', props.size);
48
+ this.uniform1f('u_distanceRange', props.distanceRange);
49
+ this.uniform1i('u_debug', props.debug ? 1 : 0);
50
+ },
51
+ vertex: `
52
+ # ifdef GL_FRAGMENT_PRECISION_HIGH
53
+ precision highp float;
54
+ # else
55
+ precision mediump float;
56
+ # endif
57
+ // an attribute is an input (in) to a vertex shader.
58
+ // It will receive data from a buffer
59
+ attribute vec2 a_position;
60
+ attribute vec2 a_textureCoords;
61
+
62
+ uniform vec2 u_resolution;
63
+ uniform mat3 u_transform;
64
+ uniform float u_scrollY;
65
+ uniform float u_pixelRatio;
66
+ uniform float u_size;
67
+
68
+ varying vec2 v_texcoord;
69
+
70
+ void main() {
71
+ vec2 scrolledPosition = a_position * u_size - vec2(0, u_scrollY);
72
+ vec2 transformedPosition = (u_transform * vec3(scrolledPosition, 1)).xy;
73
+
74
+ // Calculate screen space with pixel ratio
75
+ vec2 screenSpace = (transformedPosition * u_pixelRatio / u_resolution * 2.0 - 1.0) * vec2(1, -1);
76
+
77
+ gl_Position = vec4(screenSpace, 0.0, 1.0);
78
+ v_texcoord = a_textureCoords;
79
+
80
+ }
81
+ `,
82
+ fragment: `
83
+ # ifdef GL_FRAGMENT_PRECISION_HIGH
84
+ precision highp float;
85
+ # else
86
+ precision mediump float;
87
+ # endif
88
+ uniform vec4 u_color;
89
+ uniform sampler2D u_texture;
90
+ uniform float u_distanceRange;
91
+ uniform float u_pixelRatio;
92
+ uniform int u_debug;
93
+
94
+ varying vec2 v_texcoord;
95
+
96
+ float median(float r, float g, float b) {
97
+ return max(min(r, g), min(max(r, g), b));
98
+ }
99
+
100
+ void main() {
101
+ vec3 sample = texture2D(u_texture, v_texcoord).rgb;
102
+ if (u_debug == 1) {
103
+ gl_FragColor = vec4(sample.r, sample.g, sample.b, 1.0);
104
+ return;
105
+ }
106
+ float scaledDistRange = u_distanceRange * u_pixelRatio;
107
+ float sigDist = scaledDistRange * (median(sample.r, sample.g, sample.b) - 0.5);
108
+ float opacity = clamp(sigDist + 0.5, 0.0, 1.0) * u_color.a;
109
+
110
+ // Build the final color.
111
+ // IMPORTANT: We must premultiply the color by the alpha value before returning it.
112
+ gl_FragColor = vec4(u_color.r * opacity, u_color.g * opacity, u_color.b * opacity, opacity);
113
+ }
114
+ `,
115
+ };
116
+ //# sourceMappingURL=SdfShader.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SdfShader.js","sourceRoot":"","sources":["../../../../../src/core/shaders/webgl/SdfShader.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;GAiBG;AACH,OAAO,EAAE,2BAA2B,EAAE,MAAM,oBAAoB,CAAC;AAGjE,MAAM,mBAAmB,GAAG,IAAI,YAAY,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;AAkB1E;;;;;;;;;;;;GAYG;AACH,MAAM,CAAC,MAAM,GAAG,GAAoC;IAClD,KAAK,EAAE;QACL,SAAS,EAAE,mBAAmB;QAC9B,OAAO,EAAE,CAAC;QACV,KAAK,EAAE,UAAU;QACjB,IAAI,EAAE,EAAE;QACR,aAAa,EAAE,GAAG;QAClB,KAAK,EAAE,KAAK;KACb;IACD,SAAS,CAAC,KAAK;QACb,IAAI,CAAC,gBAAgB,CAAC,aAAa,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC;QACtD,IAAI,CAAC,SAAS,CAAC,WAAW,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC;QAC3C,IAAI,CAAC,UAAU,CAAC,SAAS,EAAE,2BAA2B,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC;QACrE,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC;QACrC,IAAI,CAAC,SAAS,CAAC,iBAAiB,EAAE,KAAK,CAAC,aAAa,CAAC,CAAC;QACvD,IAAI,CAAC,SAAS,CAAC,SAAS,EAAE,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IACjD,CAAC;IACD,MAAM,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA8BP;IACD,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAgCT;CACF,CAAC"}
@@ -0,0 +1,3 @@
1
+ import type { WebGlShaderType } from '../../renderers/webgl/WebGlShaderNode.js';
2
+ import { type ShadowProps } from '../templates/ShadowTemplate.js';
3
+ export declare const Shadow: WebGlShaderType<ShadowProps>;
@@ -0,0 +1,110 @@
1
+ /*
2
+ * Copyright 2023 Comcast Cable Communications Management, LLC
3
+ * Licensed under the Apache License, Version 2.0 (the "License");
4
+ * you may not use this file except in compliance with the License.
5
+ * You may obtain a copy of the License at
6
+ *
7
+ * http://www.apache.org/licenses/LICENSE-2.0
8
+ *
9
+ * Unless required by applicable law or agreed to in writing, software
10
+ * distributed under the License is distributed on an "AS IS" BASIS,
11
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
+ * See the License for the specific language governing permissions and
13
+ * limitations under the License.
14
+ *
15
+ * SPDX-License-Identifier: Apache-2.0
16
+ */
17
+ import { ShadowTemplate, } from '../templates/ShadowTemplate.js';
18
+ export const Shadow = {
19
+ props: ShadowTemplate.props,
20
+ update() {
21
+ this.uniformRGBA('u_color', this.props.color);
22
+ this.uniform4fa('u_shadow', this.props.projection);
23
+ },
24
+ vertex: `
25
+ # ifdef GL_FRAGMENT_PRECISION_HIGH
26
+ precision highp float;
27
+ # else
28
+ precision mediump float;
29
+ # endif
30
+
31
+ attribute vec2 a_position;
32
+ attribute vec2 a_textureCoords;
33
+ attribute vec4 a_color;
34
+ attribute vec2 a_nodeCoords;
35
+
36
+ uniform vec2 u_resolution;
37
+ uniform float u_pixelRatio;
38
+ uniform float u_rtt;
39
+ uniform vec2 u_dimensions;
40
+
41
+ uniform vec4 u_shadow;
42
+
43
+ varying vec4 v_color;
44
+ varying vec2 v_textureCoords;
45
+ varying vec2 v_nodeCoords;
46
+
47
+ void main() {
48
+ vec2 screenSpace = vec2(2.0 / u_resolution.x, -2.0 / u_resolution.y);
49
+ vec2 outerEdge = clamp(a_nodeCoords * 2.0 - vec2(1.0), -1.0, 1.0);
50
+
51
+ vec2 shadowEdge = outerEdge * ((u_shadow.w * 2.0)+ u_shadow.z) + u_shadow.xy;
52
+ vec2 normVertexPos = a_position * u_pixelRatio;
53
+
54
+ vec2 vertexPos = (a_position + outerEdge + shadowEdge) * u_pixelRatio;
55
+ gl_Position = vec4(vertexPos.x * screenSpace.x - 1.0, -sign(screenSpace.y) * (vertexPos.y * -abs(screenSpace.y)) + 1.0, 0.0, 1.0);
56
+
57
+ v_color = a_color;
58
+ v_nodeCoords = a_nodeCoords + (screenSpace + shadowEdge) / (u_dimensions);
59
+ v_textureCoords = a_textureCoords + (screenSpace + shadowEdge) / (u_dimensions);
60
+ }
61
+ `,
62
+ fragment: `
63
+ # ifdef GL_FRAGMENT_PRECISION_HIGH
64
+ precision highp float;
65
+ # else
66
+ precision mediump float;
67
+ # endif
68
+
69
+ uniform vec2 u_resolution;
70
+ uniform float u_pixelRatio;
71
+ uniform float u_alpha;
72
+ uniform vec2 u_dimensions;
73
+ uniform sampler2D u_texture;
74
+
75
+ uniform vec4 u_color;
76
+ uniform vec4 u_shadow;
77
+
78
+ varying vec4 v_color;
79
+ varying vec2 v_textureCoords;
80
+ varying vec2 v_nodeCoords;
81
+
82
+ float box(vec2 p, vec2 s) {
83
+ vec2 q = abs(p) - s;
84
+ return (min(max(q.x, q.y), 0.0) + length(max(q, 0.0))) + 2.0;
85
+ }
86
+
87
+ float shadowBox(vec2 p, vec2 s, float r) {
88
+ vec2 q = abs(p) - s + r;
89
+ float dist = min(max(q.x, q.y), 0.0) + length(max(q, 0.0)) - r;
90
+ return 1.0 - smoothstep(-u_shadow.w, u_shadow.w + u_shadow.z, dist);
91
+ }
92
+
93
+ void main() {
94
+ vec4 color = texture2D(u_texture, v_textureCoords) * v_color;
95
+ vec2 halfDimensions = (u_dimensions * 0.5);
96
+
97
+ vec2 boxUv = v_nodeCoords.xy * u_dimensions - halfDimensions;
98
+ float boxDist = box(boxUv, halfDimensions);
99
+
100
+ float boxAlpha = 1.0 - smoothstep(0.0, u_pixelRatio, boxDist);
101
+ float shadowDist = shadowBox(boxUv - u_shadow.xy, halfDimensions + u_shadow.w, u_shadow.z);
102
+
103
+ vec4 resColor = vec4(0.0);
104
+ resColor = mix(resColor, u_color, shadowDist);
105
+ resColor = mix(resColor, color, min(color.a, boxAlpha));
106
+ gl_FragColor = resColor * u_alpha;
107
+ }
108
+ `,
109
+ };
110
+ //# sourceMappingURL=Shadow.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Shadow.js","sourceRoot":"","sources":["../../../../../src/core/shaders/webgl/Shadow.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;GAeG;AAGH,OAAO,EACL,cAAc,GAEf,MAAM,gCAAgC,CAAC;AAExC,MAAM,CAAC,MAAM,MAAM,GAAiC;IAClD,KAAK,EAAE,cAAc,CAAC,KAAK;IAC3B,MAAM;QACJ,IAAI,CAAC,WAAW,CAAC,SAAS,EAAE,IAAI,CAAC,KAAM,CAAC,KAAK,CAAC,CAAC;QAC/C,IAAI,CAAC,UAAU,CAAC,UAAU,EAAE,IAAI,CAAC,KAAM,CAAC,UAAU,CAAC,CAAC;IACtD,CAAC;IACD,MAAM,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAqCP;IACD,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA8CT;CACF,CAAC"}
@@ -0,0 +1,77 @@
1
+ checkRenderBounds();
2
+ CoreNodeRenderState;
3
+ {
4
+ assertTruthy(this.renderBound);
5
+ assertTruthy(this.strictBound);
6
+ assertTruthy(this.preloadBound);
7
+ if (boundInsideBound(this.renderBound, this.strictBound)) {
8
+ return CoreNodeRenderState.InViewport;
9
+ }
10
+ if (boundInsideBound(this.renderBound, this.preloadBound)) {
11
+ return CoreNodeRenderState.InBounds;
12
+ }
13
+ // check if we're larger then our parent, we're definitely in the viewport
14
+ if (boundLargeThanBound(this.renderBound, this.strictBound)) {
15
+ return CoreNodeRenderState.InViewport;
16
+ }
17
+ // check if we dont have dimensions, take our parent's render state
18
+ if (this.parent !== null &&
19
+ (this.props.width === 0 || this.props.height === 0)) {
20
+ return this.parent.renderState;
21
+ }
22
+ return CoreNodeRenderState.OutOfBounds;
23
+ }
24
+ updateBoundingRect();
25
+ {
26
+ const transform = this.sceneGlobalTransform || this.globalTransform;
27
+ const renderCoords = this.sceneRenderCoords || this.renderCoords;
28
+ assertTruthy(transform);
29
+ assertTruthy(renderCoords);
30
+ if (transform.tb === 0 || transform.tc === 0) {
31
+ this.renderBound = createBound(renderCoords.x1, renderCoords.y1, renderCoords.x3, renderCoords.y3, this.renderBound);
32
+ }
33
+ else {
34
+ const { x1, y1, x2, y2, x3, y3, x4, y4 } = renderCoords;
35
+ this.renderBound = createBound(Math.min(x1, x2, x3, x4), Math.min(y1, y2, y3, y4), Math.max(x1, x2, x3, x4), Math.max(y1, y2, y3, y4), this.renderBound);
36
+ }
37
+ }
38
+ createRenderBounds();
39
+ void {
40
+ : .stage,
41
+ : .parent !== null && this.parent.strictBound !== undefined
42
+ };
43
+ {
44
+ // we have a parent with a valid bound, copy it
45
+ const parentBound = this.parent.strictBound;
46
+ this.strictBound = createBound(parentBound.x1, parentBound.y1, parentBound.x2, parentBound.y2);
47
+ this.preloadBound = createPreloadBounds(this.strictBound, this.boundsMargin);
48
+ }
49
+ {
50
+ // no parent or parent does not have a bound, take the stage boundaries
51
+ this.strictBound = this.stage.strictBound;
52
+ this.preloadBound = this.stage.preloadBound;
53
+ }
54
+ // if clipping is disabled, we're done
55
+ if (this.props.clipping === false) {
56
+ return;
57
+ }
58
+ // only create local clipping bounds if node itself is in bounds
59
+ // this can only be done if we have a render bound already
60
+ if (this.renderBound === undefined) {
61
+ return;
62
+ }
63
+ // if we're out of bounds, we're done
64
+ if (boundInsideBound(this.renderBound, this.strictBound) === false) {
65
+ return;
66
+ }
67
+ // clipping is enabled and we are in bounds create our own bounds
68
+ const { x, y, width, height } = this.props;
69
+ // Pick the global transform if available, otherwise use the local transform
70
+ // global transform is only available if the node in an RTT chain
71
+ const { tx, ty } = this.sceneGlobalTransform || this.globalTransform || {};
72
+ const _x = tx ?? x;
73
+ const _y = ty ?? y;
74
+ this.strictBound = createBound(_x, _y, _x + width, _y + height, this.strictBound);
75
+ this.preloadBound = createPreloadBounds(this.strictBound, this.boundsMargin);
76
+ export {};
77
+ //# sourceMappingURL=temp.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"temp.js","sourceRoot":"","sources":["../../../src/core/temp.ts"],"names":[],"mappings":"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"}