@lightningjs/renderer 2.16.0 → 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 (443) 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 +8 -2
  6. package/dist/exports/canvas.js +8 -2
  7. package/dist/exports/canvas.js.map +1 -1
  8. package/dist/exports/index.d.ts +16 -13
  9. package/dist/exports/index.js +8 -9
  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 +11 -2
  15. package/dist/exports/webgl.js +11 -2
  16. package/dist/exports/webgl.js.map +1 -1
  17. package/dist/src/core/CoreNode.d.ts +47 -76
  18. package/dist/src/core/CoreNode.js +322 -309
  19. package/dist/src/core/CoreNode.js.map +1 -1
  20. package/dist/src/core/CoreShaderManager.d.ts +29 -73
  21. package/dist/src/core/CoreShaderManager.js +110 -97
  22. package/dist/src/core/CoreShaderManager.js.map +1 -1
  23. package/dist/src/core/CoreTextNode.d.ts +58 -87
  24. package/dist/src/core/CoreTextNode.js +243 -237
  25. package/dist/src/core/CoreTextNode.js.map +1 -1
  26. package/dist/src/core/CoreTextureManager.d.ts +2 -0
  27. package/dist/src/core/CoreTextureManager.js +12 -10
  28. package/dist/src/core/CoreTextureManager.js.map +1 -1
  29. package/dist/src/core/Stage.d.ts +58 -53
  30. package/dist/src/core/Stage.js +260 -196
  31. package/dist/src/core/Stage.js.map +1 -1
  32. package/dist/src/core/TextureMemoryManager.d.ts +3 -0
  33. package/dist/src/core/TextureMemoryManager.js +78 -74
  34. package/dist/src/core/TextureMemoryManager.js.map +1 -1
  35. package/dist/src/core/animations/CoreAnimation.d.ts +0 -1
  36. package/dist/src/core/animations/CoreAnimation.js +6 -52
  37. package/dist/src/core/animations/CoreAnimation.js.map +1 -1
  38. package/dist/src/core/lib/ImageWorker.js +1 -1
  39. package/dist/src/core/lib/ImageWorker.js.map +1 -1
  40. package/dist/src/core/lib/RenderCoords.d.ts +9 -10
  41. package/dist/src/core/lib/RenderCoords.js +43 -55
  42. package/dist/src/core/lib/RenderCoords.js.map +1 -1
  43. package/dist/src/core/lib/WebGlContextWrapper.d.ts +117 -55
  44. package/dist/src/core/lib/WebGlContextWrapper.js +196 -157
  45. package/dist/src/core/lib/WebGlContextWrapper.js.map +1 -1
  46. package/dist/src/core/lib/colorCache.d.ts +1 -0
  47. package/dist/src/core/lib/colorCache.js +19 -0
  48. package/dist/src/core/lib/colorCache.js.map +1 -0
  49. package/dist/src/core/lib/colorParser.d.ts +21 -0
  50. package/dist/src/core/lib/colorParser.js +72 -0
  51. package/dist/src/core/lib/colorParser.js.map +1 -0
  52. package/dist/src/core/lib/textureCompression.js +0 -1
  53. package/dist/src/core/lib/textureCompression.js.map +1 -1
  54. package/dist/src/core/lib/utils.d.ts +3 -1
  55. package/dist/src/core/lib/utils.js +19 -0
  56. package/dist/src/core/lib/utils.js.map +1 -1
  57. package/dist/src/core/lib/validateImageBitmap.d.ts +2 -1
  58. package/dist/src/core/lib/validateImageBitmap.js +4 -4
  59. package/dist/src/core/lib/validateImageBitmap.js.map +1 -1
  60. package/dist/src/core/platforms/web/WebPlatform.js +29 -3
  61. package/dist/src/core/platforms/web/WebPlatform.js.map +1 -1
  62. package/dist/src/core/renderers/CoreRenderer.d.ts +15 -22
  63. package/dist/src/core/renderers/CoreRenderer.js +0 -6
  64. package/dist/src/core/renderers/CoreRenderer.js.map +1 -1
  65. package/dist/src/core/renderers/canvas/CanvasRenderer.d.ts +0 -2
  66. package/dist/src/core/renderers/canvas/CanvasRenderer.js +7 -21
  67. package/dist/src/core/renderers/canvas/CanvasRenderer.js.map +1 -1
  68. package/dist/src/core/renderers/canvas/CanvasShaderNode.js +2 -1
  69. package/dist/src/core/renderers/canvas/CanvasShaderNode.js.map +1 -1
  70. package/dist/src/core/renderers/canvas/CanvasTexture.d.ts +2 -2
  71. package/dist/src/core/renderers/canvas/CanvasTexture.js +8 -7
  72. package/dist/src/core/renderers/canvas/CanvasTexture.js.map +1 -1
  73. package/dist/src/core/renderers/canvas/internal/C2DShaderUtils.d.ts +0 -13
  74. package/dist/src/core/renderers/canvas/internal/C2DShaderUtils.js +192 -113
  75. package/dist/src/core/renderers/canvas/internal/C2DShaderUtils.js.map +1 -1
  76. package/dist/src/core/renderers/canvas/internal/ColorUtils.d.ts +2 -0
  77. package/dist/src/core/renderers/canvas/internal/ColorUtils.js +14 -0
  78. package/dist/src/core/renderers/canvas/internal/ColorUtils.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 -18
  83. package/dist/src/core/renderers/webgl/WebGlCtxTexture.js.map +1 -1
  84. package/dist/src/core/renderers/webgl/WebGlShaderProgram.d.ts +4 -2
  85. package/dist/src/core/renderers/webgl/WebGlShaderProgram.js +31 -13
  86. package/dist/src/core/renderers/webgl/WebGlShaderProgram.js.map +1 -1
  87. package/dist/src/core/renderers/webgl/internal/ShaderUtils.d.ts +32 -5
  88. package/dist/src/core/renderers/webgl/internal/ShaderUtils.js +50 -0
  89. package/dist/src/core/renderers/webgl/internal/ShaderUtils.js.map +1 -1
  90. package/dist/src/core/shaders/canvas/Border.js +1 -1
  91. package/dist/src/core/shaders/canvas/Border.js.map +1 -1
  92. package/dist/src/core/shaders/webgl/Border.js +82 -82
  93. package/dist/src/core/shaders/webgl/Default.js +47 -47
  94. package/dist/src/core/shaders/webgl/DefaultBatched.js +61 -61
  95. package/dist/src/core/shaders/webgl/HolePunch.js +32 -32
  96. package/dist/src/core/shaders/webgl/LinearGradient.js +36 -36
  97. package/dist/src/core/shaders/webgl/RadialGradient.js +33 -33
  98. package/dist/src/core/shaders/webgl/Rounded.js +71 -71
  99. package/dist/src/core/shaders/webgl/RoundedWithBorder.js +111 -111
  100. package/dist/src/core/shaders/webgl/RoundedWithBorderAndShadow.js +130 -130
  101. package/dist/src/core/shaders/webgl/RoundedWithShadow.js +54 -54
  102. package/dist/src/core/shaders/webgl/SdfShader.js +62 -62
  103. package/dist/src/core/shaders/webgl/Shadow.js +83 -83
  104. package/dist/src/core/text-rendering/CanvasFontHandler.d.ts +4 -4
  105. package/dist/src/core/text-rendering/CanvasFontHandler.js +19 -6
  106. package/dist/src/core/text-rendering/CanvasFontHandler.js.map +1 -1
  107. package/dist/src/core/text-rendering/CanvasTextRenderer.d.ts +18 -2
  108. package/dist/src/core/text-rendering/CanvasTextRenderer.js +296 -69
  109. package/dist/src/core/text-rendering/CanvasTextRenderer.js.map +1 -1
  110. package/dist/src/core/text-rendering/SdfFontHandler.d.ts +4 -4
  111. package/dist/src/core/text-rendering/SdfFontHandler.js +6 -6
  112. package/dist/src/core/text-rendering/SdfFontHandler.js.map +1 -1
  113. package/dist/src/core/text-rendering/SdfTextRenderer.d.ts +4 -8
  114. package/dist/src/core/text-rendering/SdfTextRenderer.js +68 -37
  115. package/dist/src/core/text-rendering/SdfTextRenderer.js.map +1 -1
  116. package/dist/src/core/text-rendering/TextRenderer.d.ts +37 -113
  117. package/dist/src/core/text-rendering/TextRenderer.js +1 -51
  118. package/dist/src/core/text-rendering/TextRenderer.js.map +1 -1
  119. package/dist/src/core/text-rendering/TextTextureRendererUtils.js.map +1 -1
  120. package/dist/src/core/text-rendering/canvas/Settings.d.ts +14 -3
  121. package/dist/src/core/text-rendering/canvas/Utils.d.ts +3 -2
  122. package/dist/src/core/text-rendering/canvas/Utils.js +9 -4
  123. package/dist/src/core/text-rendering/canvas/Utils.js.map +1 -1
  124. package/dist/src/core/text-rendering/canvas/calculateRenderInfo.d.ts +32 -9
  125. package/dist/src/core/text-rendering/canvas/calculateRenderInfo.js +52 -57
  126. package/dist/src/core/text-rendering/canvas/calculateRenderInfo.js.map +1 -1
  127. package/dist/src/core/text-rendering/canvas/draw.d.ts +3 -10
  128. package/dist/src/core/text-rendering/canvas/draw.js +26 -27
  129. package/dist/src/core/text-rendering/canvas/draw.js.map +1 -1
  130. package/dist/src/core/text-rendering/font-face-types/SdfTrFontFace/SdfTrFontFace.js +2 -2
  131. package/dist/src/core/text-rendering/font-face-types/SdfTrFontFace/SdfTrFontFace.js.map +1 -1
  132. package/dist/src/core/text-rendering/renderers/CanvasTextRenderer.js +5 -0
  133. package/dist/src/core/text-rendering/renderers/CanvasTextRenderer.js.map +1 -1
  134. package/dist/src/core/text-rendering/renderers/LightningTextTextureRenderer.d.ts +7 -1
  135. package/dist/src/core/text-rendering/renderers/LightningTextTextureRenderer.js +50 -2
  136. package/dist/src/core/text-rendering/renderers/LightningTextTextureRenderer.js.map +1 -1
  137. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.d.ts +2 -3
  138. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.js +42 -83
  139. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.js.map +1 -1
  140. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText.d.ts +1 -1
  141. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText.js +66 -8
  142. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText.js.map +1 -1
  143. package/dist/src/core/text-rendering/renderers/TextRenderer.d.ts +14 -4
  144. package/dist/src/core/text-rendering/renderers/TextRenderer.js +3 -0
  145. package/dist/src/core/text-rendering/renderers/TextRenderer.js.map +1 -1
  146. package/dist/src/core/text-rendering/sdf/Utils.d.ts +26 -0
  147. package/dist/src/core/text-rendering/sdf/Utils.js +304 -0
  148. package/dist/src/core/text-rendering/sdf/Utils.js.map +1 -0
  149. package/dist/src/core/text-rendering/sdf/index.d.ts +1 -0
  150. package/{src/core/text-rendering/renderers/SdfTextRenderer/internal/getUnicodeCodepoints.ts → dist/src/core/text-rendering/sdf/index.js} +3 -21
  151. package/dist/src/core/text-rendering/sdf/index.js.map +1 -0
  152. package/dist/src/core/textures/ImageTexture.d.ts +1 -0
  153. package/dist/src/core/textures/ImageTexture.js +11 -4
  154. package/dist/src/core/textures/ImageTexture.js.map +1 -1
  155. package/dist/src/core/textures/Texture.d.ts +6 -1
  156. package/dist/src/core/textures/Texture.js.map +1 -1
  157. package/dist/src/main-api/INode.d.ts +9 -9
  158. package/dist/src/main-api/Inspector.d.ts +6 -1
  159. package/dist/src/main-api/Inspector.js +43 -7
  160. package/dist/src/main-api/Inspector.js.map +1 -1
  161. package/dist/src/main-api/Renderer.d.ts +83 -136
  162. package/dist/src/main-api/Renderer.js +139 -91
  163. package/dist/src/main-api/Renderer.js.map +1 -1
  164. package/dist/src/utils.d.ts +5 -4
  165. package/dist/src/utils.js +20 -9
  166. package/dist/src/utils.js.map +1 -1
  167. package/dist/tsconfig.dist.tsbuildinfo +1 -1
  168. package/exports/canvas-shaders.ts +28 -0
  169. package/exports/canvas.ts +45 -39
  170. package/exports/index.ts +82 -89
  171. package/exports/inspector.ts +24 -24
  172. package/exports/utils.ts +50 -44
  173. package/exports/webgl-shaders.ts +28 -0
  174. package/exports/webgl.ts +52 -38
  175. package/package.json +4 -4
  176. package/src/common/CommonTypes.ts +146 -146
  177. package/src/common/EventEmitter.ts +77 -77
  178. package/src/common/IAnimationController.ts +92 -92
  179. package/src/common/IEventEmitter.ts +28 -28
  180. package/src/core/CoreNode.test.ts +202 -202
  181. package/src/core/CoreNode.ts +2491 -2487
  182. package/src/core/CoreShaderManager.ts +188 -292
  183. package/src/core/CoreTextNode.ts +443 -455
  184. package/src/core/CoreTextureManager.ts +565 -561
  185. package/src/core/Stage.ts +906 -826
  186. package/src/core/TextureMemoryManager.ts +445 -431
  187. package/src/core/animations/AnimationManager.ts +38 -38
  188. package/src/core/animations/CoreAnimation.ts +291 -347
  189. package/src/core/animations/CoreAnimationController.ts +166 -166
  190. package/src/core/lib/ContextSpy.ts +41 -41
  191. package/src/core/lib/ImageWorker.ts +286 -280
  192. package/src/core/lib/Matrix3d.ts +244 -244
  193. package/src/core/lib/RenderCoords.ts +71 -86
  194. package/src/core/lib/WebGlContextWrapper.ts +1381 -1332
  195. package/src/core/lib/colorCache.ts +20 -0
  196. package/src/core/{renderers/canvas/internal/ColorUtils.ts → lib/colorParser.ts} +85 -69
  197. package/src/core/lib/textureCompression.ts +152 -152
  198. package/src/core/lib/textureSvg.ts +78 -78
  199. package/src/core/lib/utils.ts +412 -388
  200. package/src/core/lib/validateImageBitmap.ts +87 -76
  201. package/src/core/platforms/Platform.ts +77 -0
  202. package/src/core/platforms/web/WebPlatform.ts +121 -0
  203. package/src/core/renderers/CoreContextTexture.ts +43 -43
  204. package/src/core/renderers/CoreRenderOp.ts +22 -22
  205. package/src/core/renderers/CoreRenderer.ts +110 -115
  206. package/src/core/renderers/CoreShaderNode.ts +175 -0
  207. package/{dist/src/core/renderers/CoreShader.js → src/core/renderers/CoreShaderProgram.ts} +23 -28
  208. package/src/core/renderers/canvas/CanvasRenderer.ts +283 -0
  209. package/src/core/renderers/canvas/CanvasShaderNode.ts +96 -0
  210. package/src/core/renderers/canvas/{CanvasCoreTexture.ts → CanvasTexture.ts} +156 -153
  211. package/src/core/renderers/webgl/{WebGlCoreCtxRenderTexture.ts → WebGlCtxRenderTexture.ts} +91 -91
  212. package/src/core/renderers/webgl/{WebGlCoreCtxSubTexture.ts → WebGlCtxSubTexture.ts} +50 -50
  213. package/src/core/renderers/webgl/{WebGlCoreCtxTexture.ts → WebGlCtxTexture.ts} +310 -313
  214. package/src/core/renderers/webgl/WebGlRenderOp.ts +167 -0
  215. package/src/core/renderers/webgl/{WebGlCoreRenderer.ts → WebGlRenderer.ts} +747 -821
  216. package/src/core/renderers/webgl/WebGlShaderNode.ts +435 -0
  217. package/src/core/renderers/webgl/WebGlShaderProgram.ts +341 -0
  218. package/src/core/renderers/webgl/internal/BufferCollection.ts +54 -54
  219. package/src/core/renderers/webgl/internal/RendererUtils.ts +155 -155
  220. package/src/core/renderers/webgl/internal/ShaderUtils.ts +281 -143
  221. package/src/core/renderers/webgl/internal/WebGlUtils.ts +35 -35
  222. package/src/core/shaders/canvas/Border.ts +75 -0
  223. package/src/core/shaders/canvas/HolePunch.ts +62 -0
  224. package/src/core/shaders/canvas/LinearGradient.ts +71 -0
  225. package/src/core/shaders/canvas/RadialGradient.ts +99 -0
  226. package/src/core/shaders/canvas/Rounded.ts +55 -0
  227. package/src/core/shaders/canvas/RoundedWithBorder.ts +74 -0
  228. package/src/core/shaders/canvas/RoundedWithBorderAndShadow.ts +90 -0
  229. package/src/core/shaders/canvas/RoundedWithShadow.ts +70 -0
  230. package/src/core/shaders/canvas/Shadow.ts +52 -0
  231. package/src/core/shaders/canvas/utils/render.ts +151 -0
  232. package/src/core/shaders/templates/BorderTemplate.ts +115 -0
  233. package/src/core/shaders/templates/HolePunchTemplate.ts +82 -0
  234. package/src/core/shaders/templates/LinearGradientTemplate.ts +71 -0
  235. package/src/core/shaders/templates/RadialGradientTemplate.ts +81 -0
  236. package/src/core/shaders/templates/RoundedTemplate.ts +98 -0
  237. package/src/core/shaders/templates/RoundedWithBorderAndShadowTemplate.ts +38 -0
  238. package/{dist/src/core/shaders/templates/shaderUtils.js → src/core/shaders/templates/RoundedWithBorderTemplate.ts} +35 -41
  239. package/src/core/shaders/templates/RoundedWithShadowTemplate.ts +35 -0
  240. package/src/core/shaders/templates/ShadowTemplate.ts +106 -0
  241. package/src/core/shaders/utils.ts +46 -0
  242. package/src/core/shaders/webgl/Border.ts +116 -0
  243. package/src/core/shaders/webgl/Default.ts +89 -0
  244. package/src/core/shaders/webgl/DefaultBatched.ts +129 -0
  245. package/src/core/shaders/webgl/HolePunch.ts +75 -0
  246. package/src/core/shaders/webgl/LinearGradient.ts +82 -0
  247. package/src/core/shaders/webgl/RadialGradient.ts +85 -0
  248. package/src/core/shaders/webgl/Rounded.ts +117 -0
  249. package/src/core/shaders/webgl/RoundedWithBorder.ts +155 -0
  250. package/src/core/shaders/webgl/RoundedWithBorderAndShadow.ts +175 -0
  251. package/src/core/shaders/webgl/RoundedWithShadow.ts +98 -0
  252. package/src/core/shaders/webgl/SdfShader.ts +134 -0
  253. package/src/core/shaders/webgl/Shadow.ts +115 -0
  254. package/src/core/text-rendering/CanvasFontHandler.ts +176 -0
  255. package/src/core/text-rendering/CanvasTextRenderer.ts +622 -0
  256. package/src/core/text-rendering/SdfFontHandler.ts +517 -0
  257. package/src/core/text-rendering/SdfTextRenderer.ts +466 -0
  258. package/src/core/text-rendering/TextRenderer.ts +404 -0
  259. package/src/core/text-rendering/{TextTextureRendererUtils.ts → Utils.ts} +257 -263
  260. package/src/core/text-rendering/canvas/Settings.ts +99 -0
  261. package/src/core/text-rendering/canvas/Utils.test.ts +206 -0
  262. package/src/core/text-rendering/canvas/Utils.ts +178 -0
  263. package/src/core/text-rendering/canvas/calculateRenderInfo.ts +299 -0
  264. package/src/core/text-rendering/canvas/draw.ts +165 -0
  265. package/src/core/text-rendering/sdf/Utils.test.ts +402 -0
  266. package/src/core/text-rendering/sdf/Utils.ts +436 -0
  267. package/src/core/text-rendering/{renderers/SdfTextRenderer/internal/constants.ts → sdf/index.ts} +20 -32
  268. package/src/core/textures/ColorTexture.ts +102 -102
  269. package/src/core/textures/ImageTexture.ts +418 -400
  270. package/src/core/textures/NoiseTexture.ts +104 -104
  271. package/src/core/textures/RenderTexture.ts +85 -85
  272. package/src/core/textures/SubTexture.ts +205 -205
  273. package/src/core/textures/Texture.ts +381 -376
  274. package/src/core/utils.ts +227 -227
  275. package/src/env.d.ts +7 -7
  276. package/src/main-api/INode.ts +100 -101
  277. package/src/main-api/Inspector.ts +567 -522
  278. package/src/main-api/Renderer.ts +873 -807
  279. package/src/main-api/utils.ts +45 -45
  280. package/src/utils.ts +267 -248
  281. package/dist/src/core/platform.d.ts +0 -10
  282. package/dist/src/core/platform.js +0 -81
  283. package/dist/src/core/platform.js.map +0 -1
  284. package/dist/src/core/renderers/CoreShader.d.ts +0 -9
  285. package/dist/src/core/renderers/CoreShader.js.map +0 -1
  286. package/dist/src/core/renderers/canvas/CanvasCoreRenderer.d.ts +0 -33
  287. package/dist/src/core/renderers/canvas/CanvasCoreRenderer.js +0 -250
  288. package/dist/src/core/renderers/canvas/CanvasCoreRenderer.js.map +0 -1
  289. package/dist/src/core/renderers/canvas/CanvasCoreTexture.d.ts +0 -16
  290. package/dist/src/core/renderers/canvas/CanvasCoreTexture.js +0 -124
  291. package/dist/src/core/renderers/canvas/CanvasCoreTexture.js.map +0 -1
  292. package/dist/src/core/renderers/canvas/shaders/UnsupportedShader.d.ts +0 -10
  293. package/dist/src/core/renderers/canvas/shaders/UnsupportedShader.js +0 -43
  294. package/dist/src/core/renderers/canvas/shaders/UnsupportedShader.js.map +0 -1
  295. package/dist/src/core/renderers/webgl/WebGlCoreCtxRenderTexture.d.ts +0 -12
  296. package/dist/src/core/renderers/webgl/WebGlCoreCtxRenderTexture.js +0 -58
  297. package/dist/src/core/renderers/webgl/WebGlCoreCtxRenderTexture.js.map +0 -1
  298. package/dist/src/core/renderers/webgl/WebGlCoreCtxSubTexture.d.ts +0 -9
  299. package/dist/src/core/renderers/webgl/WebGlCoreCtxSubTexture.js +0 -38
  300. package/dist/src/core/renderers/webgl/WebGlCoreCtxSubTexture.js.map +0 -1
  301. package/dist/src/core/renderers/webgl/WebGlCoreCtxTexture.d.ts +0 -56
  302. package/dist/src/core/renderers/webgl/WebGlCoreCtxTexture.js +0 -239
  303. package/dist/src/core/renderers/webgl/WebGlCoreCtxTexture.js.map +0 -1
  304. package/dist/src/core/renderers/webgl/WebGlCoreRenderOp.d.ts +0 -34
  305. package/dist/src/core/renderers/webgl/WebGlCoreRenderOp.js +0 -114
  306. package/dist/src/core/renderers/webgl/WebGlCoreRenderOp.js.map +0 -1
  307. package/dist/src/core/renderers/webgl/WebGlCoreRenderer.d.ts +0 -133
  308. package/dist/src/core/renderers/webgl/WebGlCoreRenderer.js +0 -616
  309. package/dist/src/core/renderers/webgl/WebGlCoreRenderer.js.map +0 -1
  310. package/dist/src/core/renderers/webgl/WebGlCoreShader.d.ts +0 -83
  311. package/dist/src/core/renderers/webgl/WebGlCoreShader.js +0 -233
  312. package/dist/src/core/renderers/webgl/WebGlCoreShader.js.map +0 -1
  313. package/dist/src/core/renderers/webgl/shaders/DefaultShader.d.ts +0 -9
  314. package/dist/src/core/renderers/webgl/shaders/DefaultShader.js +0 -87
  315. package/dist/src/core/renderers/webgl/shaders/DefaultShader.js.map +0 -1
  316. package/dist/src/core/renderers/webgl/shaders/DefaultShaderBatched.d.ts +0 -10
  317. package/dist/src/core/renderers/webgl/shaders/DefaultShaderBatched.js +0 -119
  318. package/dist/src/core/renderers/webgl/shaders/DefaultShaderBatched.js.map +0 -1
  319. package/dist/src/core/renderers/webgl/shaders/DynamicShader.d.ts +0 -29
  320. package/dist/src/core/renderers/webgl/shaders/DynamicShader.js +0 -413
  321. package/dist/src/core/renderers/webgl/shaders/DynamicShader.js.map +0 -1
  322. package/dist/src/core/renderers/webgl/shaders/RoundedRectangle.d.ts +0 -28
  323. package/dist/src/core/renderers/webgl/shaders/RoundedRectangle.js +0 -131
  324. package/dist/src/core/renderers/webgl/shaders/RoundedRectangle.js.map +0 -1
  325. package/dist/src/core/renderers/webgl/shaders/SdfShader.d.ts +0 -47
  326. package/dist/src/core/renderers/webgl/shaders/SdfShader.js +0 -160
  327. package/dist/src/core/renderers/webgl/shaders/SdfShader.js.map +0 -1
  328. package/dist/src/core/renderers/webgl/shaders/effects/BorderBottomEffect.d.ts +0 -31
  329. package/dist/src/core/renderers/webgl/shaders/effects/BorderBottomEffect.js +0 -71
  330. package/dist/src/core/renderers/webgl/shaders/effects/BorderBottomEffect.js.map +0 -1
  331. package/dist/src/core/renderers/webgl/shaders/effects/BorderEffect.d.ts +0 -30
  332. package/dist/src/core/renderers/webgl/shaders/effects/BorderEffect.js +0 -58
  333. package/dist/src/core/renderers/webgl/shaders/effects/BorderEffect.js.map +0 -1
  334. package/dist/src/core/renderers/webgl/shaders/effects/BorderLeftEffect.d.ts +0 -31
  335. package/dist/src/core/renderers/webgl/shaders/effects/BorderLeftEffect.js +0 -71
  336. package/dist/src/core/renderers/webgl/shaders/effects/BorderLeftEffect.js.map +0 -1
  337. package/dist/src/core/renderers/webgl/shaders/effects/BorderRightEffect.d.ts +0 -31
  338. package/dist/src/core/renderers/webgl/shaders/effects/BorderRightEffect.js +0 -71
  339. package/dist/src/core/renderers/webgl/shaders/effects/BorderRightEffect.js.map +0 -1
  340. package/dist/src/core/renderers/webgl/shaders/effects/BorderTopEffect.d.ts +0 -31
  341. package/dist/src/core/renderers/webgl/shaders/effects/BorderTopEffect.js +0 -71
  342. package/dist/src/core/renderers/webgl/shaders/effects/BorderTopEffect.js.map +0 -1
  343. package/dist/src/core/renderers/webgl/shaders/effects/EffectUtils.d.ts +0 -9
  344. package/dist/src/core/renderers/webgl/shaders/effects/EffectUtils.js +0 -136
  345. package/dist/src/core/renderers/webgl/shaders/effects/EffectUtils.js.map +0 -1
  346. package/dist/src/core/renderers/webgl/shaders/effects/FadeOutEffect.d.ts +0 -36
  347. package/dist/src/core/renderers/webgl/shaders/effects/FadeOutEffect.js +0 -85
  348. package/dist/src/core/renderers/webgl/shaders/effects/FadeOutEffect.js.map +0 -1
  349. package/dist/src/core/renderers/webgl/shaders/effects/GlitchEffect.d.ts +0 -45
  350. package/dist/src/core/renderers/webgl/shaders/effects/GlitchEffect.js +0 -104
  351. package/dist/src/core/renderers/webgl/shaders/effects/GlitchEffect.js.map +0 -1
  352. package/dist/src/core/renderers/webgl/shaders/effects/GrayscaleEffect.d.ts +0 -22
  353. package/dist/src/core/renderers/webgl/shaders/effects/GrayscaleEffect.js +0 -45
  354. package/dist/src/core/renderers/webgl/shaders/effects/GrayscaleEffect.js.map +0 -1
  355. package/dist/src/core/renderers/webgl/shaders/effects/HolePunchEffect.d.ts +0 -58
  356. package/dist/src/core/renderers/webgl/shaders/effects/HolePunchEffect.js +0 -80
  357. package/dist/src/core/renderers/webgl/shaders/effects/HolePunchEffect.js.map +0 -1
  358. package/dist/src/core/renderers/webgl/shaders/effects/LinearGradientEffect.d.ts +0 -35
  359. package/dist/src/core/renderers/webgl/shaders/effects/LinearGradientEffect.js +0 -129
  360. package/dist/src/core/renderers/webgl/shaders/effects/LinearGradientEffect.js.map +0 -1
  361. package/dist/src/core/renderers/webgl/shaders/effects/RadialGradientEffect.d.ts +0 -39
  362. package/dist/src/core/renderers/webgl/shaders/effects/RadialGradientEffect.js +0 -116
  363. package/dist/src/core/renderers/webgl/shaders/effects/RadialGradientEffect.js.map +0 -1
  364. package/dist/src/core/renderers/webgl/shaders/effects/RadialProgressEffect.d.ts +0 -61
  365. package/dist/src/core/renderers/webgl/shaders/effects/RadialProgressEffect.js +0 -127
  366. package/dist/src/core/renderers/webgl/shaders/effects/RadialProgressEffect.js.map +0 -1
  367. package/dist/src/core/renderers/webgl/shaders/effects/RadiusEffect.d.ts +0 -40
  368. package/dist/src/core/renderers/webgl/shaders/effects/RadiusEffect.js +0 -71
  369. package/dist/src/core/renderers/webgl/shaders/effects/RadiusEffect.js.map +0 -1
  370. package/dist/src/core/renderers/webgl/shaders/effects/ShaderEffect.d.ts +0 -115
  371. package/dist/src/core/renderers/webgl/shaders/effects/ShaderEffect.js +0 -61
  372. package/dist/src/core/renderers/webgl/shaders/effects/ShaderEffect.js.map +0 -1
  373. package/dist/src/core/shaders/templates/shaderUtils.d.ts +0 -5
  374. package/dist/src/core/shaders/templates/shaderUtils.js.map +0 -1
  375. package/dist/src/core/shaders/webgl/Spinner.d.ts +0 -1
  376. package/dist/src/core/shaders/webgl/Spinner.js +0 -2
  377. package/dist/src/core/shaders/webgl/Spinner.js.map +0 -1
  378. package/dist/src/core/text-rendering/sdf/PeekableGenerator.d.ts +0 -12
  379. package/dist/src/core/text-rendering/sdf/PeekableGenerator.js +0 -61
  380. package/dist/src/core/text-rendering/sdf/PeekableGenerator.js.map +0 -1
  381. package/dist/src/core/text-rendering/sdf/SimpleFontShaper.d.ts +0 -45
  382. package/dist/src/core/text-rendering/sdf/SimpleFontShaper.js +0 -69
  383. package/dist/src/core/text-rendering/sdf/SimpleFontShaper.js.map +0 -1
  384. package/dist/src/main-api/DynamicShaderController.d.ts +0 -29
  385. package/dist/src/main-api/DynamicShaderController.js +0 -58
  386. package/dist/src/main-api/DynamicShaderController.js.map +0 -1
  387. package/dist/src/main-api/ShaderController.d.ts +0 -31
  388. package/dist/src/main-api/ShaderController.js +0 -37
  389. package/dist/src/main-api/ShaderController.js.map +0 -1
  390. package/scripts/please-use-pnpm.js +0 -13
  391. package/src/core/platform.ts +0 -100
  392. package/src/core/renderers/CoreShader.ts +0 -41
  393. package/src/core/renderers/canvas/CanvasCoreRenderer.ts +0 -375
  394. package/src/core/renderers/canvas/internal/C2DShaderUtils.ts +0 -231
  395. package/src/core/renderers/canvas/shaders/UnsupportedShader.ts +0 -48
  396. package/src/core/renderers/webgl/WebGlCoreRenderOp.ts +0 -125
  397. package/src/core/renderers/webgl/WebGlCoreShader.ts +0 -365
  398. package/src/core/renderers/webgl/shaders/DefaultShader.ts +0 -93
  399. package/src/core/renderers/webgl/shaders/DefaultShaderBatched.ts +0 -132
  400. package/src/core/renderers/webgl/shaders/DynamicShader.ts +0 -580
  401. package/src/core/renderers/webgl/shaders/RoundedRectangle.ts +0 -167
  402. package/src/core/renderers/webgl/shaders/SdfShader.ts +0 -204
  403. package/src/core/renderers/webgl/shaders/effects/BorderBottomEffect.ts +0 -101
  404. package/src/core/renderers/webgl/shaders/effects/BorderEffect.ts +0 -87
  405. package/src/core/renderers/webgl/shaders/effects/BorderLeftEffect.ts +0 -101
  406. package/src/core/renderers/webgl/shaders/effects/BorderRightEffect.ts +0 -101
  407. package/src/core/renderers/webgl/shaders/effects/BorderTopEffect.ts +0 -101
  408. package/src/core/renderers/webgl/shaders/effects/EffectUtils.ts +0 -159
  409. package/src/core/renderers/webgl/shaders/effects/FadeOutEffect.ts +0 -127
  410. package/src/core/renderers/webgl/shaders/effects/GlitchEffect.ts +0 -148
  411. package/src/core/renderers/webgl/shaders/effects/GrayscaleEffect.ts +0 -67
  412. package/src/core/renderers/webgl/shaders/effects/HolePunchEffect.ts +0 -157
  413. package/src/core/renderers/webgl/shaders/effects/LinearGradientEffect.ts +0 -171
  414. package/src/core/renderers/webgl/shaders/effects/RadialGradientEffect.ts +0 -168
  415. package/src/core/renderers/webgl/shaders/effects/RadialProgressEffect.ts +0 -187
  416. package/src/core/renderers/webgl/shaders/effects/RadiusEffect.ts +0 -110
  417. package/src/core/renderers/webgl/shaders/effects/ShaderEffect.ts +0 -196
  418. package/src/core/text-rendering/TextRenderingUtils.ts +0 -36
  419. package/src/core/text-rendering/TrFontManager.ts +0 -183
  420. package/src/core/text-rendering/font-face-types/SdfTrFontFace/SdfTrFontFace.ts +0 -176
  421. package/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/FontShaper.ts +0 -139
  422. package/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/SdfFontShaper.test.ts +0 -173
  423. package/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/SdfFontShaper.ts +0 -171
  424. package/src/core/text-rendering/font-face-types/TrFontFace.ts +0 -187
  425. package/src/core/text-rendering/font-face-types/WebTrFontFace.ts +0 -94
  426. package/src/core/text-rendering/font-face-types/utils.ts +0 -39
  427. package/src/core/text-rendering/renderers/CanvasTextRenderer.ts +0 -509
  428. package/src/core/text-rendering/renderers/LightningTextTextureRenderer.ts +0 -808
  429. package/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.ts +0 -853
  430. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/PeekableGenerator.test.ts +0 -48
  431. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/PeekableGenerator.ts +0 -66
  432. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/SpecialCodepoints.ts +0 -52
  433. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/getStartConditions.ts +0 -117
  434. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/getUnicodeCodepoints.test.ts +0 -133
  435. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText.ts +0 -408
  436. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/measureText.test.ts +0 -49
  437. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/measureText.ts +0 -52
  438. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/setRenderWindow.test.ts +0 -205
  439. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/setRenderWindow.ts +0 -93
  440. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/util.ts +0 -40
  441. package/src/core/text-rendering/renderers/TextRenderer.ts +0 -557
  442. package/src/main-api/DynamicShaderController.ts +0 -104
  443. package/src/main-api/ShaderController.ts +0 -80
@@ -1,167 +0,0 @@
1
- /*
2
- * If not stated otherwise in this file or this component's LICENSE file the
3
- * following copyright and licenses apply:
4
- *
5
- * Copyright 2023 Comcast Cable Communications Management, LLC.
6
- *
7
- * Licensed under the Apache License, Version 2.0 (the License);
8
- * you may not use this file except in compliance with the License.
9
- * You may obtain a copy of the License at
10
- *
11
- * http://www.apache.org/licenses/LICENSE-2.0
12
- *
13
- * Unless required by applicable law or agreed to in writing, software
14
- * distributed under the License is distributed on an "AS IS" BASIS,
15
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16
- * See the License for the specific language governing permissions and
17
- * limitations under the License.
18
- */
19
-
20
- import type { WebGlCoreRenderer } from '../WebGlCoreRenderer.js';
21
- import {
22
- WebGlCoreShader,
23
- type DimensionsShaderProp,
24
- } from '../WebGlCoreShader.js';
25
- import type { WebGlCoreCtxTexture } from '../WebGlCoreCtxTexture.js';
26
- import type { ShaderProgramSources } from '../internal/ShaderUtils.js';
27
-
28
- /**
29
- * Properties of the {@link RoundedRectangle} shader
30
- */
31
- export interface RoundedRectangleProps extends DimensionsShaderProp {
32
- /**
33
- * Corner radius, in pixels, to cut out of the corners
34
- *
35
- * @defaultValue 10
36
- */
37
- radius?: number;
38
- }
39
-
40
- /**
41
- * Similar to the {@link DefaultShader} but cuts out 4 rounded rectangle corners
42
- * as defined by the specified corner {@link RoundedRectangleProps.radius}
43
- */
44
- export class RoundedRectangle extends WebGlCoreShader {
45
- constructor(renderer: WebGlCoreRenderer) {
46
- super({
47
- renderer,
48
- attributes: ['a_position', 'a_textureCoordinate', 'a_color'],
49
- uniforms: [
50
- { name: 'u_resolution', uniform: 'uniform2fv' },
51
- { name: 'u_pixelRatio', uniform: 'uniform1f' },
52
- { name: 'u_texture', uniform: 'uniform2f' },
53
- { name: 'u_dimensions', uniform: 'uniform2fv' },
54
- { name: 'u_radius', uniform: 'uniform1f' },
55
- ],
56
- });
57
- }
58
-
59
- static z$__type__Props: RoundedRectangleProps;
60
-
61
- static override resolveDefaults(
62
- props: RoundedRectangleProps,
63
- ): Required<RoundedRectangleProps> {
64
- return {
65
- radius: props.radius || 10,
66
- $dimensions: {
67
- width: 0,
68
- height: 0,
69
- },
70
- };
71
- }
72
-
73
- override bindTextures(textures: WebGlCoreCtxTexture[]) {
74
- const { glw } = this;
75
- glw.activeTexture(0);
76
- glw.bindTexture(textures[0]!.ctxTexture);
77
- }
78
-
79
- protected override bindProps(props: Required<RoundedRectangleProps>): void {
80
- const radiusFactor =
81
- Math.min(props.$dimensions.width, props.$dimensions.height) /
82
- (2.0 * props.radius);
83
- this.glw.uniform1f(
84
- this.getUniformLocation('u_radius'),
85
- props.radius * Math.min(radiusFactor, 1),
86
- );
87
- }
88
-
89
- override canBatchShaderProps(
90
- propsA: Required<RoundedRectangleProps>,
91
- propsB: Required<RoundedRectangleProps>,
92
- ): boolean {
93
- return (
94
- propsA.radius === propsB.radius &&
95
- propsA.$dimensions.width === propsB.$dimensions.width &&
96
- propsA.$dimensions.height === propsB.$dimensions.height
97
- );
98
- }
99
-
100
- static override shaderSources: ShaderProgramSources = {
101
- vertex: `
102
- # ifdef GL_FRAGMENT_PRECISION_HIGH
103
- precision highp float;
104
- # else
105
- precision mediump float;
106
- # endif
107
-
108
- attribute vec2 a_position;
109
- attribute vec2 a_textureCoordinate;
110
- attribute vec4 a_color;
111
- attribute float a_textureIndex;
112
- attribute float a_depth;
113
-
114
- uniform vec2 u_resolution;
115
- uniform float u_pixelRatio;
116
-
117
- varying vec4 v_color;
118
- varying vec2 v_textureCoordinate;
119
-
120
- void main() {
121
- vec2 normalized = a_position * u_pixelRatio / u_resolution;
122
- vec2 zero_two = normalized * 2.0;
123
- vec2 clip_space = zero_two - 1.0;
124
-
125
- // pass to fragment
126
- v_color = a_color;
127
- v_textureCoordinate = a_textureCoordinate;
128
-
129
- // flip y
130
- gl_Position = vec4(clip_space * vec2(1.0, -1.0), 0, 1);
131
- }
132
- `,
133
- fragment: `
134
- # ifdef GL_FRAGMENT_PRECISION_HIGH
135
- precision highp float;
136
- # else
137
- precision mediump float;
138
- # endif
139
-
140
- uniform vec2 u_resolution;
141
- uniform vec2 u_dimensions;
142
- uniform float u_radius;
143
- uniform sampler2D u_texture;
144
-
145
- varying vec4 v_color;
146
- varying vec2 v_textureCoordinate;
147
-
148
- float boxDist(vec2 p, vec2 size, float radius){
149
- size -= vec2(radius);
150
- vec2 d = abs(p) - size;
151
- return min(max(d.x, d.y), 0.0) + length(max(d, 0.0)) - radius;
152
- }
153
-
154
- float fillMask(float dist) {
155
- return clamp(-dist, 0.0, 1.0);
156
- }
157
-
158
- void main() {
159
- vec4 color = texture2D(u_texture, v_textureCoordinate) * v_color;
160
- vec2 halfDimensions = u_dimensions * 0.5;
161
-
162
- float d = boxDist(v_textureCoordinate.xy * u_dimensions - halfDimensions, halfDimensions + 0.5, u_radius);
163
- gl_FragColor = mix(vec4(0.0), color, fillMask(d));
164
- }
165
- `,
166
- };
167
- }
@@ -1,204 +0,0 @@
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
- import type { WebGlCoreCtxTexture } from '../WebGlCoreCtxTexture.js';
21
- import type { WebGlCoreRenderer } from '../WebGlCoreRenderer.js';
22
- import { WebGlCoreShader } from '../WebGlCoreShader.js';
23
- import type { ShaderProgramSources } from '../internal/ShaderUtils.js';
24
-
25
- const IDENTITY_MATRIX_3x3 = new Float32Array([1, 0, 0, 0, 1, 0, 0, 0, 1]);
26
-
27
- declare module '../../../CoreShaderManager.js' {
28
- interface ShaderMap {
29
- SdfShader: typeof SdfShader;
30
- }
31
- }
32
-
33
- /**
34
- * Properties of the {@link SdfShader}
35
- */
36
- export interface SdfShaderProps {
37
- transform?: Float32Array;
38
- scrollY?: number;
39
- /**
40
- * Color in RGBA format
41
- *
42
- * @remarks
43
- * Color channels must NOT be premultiplied by alpha for best blending results.
44
- */
45
- color?: number;
46
- size?: number;
47
- distanceRange?: number;
48
- debug?: boolean;
49
- }
50
- /**
51
- * SdfShader supports multi-channel and single-channel signed distance field textures.
52
- *
53
- * @remarks
54
- * This Shader is used by the {@link SdfTextRenderer}. Do not use thie Shader
55
- * directly. Instead create a Text Node and assign a SDF font family to it.
56
- *
57
- * @internalRemarks
58
- * The only thing this shader does to support multi-channel SDFs is to
59
- * add a median function to the fragment shader. If this one function call
60
- * ends up being a performance bottleneck we can always look at ways to
61
- * remove it.
62
- */
63
- export class SdfShader extends WebGlCoreShader {
64
- constructor(renderer: WebGlCoreRenderer) {
65
- super({
66
- renderer,
67
- attributes: ['a_position', 'a_textureCoordinate'],
68
- uniforms: [
69
- { name: 'u_resolution', uniform: 'uniform2fv' },
70
- { name: 'u_transform', uniform: 'uniformMatrix3fv' },
71
- { name: 'u_scrollY', uniform: 'uniform1f' },
72
- { name: 'u_pixelRatio', uniform: 'uniform1f' },
73
- { name: 'u_texture', uniform: 'uniform2f' },
74
- { name: 'u_color', uniform: 'uniform4fv' },
75
- { name: 'u_size', uniform: 'uniform1f' },
76
- { name: 'u_distanceRange', uniform: 'uniform1f' },
77
- { name: 'u_debug', uniform: 'uniform1i' },
78
- ],
79
- });
80
- }
81
-
82
- static z$__type__Props: SdfShaderProps;
83
-
84
- override bindTextures(textures: WebGlCoreCtxTexture[]) {
85
- const { glw } = this;
86
- glw.activeTexture(0);
87
- glw.bindTexture(textures[0]!.ctxTexture);
88
- }
89
-
90
- protected override bindProps(props: SdfShaderProps): void {
91
- const resolvedProps = SdfShader.resolveDefaults(props);
92
- for (const key in resolvedProps) {
93
- if (key === 'transform') {
94
- this.glw.uniformMatrix3fv(
95
- this.getUniformLocation('u_transform'),
96
- resolvedProps[key],
97
- );
98
- } else if (key === 'scrollY') {
99
- this.glw.uniform1f(
100
- this.getUniformLocation('u_scrollY'),
101
- resolvedProps[key],
102
- );
103
- } else if (key === 'color') {
104
- const components = getNormalizedRgbaComponents(resolvedProps.color);
105
- this.glw.uniform4fv(this.getUniformLocation('u_color'), components);
106
- } else if (key === 'size') {
107
- this.glw.uniform1f(
108
- this.getUniformLocation('u_size'),
109
- resolvedProps[key],
110
- );
111
- } else if (key === 'distanceRange') {
112
- this.glw.uniform1f(
113
- this.getUniformLocation('u_distanceRange'),
114
- resolvedProps[key],
115
- );
116
- } else if (key === 'debug') {
117
- this.glw.uniform1i(
118
- this.getUniformLocation('u_debug'),
119
- resolvedProps[key] ? 1 : 0,
120
- );
121
- }
122
- }
123
- }
124
-
125
- static override resolveDefaults(
126
- props: SdfShaderProps = {},
127
- ): Required<SdfShaderProps> {
128
- return {
129
- transform: props.transform ?? IDENTITY_MATRIX_3x3,
130
- scrollY: props.scrollY ?? 0,
131
- color: props.color ?? 0xffffffff,
132
- size: props.size ?? 16,
133
- distanceRange: props.distanceRange ?? 1.0,
134
- debug: props.debug ?? false,
135
- };
136
- }
137
-
138
- static override shaderSources: ShaderProgramSources = {
139
- vertex: `
140
- # ifdef GL_FRAGMENT_PRECISION_HIGH
141
- precision highp float;
142
- # else
143
- precision mediump float;
144
- # endif
145
- // an attribute is an input (in) to a vertex shader.
146
- // It will receive data from a buffer
147
- attribute vec2 a_position;
148
- attribute vec2 a_textureCoordinate;
149
-
150
- uniform vec2 u_resolution;
151
- uniform mat3 u_transform;
152
- uniform float u_scrollY;
153
- uniform float u_pixelRatio;
154
- uniform float u_size;
155
-
156
- varying vec2 v_texcoord;
157
-
158
- void main() {
159
- vec2 scrolledPosition = a_position * u_size - vec2(0, u_scrollY);
160
- vec2 transformedPosition = (u_transform * vec3(scrolledPosition, 1)).xy;
161
-
162
- // Calculate screen space with pixel ratio
163
- vec2 screenSpace = (transformedPosition * u_pixelRatio / u_resolution * 2.0 - 1.0) * vec2(1, -1);
164
-
165
- gl_Position = vec4(screenSpace, 0.0, 1.0);
166
- v_texcoord = a_textureCoordinate;
167
-
168
- }
169
- `,
170
- fragment: `
171
- # ifdef GL_FRAGMENT_PRECISION_HIGH
172
- precision highp float;
173
- # else
174
- precision mediump float;
175
- # endif
176
- uniform vec4 u_color;
177
- uniform sampler2D u_texture;
178
- uniform float u_distanceRange;
179
- uniform float u_pixelRatio;
180
- uniform int u_debug;
181
-
182
- varying vec2 v_texcoord;
183
-
184
- float median(float r, float g, float b) {
185
- return max(min(r, g), min(max(r, g), b));
186
- }
187
-
188
- void main() {
189
- vec3 sample = texture2D(u_texture, v_texcoord).rgb;
190
- if (u_debug == 1) {
191
- gl_FragColor = vec4(sample.r, sample.g, sample.b, 1.0);
192
- return;
193
- }
194
- float scaledDistRange = u_distanceRange * u_pixelRatio;
195
- float sigDist = scaledDistRange * (median(sample.r, sample.g, sample.b) - 0.5);
196
- float opacity = clamp(sigDist + 0.5, 0.0, 1.0) * u_color.a;
197
-
198
- // Build the final color.
199
- // IMPORTANT: We must premultiply the color by the alpha value before returning it.
200
- gl_FragColor = vec4(u_color.r * opacity, u_color.g * opacity, u_color.b * opacity, opacity);
201
- }
202
- `,
203
- };
204
- }
@@ -1,101 +0,0 @@
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 { updateShaderEffectColor } from './EffectUtils.js';
20
- import {
21
- ShaderEffect,
22
- type DefaultEffectProps,
23
- type ShaderEffectUniforms,
24
- } from './ShaderEffect.js';
25
-
26
- /**
27
- * Properties of the {@link BorderBottomEffect} effect
28
- */
29
- export interface BorderBottomEffectProps extends DefaultEffectProps {
30
- /**
31
- * Width of the border in pixels
32
- *
33
- * @default 10
34
- */
35
- width?: number;
36
- /**
37
- * Color of the border in 0xRRGGBBAA
38
- *
39
- * @default 0xffffffff
40
- */
41
- color?: number;
42
- }
43
-
44
- /**
45
- * The BorderBottomEffect renders a border on the bottom side of an element
46
- */
47
- export class BorderBottomEffect extends ShaderEffect {
48
- static z$__type__Props: BorderBottomEffectProps;
49
- override readonly name = 'borderBottom';
50
-
51
- static override getEffectKey(): string {
52
- return `borderBottom`;
53
- }
54
-
55
- static override resolveDefaults(
56
- props: BorderBottomEffectProps,
57
- ): Required<BorderBottomEffectProps> {
58
- return {
59
- width: props.width ?? 10,
60
- color: props.color ?? 0xffffffff,
61
- };
62
- }
63
-
64
- static override uniforms: ShaderEffectUniforms = {
65
- width: {
66
- value: 0,
67
- method: 'uniform1f',
68
- type: 'float',
69
- },
70
- color: {
71
- value: 0xffffffff,
72
- updateProgramValue: updateShaderEffectColor,
73
- method: 'uniform4fv',
74
- type: 'vec4',
75
- },
76
- };
77
-
78
- static override methods: Record<string, string> = {
79
- fillMask: `
80
- float function(float dist) {
81
- return clamp(-dist, 0.0, 1.0);
82
- }
83
- `,
84
- rectDist: `
85
- float function(vec2 p, vec2 size) {
86
- vec2 d = abs(p) - size;
87
- return min(max(d.x, d.y), 0.0) + length(max(d, 0.0));
88
- }
89
- `,
90
- };
91
-
92
- static override onEffectMask = `
93
- vec2 pos = vec2(0.0, u_dimensions.y - width * 0.5);
94
- float mask = $rectDist(v_textureCoordinate.xy * u_dimensions - pos, vec2(u_dimensions.x, width*0.5));
95
- return mix(shaderColor, maskColor, $fillMask(mask));
96
- `;
97
-
98
- static override onColorize = `
99
- return color;
100
- `;
101
- }
@@ -1,87 +0,0 @@
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 { updateShaderEffectColor } from './EffectUtils.js';
20
- import {
21
- ShaderEffect,
22
- type DefaultEffectProps,
23
- type ShaderEffectUniforms,
24
- } from './ShaderEffect.js';
25
-
26
- /**
27
- * Properties of the {@link BorderEffect} effect
28
- */
29
- export interface BorderEffectProps extends DefaultEffectProps {
30
- /**
31
- * Width of the border in pixels
32
- *
33
- * @default 10
34
- */
35
- width?: number;
36
- /**
37
- * Color of the border in 0xRRGGBBAA
38
- *
39
- * @default 0xffffffff
40
- */
41
- color?: number;
42
- }
43
-
44
- /**
45
- * The BorderEffect renders a border along all edges of an element
46
- */
47
- export class BorderEffect extends ShaderEffect {
48
- static z$__type__Props: BorderEffectProps;
49
- override readonly name = 'border';
50
-
51
- static override getEffectKey(): string {
52
- return `border`;
53
- }
54
-
55
- static override resolveDefaults(
56
- props: BorderEffectProps,
57
- ): Required<BorderEffectProps> {
58
- return {
59
- width: props.width ?? 10,
60
- color: props.color ?? 0xffffffff,
61
- };
62
- }
63
-
64
- static override uniforms: ShaderEffectUniforms = {
65
- width: {
66
- value: 0,
67
- method: 'uniform1f',
68
- type: 'float',
69
- },
70
- color: {
71
- value: 0xffffffff,
72
- updateProgramValue: updateShaderEffectColor,
73
- method: 'uniform4fv',
74
- type: 'vec4',
75
- },
76
- };
77
-
78
- static override onEffectMask = `
79
- float intR = shaderMask + 1.0;
80
- float mask = clamp(intR + width, 0.0, 1.0) - clamp(intR, 0.0, 1.0);
81
- return mix(shaderColor, mix(shaderColor, maskColor, maskColor.a), mask);
82
- `;
83
-
84
- static override onColorize = `
85
- return color;
86
- `;
87
- }
@@ -1,101 +0,0 @@
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 { updateShaderEffectColor } from './EffectUtils.js';
20
- import {
21
- ShaderEffect,
22
- type DefaultEffectProps,
23
- type ShaderEffectUniforms,
24
- } from './ShaderEffect.js';
25
-
26
- /**
27
- * Properties of the {@link BorderLeftEffect} effect
28
- */
29
- export interface BorderLeftEffectProps extends DefaultEffectProps {
30
- /**
31
- * Width of the border in pixels
32
- *
33
- * @default 10
34
- */
35
- width?: number;
36
- /**
37
- * Color of the border in 0xRRGGBBAA
38
- *
39
- * @default 0xffffffff
40
- */
41
- color?: number;
42
- }
43
-
44
- /**
45
- * The BorderBottomEffect renders a border on the left of an element
46
- */
47
- export class BorderLeftEffect extends ShaderEffect {
48
- static z$__type__Props: BorderLeftEffectProps;
49
- override readonly name = 'borderLeft';
50
-
51
- static override getEffectKey(): string {
52
- return `borderLeft`;
53
- }
54
-
55
- static override resolveDefaults(
56
- props: BorderLeftEffectProps,
57
- ): Required<BorderLeftEffectProps> {
58
- return {
59
- width: props.width ?? 10,
60
- color: props.color ?? 0xffffffff,
61
- };
62
- }
63
-
64
- static override uniforms: ShaderEffectUniforms = {
65
- width: {
66
- value: 0,
67
- method: 'uniform1f',
68
- type: 'float',
69
- },
70
- color: {
71
- value: 0xffffffff,
72
- updateProgramValue: updateShaderEffectColor,
73
- method: 'uniform4fv',
74
- type: 'vec4',
75
- },
76
- };
77
-
78
- static override methods: Record<string, string> = {
79
- fillMask: `
80
- float function(float dist) {
81
- return clamp(-dist, 0.0, 1.0);
82
- }
83
- `,
84
- rectDist: `
85
- float function(vec2 p, vec2 size) {
86
- vec2 d = abs(p) - size;
87
- return min(max(d.x, d.y), 0.0) + length(max(d, 0.0));
88
- }
89
- `,
90
- };
91
-
92
- static override onEffectMask = `
93
- vec2 pos = vec2(width * 0.5, 0.0);
94
- float mask = $rectDist(v_textureCoordinate.xy * u_dimensions - pos, vec2(width*0.5, u_dimensions.y));
95
- return mix(shaderColor, maskColor, $fillMask(mask));
96
- `;
97
-
98
- static override onColorize = `
99
- return color;
100
- `;
101
- }