@lightningjs/renderer 2.16.0 → 2.18.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (257) hide show
  1. package/dist/src/core/CoreNode.js +7 -5
  2. package/dist/src/core/CoreNode.js.map +1 -1
  3. package/dist/src/core/CoreTextureManager.d.ts +14 -8
  4. package/dist/src/core/CoreTextureManager.js +33 -59
  5. package/dist/src/core/CoreTextureManager.js.map +1 -1
  6. package/dist/src/core/Stage.d.ts +3 -3
  7. package/dist/src/core/Stage.js +9 -14
  8. package/dist/src/core/Stage.js.map +1 -1
  9. package/dist/src/core/TextureMemoryManager.d.ts +21 -17
  10. package/dist/src/core/TextureMemoryManager.js +99 -124
  11. package/dist/src/core/TextureMemoryManager.js.map +1 -1
  12. package/dist/src/core/lib/WebGlContextWrapper.d.ts +10 -0
  13. package/dist/src/core/lib/WebGlContextWrapper.js +32 -0
  14. package/dist/src/core/lib/WebGlContextWrapper.js.map +1 -1
  15. package/dist/src/core/lib/textureCompression.js +13 -6
  16. package/dist/src/core/lib/textureCompression.js.map +1 -1
  17. package/dist/src/core/platform.js +4 -1
  18. package/dist/src/core/platform.js.map +1 -1
  19. package/dist/src/core/renderers/CoreContextTexture.d.ts +1 -0
  20. package/dist/src/core/renderers/CoreContextTexture.js.map +1 -1
  21. package/dist/src/core/renderers/canvas/CanvasCoreTexture.d.ts +1 -0
  22. package/dist/src/core/renderers/canvas/CanvasCoreTexture.js +4 -3
  23. package/dist/src/core/renderers/canvas/CanvasCoreTexture.js.map +1 -1
  24. package/dist/src/core/renderers/webgl/WebGlCoreCtxTexture.d.ts +9 -0
  25. package/dist/src/core/renderers/webgl/WebGlCoreCtxTexture.js +59 -29
  26. package/dist/src/core/renderers/webgl/WebGlCoreCtxTexture.js.map +1 -1
  27. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.js +4 -4
  28. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.js.map +1 -1
  29. package/dist/src/core/textures/ColorTexture.d.ts +2 -2
  30. package/dist/src/core/textures/ColorTexture.js +1 -2
  31. package/dist/src/core/textures/ColorTexture.js.map +1 -1
  32. package/dist/src/core/textures/ImageTexture.d.ts +7 -1
  33. package/dist/src/core/textures/ImageTexture.js +55 -39
  34. package/dist/src/core/textures/ImageTexture.js.map +1 -1
  35. package/dist/src/core/textures/NoiseTexture.js +1 -1
  36. package/dist/src/core/textures/NoiseTexture.js.map +1 -1
  37. package/dist/src/core/textures/RenderTexture.js +1 -1
  38. package/dist/src/core/textures/RenderTexture.js.map +1 -1
  39. package/dist/src/core/textures/SubTexture.d.ts +1 -2
  40. package/dist/src/core/textures/SubTexture.js +11 -29
  41. package/dist/src/core/textures/SubTexture.js.map +1 -1
  42. package/dist/src/core/textures/Texture.d.ts +51 -7
  43. package/dist/src/core/textures/Texture.js +127 -15
  44. package/dist/src/core/textures/Texture.js.map +1 -1
  45. package/dist/src/main-api/Inspector.d.ts +3 -0
  46. package/dist/src/main-api/Inspector.js +156 -0
  47. package/dist/src/main-api/Inspector.js.map +1 -1
  48. package/dist/src/main-api/Renderer.d.ts +1 -3
  49. package/dist/src/main-api/Renderer.js +2 -4
  50. package/dist/src/main-api/Renderer.js.map +1 -1
  51. package/dist/tsconfig.dist.tsbuildinfo +1 -1
  52. package/package.json +1 -1
  53. package/src/core/CoreNode.ts +8 -4
  54. package/src/core/CoreTextureManager.ts +59 -65
  55. package/src/core/Stage.ts +10 -16
  56. package/src/core/TextureMemoryManager.ts +118 -148
  57. package/src/core/lib/WebGlContextWrapper.ts +38 -0
  58. package/src/core/lib/textureCompression.ts +18 -7
  59. package/src/core/platform.ts +5 -1
  60. package/src/core/renderers/CoreContextTexture.ts +1 -0
  61. package/src/core/renderers/canvas/CanvasCoreTexture.ts +5 -3
  62. package/src/core/renderers/webgl/WebGlCoreCtxTexture.ts +78 -40
  63. package/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.ts +10 -4
  64. package/src/core/textures/ColorTexture.ts +4 -7
  65. package/src/core/textures/ImageTexture.ts +66 -51
  66. package/src/core/textures/NoiseTexture.ts +1 -1
  67. package/src/core/textures/RenderTexture.ts +1 -1
  68. package/src/core/textures/SubTexture.ts +14 -31
  69. package/src/core/textures/Texture.ts +150 -21
  70. package/src/main-api/Inspector.ts +203 -0
  71. package/src/main-api/Renderer.ts +2 -4
  72. package/dist/exports/canvas-shaders.d.ts +0 -10
  73. package/dist/exports/canvas-shaders.js +0 -27
  74. package/dist/exports/canvas-shaders.js.map +0 -1
  75. package/dist/exports/webgl-shaders.d.ts +0 -11
  76. package/dist/exports/webgl-shaders.js +0 -28
  77. package/dist/exports/webgl-shaders.js.map +0 -1
  78. package/dist/src/core/platforms/Platform.d.ts +0 -37
  79. package/dist/src/core/platforms/Platform.js +0 -22
  80. package/dist/src/core/platforms/Platform.js.map +0 -1
  81. package/dist/src/core/platforms/web/WebPlatform.d.ts +0 -9
  82. package/dist/src/core/platforms/web/WebPlatform.js +0 -58
  83. package/dist/src/core/platforms/web/WebPlatform.js.map +0 -1
  84. package/dist/src/core/renderers/CoreShaderNode.d.ts +0 -59
  85. package/dist/src/core/renderers/CoreShaderNode.js +0 -113
  86. package/dist/src/core/renderers/CoreShaderNode.js.map +0 -1
  87. package/dist/src/core/renderers/CoreShaderProgram.d.ts +0 -4
  88. package/dist/src/core/renderers/CoreShaderProgram.js +0 -20
  89. package/dist/src/core/renderers/CoreShaderProgram.js.map +0 -1
  90. package/dist/src/core/renderers/canvas/CanvasRenderer.d.ts +0 -37
  91. package/dist/src/core/renderers/canvas/CanvasRenderer.js +0 -215
  92. package/dist/src/core/renderers/canvas/CanvasRenderer.js.map +0 -1
  93. package/dist/src/core/renderers/canvas/CanvasShaderNode.d.ts +0 -21
  94. package/dist/src/core/renderers/canvas/CanvasShaderNode.js +0 -57
  95. package/dist/src/core/renderers/canvas/CanvasShaderNode.js.map +0 -1
  96. package/dist/src/core/renderers/canvas/CanvasTexture.d.ts +0 -16
  97. package/dist/src/core/renderers/canvas/CanvasTexture.js +0 -124
  98. package/dist/src/core/renderers/canvas/CanvasTexture.js.map +0 -1
  99. package/dist/src/core/renderers/webgl/WebGlCtxRenderTexture.d.ts +0 -12
  100. package/dist/src/core/renderers/webgl/WebGlCtxRenderTexture.js +0 -55
  101. package/dist/src/core/renderers/webgl/WebGlCtxRenderTexture.js.map +0 -1
  102. package/dist/src/core/renderers/webgl/WebGlCtxSubTexture.d.ts +0 -9
  103. package/dist/src/core/renderers/webgl/WebGlCtxSubTexture.js +0 -38
  104. package/dist/src/core/renderers/webgl/WebGlCtxSubTexture.js.map +0 -1
  105. package/dist/src/core/renderers/webgl/WebGlCtxTexture.d.ts +0 -57
  106. package/dist/src/core/renderers/webgl/WebGlCtxTexture.js +0 -224
  107. package/dist/src/core/renderers/webgl/WebGlCtxTexture.js.map +0 -1
  108. package/dist/src/core/renderers/webgl/WebGlRenderOp.d.ts +0 -44
  109. package/dist/src/core/renderers/webgl/WebGlRenderOp.js +0 -125
  110. package/dist/src/core/renderers/webgl/WebGlRenderOp.js.map +0 -1
  111. package/dist/src/core/renderers/webgl/WebGlRenderer.d.ts +0 -136
  112. package/dist/src/core/renderers/webgl/WebGlRenderer.js +0 -573
  113. package/dist/src/core/renderers/webgl/WebGlRenderer.js.map +0 -1
  114. package/dist/src/core/renderers/webgl/WebGlShaderNode.d.ts +0 -222
  115. package/dist/src/core/renderers/webgl/WebGlShaderNode.js +0 -331
  116. package/dist/src/core/renderers/webgl/WebGlShaderNode.js.map +0 -1
  117. package/dist/src/core/renderers/webgl/WebGlShaderProgram.d.ts +0 -35
  118. package/dist/src/core/renderers/webgl/WebGlShaderProgram.js +0 -201
  119. package/dist/src/core/renderers/webgl/WebGlShaderProgram.js.map +0 -1
  120. package/dist/src/core/shaders/canvas/Border.d.ts +0 -9
  121. package/dist/src/core/shaders/canvas/Border.js +0 -57
  122. package/dist/src/core/shaders/canvas/Border.js.map +0 -1
  123. package/dist/src/core/shaders/canvas/HolePunch.d.ts +0 -7
  124. package/dist/src/core/shaders/canvas/HolePunch.js +0 -38
  125. package/dist/src/core/shaders/canvas/HolePunch.js.map +0 -1
  126. package/dist/src/core/shaders/canvas/LinearGradient.d.ts +0 -10
  127. package/dist/src/core/shaders/canvas/LinearGradient.js +0 -48
  128. package/dist/src/core/shaders/canvas/LinearGradient.js.map +0 -1
  129. package/dist/src/core/shaders/canvas/RadialGradient.d.ts +0 -11
  130. package/dist/src/core/shaders/canvas/RadialGradient.js +0 -70
  131. package/dist/src/core/shaders/canvas/RadialGradient.js.map +0 -1
  132. package/dist/src/core/shaders/canvas/Rounded.d.ts +0 -7
  133. package/dist/src/core/shaders/canvas/Rounded.js +0 -33
  134. package/dist/src/core/shaders/canvas/Rounded.js.map +0 -1
  135. package/dist/src/core/shaders/canvas/RoundedWithBorder.d.ts +0 -7
  136. package/dist/src/core/shaders/canvas/RoundedWithBorder.js +0 -43
  137. package/dist/src/core/shaders/canvas/RoundedWithBorder.js.map +0 -1
  138. package/dist/src/core/shaders/canvas/RoundedWithBorderAndShadow.d.ts +0 -8
  139. package/dist/src/core/shaders/canvas/RoundedWithBorderAndShadow.js +0 -41
  140. package/dist/src/core/shaders/canvas/RoundedWithBorderAndShadow.js.map +0 -1
  141. package/dist/src/core/shaders/canvas/RoundedWithShadow.d.ts +0 -7
  142. package/dist/src/core/shaders/canvas/RoundedWithShadow.js +0 -40
  143. package/dist/src/core/shaders/canvas/RoundedWithShadow.js.map +0 -1
  144. package/dist/src/core/shaders/canvas/Shadow.d.ts +0 -8
  145. package/dist/src/core/shaders/canvas/Shadow.js +0 -31
  146. package/dist/src/core/shaders/canvas/Shadow.js.map +0 -1
  147. package/dist/src/core/shaders/canvas/utils/render.d.ts +0 -5
  148. package/dist/src/core/shaders/canvas/utils/render.js +0 -84
  149. package/dist/src/core/shaders/canvas/utils/render.js.map +0 -1
  150. package/dist/src/core/shaders/templates/BorderTemplate.d.ts +0 -37
  151. package/dist/src/core/shaders/templates/BorderTemplate.js +0 -73
  152. package/dist/src/core/shaders/templates/BorderTemplate.js.map +0 -1
  153. package/dist/src/core/shaders/templates/HolePunchTemplate.d.ts +0 -46
  154. package/dist/src/core/shaders/templates/HolePunchTemplate.js +0 -35
  155. package/dist/src/core/shaders/templates/HolePunchTemplate.js.map +0 -1
  156. package/dist/src/core/shaders/templates/LinearGradientTemplate.d.ts +0 -23
  157. package/dist/src/core/shaders/templates/LinearGradientTemplate.js +0 -47
  158. package/dist/src/core/shaders/templates/LinearGradientTemplate.js.map +0 -1
  159. package/dist/src/core/shaders/templates/RadialGradientTemplate.d.ts +0 -31
  160. package/dist/src/core/shaders/templates/RadialGradientTemplate.js +0 -49
  161. package/dist/src/core/shaders/templates/RadialGradientTemplate.js.map +0 -1
  162. package/dist/src/core/shaders/templates/RoundedTemplate.d.ts +0 -29
  163. package/dist/src/core/shaders/templates/RoundedTemplate.js +0 -67
  164. package/dist/src/core/shaders/templates/RoundedTemplate.js.map +0 -1
  165. package/dist/src/core/shaders/templates/RoundedWithBorderAndShadowTemplate.d.ts +0 -7
  166. package/dist/src/core/shaders/templates/RoundedWithBorderAndShadowTemplate.js +0 -24
  167. package/dist/src/core/shaders/templates/RoundedWithBorderAndShadowTemplate.js.map +0 -1
  168. package/dist/src/core/shaders/templates/RoundedWithBorderTemplate.d.ts +0 -6
  169. package/dist/src/core/shaders/templates/RoundedWithBorderTemplate.js +0 -23
  170. package/dist/src/core/shaders/templates/RoundedWithBorderTemplate.js.map +0 -1
  171. package/dist/src/core/shaders/templates/RoundedWithShadowTemplate.d.ts +0 -6
  172. package/dist/src/core/shaders/templates/RoundedWithShadowTemplate.js +0 -23
  173. package/dist/src/core/shaders/templates/RoundedWithShadowTemplate.js.map +0 -1
  174. package/dist/src/core/shaders/templates/ShadowTemplate.d.ts +0 -34
  175. package/dist/src/core/shaders/templates/ShadowTemplate.js +0 -66
  176. package/dist/src/core/shaders/templates/ShadowTemplate.js.map +0 -1
  177. package/dist/src/core/shaders/templates/shaderUtils.d.ts +0 -5
  178. package/dist/src/core/shaders/templates/shaderUtils.js +0 -41
  179. package/dist/src/core/shaders/templates/shaderUtils.js.map +0 -1
  180. package/dist/src/core/shaders/utils.d.ts +0 -5
  181. package/dist/src/core/shaders/utils.js +0 -41
  182. package/dist/src/core/shaders/utils.js.map +0 -1
  183. package/dist/src/core/shaders/webgl/Border.d.ts +0 -3
  184. package/dist/src/core/shaders/webgl/Border.js +0 -110
  185. package/dist/src/core/shaders/webgl/Border.js.map +0 -1
  186. package/dist/src/core/shaders/webgl/Default.d.ts +0 -2
  187. package/dist/src/core/shaders/webgl/Default.js +0 -86
  188. package/dist/src/core/shaders/webgl/Default.js.map +0 -1
  189. package/dist/src/core/shaders/webgl/DefaultBatched.d.ts +0 -2
  190. package/dist/src/core/shaders/webgl/DefaultBatched.js +0 -104
  191. package/dist/src/core/shaders/webgl/DefaultBatched.js.map +0 -1
  192. package/dist/src/core/shaders/webgl/HolePunch.d.ts +0 -3
  193. package/dist/src/core/shaders/webgl/HolePunch.js +0 -65
  194. package/dist/src/core/shaders/webgl/HolePunch.js.map +0 -1
  195. package/dist/src/core/shaders/webgl/LinearGradient.d.ts +0 -3
  196. package/dist/src/core/shaders/webgl/LinearGradient.js +0 -76
  197. package/dist/src/core/shaders/webgl/LinearGradient.js.map +0 -1
  198. package/dist/src/core/shaders/webgl/RadialGradient.d.ts +0 -3
  199. package/dist/src/core/shaders/webgl/RadialGradient.js +0 -74
  200. package/dist/src/core/shaders/webgl/RadialGradient.js.map +0 -1
  201. package/dist/src/core/shaders/webgl/Rounded.d.ts +0 -7
  202. package/dist/src/core/shaders/webgl/Rounded.js +0 -86
  203. package/dist/src/core/shaders/webgl/Rounded.js.map +0 -1
  204. package/dist/src/core/shaders/webgl/RoundedWithBorder.d.ts +0 -3
  205. package/dist/src/core/shaders/webgl/RoundedWithBorder.js +0 -140
  206. package/dist/src/core/shaders/webgl/RoundedWithBorder.js.map +0 -1
  207. package/dist/src/core/shaders/webgl/RoundedWithBorderAndShadow.d.ts +0 -3
  208. package/dist/src/core/shaders/webgl/RoundedWithBorderAndShadow.js +0 -162
  209. package/dist/src/core/shaders/webgl/RoundedWithBorderAndShadow.js.map +0 -1
  210. package/dist/src/core/shaders/webgl/RoundedWithShadow.d.ts +0 -3
  211. package/dist/src/core/shaders/webgl/RoundedWithShadow.js +0 -84
  212. package/dist/src/core/shaders/webgl/RoundedWithShadow.js.map +0 -1
  213. package/dist/src/core/shaders/webgl/SdfShader.d.ts +0 -32
  214. package/dist/src/core/shaders/webgl/SdfShader.js +0 -116
  215. package/dist/src/core/shaders/webgl/SdfShader.js.map +0 -1
  216. package/dist/src/core/shaders/webgl/Shadow.d.ts +0 -3
  217. package/dist/src/core/shaders/webgl/Shadow.js +0 -110
  218. package/dist/src/core/shaders/webgl/Shadow.js.map +0 -1
  219. package/dist/src/core/shaders/webgl/Spinner.d.ts +0 -1
  220. package/dist/src/core/shaders/webgl/Spinner.js +0 -2
  221. package/dist/src/core/shaders/webgl/Spinner.js.map +0 -1
  222. package/dist/src/core/text-rendering/CanvasFontHandler.d.ts +0 -25
  223. package/dist/src/core/text-rendering/CanvasFontHandler.js +0 -117
  224. package/dist/src/core/text-rendering/CanvasFontHandler.js.map +0 -1
  225. package/dist/src/core/text-rendering/CanvasTextRenderer.d.ts +0 -6
  226. package/dist/src/core/text-rendering/CanvasTextRenderer.js +0 -139
  227. package/dist/src/core/text-rendering/CanvasTextRenderer.js.map +0 -1
  228. package/dist/src/core/text-rendering/SdfFontHandler.d.ts +0 -137
  229. package/dist/src/core/text-rendering/SdfFontHandler.js +0 -336
  230. package/dist/src/core/text-rendering/SdfFontHandler.js.map +0 -1
  231. package/dist/src/core/text-rendering/SdfTextRenderer.d.ts +0 -21
  232. package/dist/src/core/text-rendering/SdfTextRenderer.js +0 -324
  233. package/dist/src/core/text-rendering/SdfTextRenderer.js.map +0 -1
  234. package/dist/src/core/text-rendering/TextRenderer.d.ts +0 -425
  235. package/dist/src/core/text-rendering/TextRenderer.js +0 -70
  236. package/dist/src/core/text-rendering/TextRenderer.js.map +0 -1
  237. package/dist/src/core/text-rendering/Utils.d.ts +0 -71
  238. package/dist/src/core/text-rendering/Utils.js +0 -212
  239. package/dist/src/core/text-rendering/Utils.js.map +0 -1
  240. package/dist/src/core/text-rendering/canvas/Settings.d.ts +0 -53
  241. package/dist/src/core/text-rendering/canvas/Settings.js +0 -20
  242. package/dist/src/core/text-rendering/canvas/Settings.js.map +0 -1
  243. package/dist/src/core/text-rendering/canvas/Utils.d.ts +0 -19
  244. package/dist/src/core/text-rendering/canvas/Utils.js +0 -139
  245. package/dist/src/core/text-rendering/canvas/Utils.js.map +0 -1
  246. package/dist/src/core/text-rendering/canvas/calculateRenderInfo.d.ts +0 -37
  247. package/dist/src/core/text-rendering/canvas/calculateRenderInfo.js +0 -188
  248. package/dist/src/core/text-rendering/canvas/calculateRenderInfo.js.map +0 -1
  249. package/dist/src/core/text-rendering/canvas/draw.d.ts +0 -12
  250. package/dist/src/core/text-rendering/canvas/draw.js +0 -133
  251. package/dist/src/core/text-rendering/canvas/draw.js.map +0 -1
  252. package/dist/src/core/text-rendering/sdf/PeekableGenerator.d.ts +0 -12
  253. package/dist/src/core/text-rendering/sdf/PeekableGenerator.js +0 -61
  254. package/dist/src/core/text-rendering/sdf/PeekableGenerator.js.map +0 -1
  255. package/dist/src/core/text-rendering/sdf/SimpleFontShaper.d.ts +0 -45
  256. package/dist/src/core/text-rendering/sdf/SimpleFontShaper.js +0 -69
  257. package/dist/src/core/text-rendering/sdf/SimpleFontShaper.js.map +0 -1
@@ -1,336 +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 2025 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 { TextRenderers, } from './TextRenderer.js';
20
- //global state variables for SdfFontHandler
21
- const fontCache = Object.create(null);
22
- const loadedFonts = new Set();
23
- const fontLoadPromises = new Map();
24
- let initialized = false;
25
- /**
26
- * Normalize font metrics to be in the range of 0 to 1
27
- */
28
- const normalizeMetrics = (metrics) => ({
29
- ascender: metrics.ascender / metrics.unitsPerEm,
30
- descender: metrics.descender / metrics.unitsPerEm,
31
- lineGap: metrics.lineGap / metrics.unitsPerEm,
32
- });
33
- /**
34
- * Build kerning lookup table for fast access
35
- * @param {Array} kernings - Kerning data from font
36
- * @returns {KerningTable} Optimized kerning lookup table
37
- */
38
- const buildKerningTable = (kernings) => {
39
- const kerningTable = {};
40
- let i = 0;
41
- const length = kernings.length;
42
- while (i < length) {
43
- const kerning = kernings[i];
44
- i++;
45
- if (kerning === undefined) {
46
- continue;
47
- }
48
- const second = kerning.second;
49
- let firsts = kerningTable[second];
50
- if (!firsts) {
51
- firsts = {};
52
- kerningTable[second] = firsts;
53
- }
54
- firsts[kerning.first] = kerning.amount;
55
- }
56
- return kerningTable;
57
- };
58
- /**
59
- * Build glyph map from font data for fast character lookup
60
- * @param {Array} chars - Character data from font
61
- * @returns {Map} Glyph map for character to glyph lookup
62
- */
63
- const buildGlyphMap = (chars) => {
64
- const glyphMap = new Map();
65
- let maxCharHeight = 0;
66
- let i = 0;
67
- const length = chars.length;
68
- while (i < length) {
69
- const glyph = chars[i];
70
- i++;
71
- if (glyph === undefined) {
72
- continue;
73
- }
74
- glyphMap.set(glyph.id, glyph);
75
- const charHeight = glyph.yoffset + glyph.height;
76
- if (charHeight > maxCharHeight) {
77
- maxCharHeight = charHeight;
78
- }
79
- }
80
- return glyphMap;
81
- };
82
- /**
83
- * Process font data and create optimized cache entry
84
- * @param {string} fontFamily - Font family name
85
- * @param {SdfFontData} fontData - Raw font data
86
- * @param {ImageTexture} atlasTexture - Atlas texture
87
- * @param {FontMetrics} metrics - Font metrics
88
- */
89
- const processFontData = (fontFamily, fontData, atlasTexture, metrics) => {
90
- // Build optimized data structures
91
- const glyphMap = buildGlyphMap(fontData.chars);
92
- const kernings = buildKerningTable(fontData.kernings);
93
- // Calculate max char height
94
- let maxCharHeight = 0;
95
- let i = 0;
96
- const length = fontData.chars.length;
97
- while (i < length) {
98
- const glyph = fontData.chars[i];
99
- if (glyph !== undefined) {
100
- const charHeight = glyph.yoffset + glyph.height;
101
- if (charHeight > maxCharHeight) {
102
- maxCharHeight = charHeight;
103
- }
104
- }
105
- i++;
106
- }
107
- // Determine metrics
108
- let normalizedMetrics;
109
- if (metrics !== undefined) {
110
- normalizedMetrics = normalizeMetrics(metrics);
111
- }
112
- else if (fontData.lightningMetrics !== undefined) {
113
- normalizedMetrics = normalizeMetrics(fontData.lightningMetrics);
114
- }
115
- else {
116
- console.warn(`Font metrics not found for SDF font ${fontFamily}. ` +
117
- 'Make sure you are using the latest version of the Lightning ' +
118
- '3 msdf-generator tool to generate your SDF fonts. Using default metrics.');
119
- // Use default metrics
120
- normalizedMetrics = {
121
- ascender: 0.8,
122
- descender: -0.2,
123
- lineGap: 0.2,
124
- };
125
- }
126
- // Cache processed data
127
- fontCache[fontFamily] = {
128
- data: fontData,
129
- glyphMap,
130
- kernings,
131
- atlasTexture,
132
- metrics: normalizedMetrics,
133
- maxCharHeight,
134
- };
135
- };
136
- /**
137
- * Check if the SDF font handler can render a font
138
- * @param {TrProps} trProps - Text rendering properties
139
- * @returns {boolean} True if the font can be rendered
140
- */
141
- export const canRenderFont = (trProps) => {
142
- return isFontLoaded(trProps.fontFamily);
143
- };
144
- /**
145
- * Load SDF font from JSON + PNG atlas
146
- * @param {Object} options - Font loading options
147
- * @param {string} options.fontFamily - Font family name
148
- * @param {string} options.fontUrl - JSON font data URL (atlasDataUrl)
149
- * @param {string} options.atlasUrl - PNG atlas texture URL
150
- * @param {FontMetrics} options.metrics - Optional font metrics
151
- */
152
- export const loadFont = async (stage, options) => {
153
- const { fontFamily, atlasUrl, atlasDataUrl, metrics } = options;
154
- // Early return if already loaded
155
- if (loadedFonts.has(fontFamily) === true) {
156
- return;
157
- }
158
- // Early return if already loading
159
- const existingPromise = fontLoadPromises.get(fontFamily);
160
- if (existingPromise !== undefined) {
161
- return existingPromise;
162
- }
163
- if (atlasDataUrl === undefined) {
164
- throw new Error(`Atlas data URL must be provided for SDF font: ${fontFamily}`);
165
- }
166
- // Create loading promise
167
- const loadPromise = (async () => {
168
- // Load font JSON data
169
- const response = await fetch(atlasDataUrl);
170
- if (!response.ok) {
171
- throw new Error(`Failed to load font data: ${response.statusText}`);
172
- }
173
- const fontData = (await response.json());
174
- if (!fontData || !fontData.chars) {
175
- throw new Error('Invalid SDF font data format');
176
- }
177
- // Atlas texture should be provided externally
178
- if (!atlasUrl) {
179
- throw new Error('Atlas texture must be provided for SDF fonts');
180
- }
181
- // Wait for atlas texture to load
182
- return new Promise((resolve, reject) => {
183
- // create new atlas texture using ImageTexture
184
- const atlasTexture = stage.txManager.createTexture('ImageTexture', {
185
- src: atlasUrl,
186
- });
187
- atlasTexture.preventCleanup = true; // Prevent automatic cleanup
188
- if (atlasTexture.state === 'loaded') {
189
- // If already loaded, process immediately
190
- processFontData(fontFamily, fontData, atlasTexture, metrics);
191
- loadedFonts.add(fontFamily);
192
- fontLoadPromises.delete(fontFamily);
193
- return resolve();
194
- }
195
- atlasTexture.on('loaded', () => {
196
- // Process and cache font data
197
- processFontData(fontFamily, fontData, atlasTexture, metrics);
198
- // Mark as loaded
199
- loadedFonts.add(fontFamily);
200
- fontLoadPromises.delete(fontFamily);
201
- resolve();
202
- });
203
- atlasTexture.on('failed', (error) => {
204
- // Cleanup on error
205
- fontLoadPromises.delete(fontFamily);
206
- if (fontCache[fontFamily]) {
207
- delete fontCache[fontFamily];
208
- }
209
- console.error(`Failed to load SDF font: ${fontFamily}`, error);
210
- reject(error);
211
- });
212
- atlasTexture.setRenderableOwner(stage, true);
213
- });
214
- })();
215
- fontLoadPromises.set(fontFamily, loadPromise);
216
- return loadPromise;
217
- };
218
- /**
219
- * Get the font families map for resolving fonts
220
- */
221
- export const getFontFamilies = () => {
222
- const families = {};
223
- // SDF fonts don't use the traditional FontFamilyMap structure
224
- // Return empty map since SDF fonts are handled differently
225
- return families;
226
- };
227
- /**
228
- * Initialize the SDF font handler
229
- */
230
- export const init = () => {
231
- if (initialized === true) {
232
- return;
233
- }
234
- initialized = true;
235
- };
236
- export const type = TextRenderers.sdf;
237
- /**
238
- * Check if a font is already loaded by font family
239
- */
240
- export const isFontLoaded = (fontFamily) => {
241
- return loadedFonts.has(fontFamily);
242
- };
243
- /**
244
- * Get normalized font metrics for a font family
245
- */
246
- export const getFontMetrics = (fontFamily,
247
- // eslint-disable-next-line @typescript-eslint/no-unused-vars
248
- _trProps) => {
249
- const cache = fontCache[fontFamily];
250
- return cache ? cache.metrics : null;
251
- };
252
- /**
253
- * Set font metrics for a font family
254
- */
255
- export const setFontMetrics = (fontFamily, metrics) => {
256
- const cache = fontCache[fontFamily];
257
- if (cache !== undefined) {
258
- cache.metrics = metrics;
259
- }
260
- };
261
- /**
262
- * Get glyph data for a character in a specific font
263
- * @param {string} fontFamily - Font family name
264
- * @param {number} codepoint - Character codepoint
265
- * @returns {Object|null} Glyph data or null if not found
266
- */
267
- export const getGlyph = (fontFamily, codepoint) => {
268
- const cache = fontCache[fontFamily];
269
- if (cache === undefined)
270
- return null;
271
- return cache.glyphMap.get(codepoint) || cache.glyphMap.get(63) || null; // 63 = '?'
272
- };
273
- /**
274
- * Get kerning value between two glyphs
275
- * @param {string} fontFamily - Font family name
276
- * @param {number} firstGlyph - First glyph ID
277
- * @param {number} secondGlyph - Second glyph ID
278
- * @returns {number} Kerning value or 0
279
- */
280
- export const getKerning = (fontFamily, firstGlyph, secondGlyph) => {
281
- const cache = fontCache[fontFamily];
282
- if (cache === undefined)
283
- return 0;
284
- const seconds = cache.kernings[secondGlyph];
285
- return seconds ? seconds[firstGlyph] || 0 : 0;
286
- };
287
- /**
288
- * Get atlas texture for a font family
289
- * @param {string} fontFamily - Font family name
290
- * @returns {ImageTexture|null} Atlas texture or null
291
- */
292
- export const getAtlas = (fontFamily) => {
293
- const cache = fontCache[fontFamily];
294
- return cache !== undefined ? cache.atlasTexture : null;
295
- };
296
- /**
297
- * Get font data for a font family
298
- * @param {string} fontFamily - Font family name
299
- * @returns {SdfFontData|null} Font data or null
300
- */
301
- export const getFontData = (fontFamily) => {
302
- const cache = fontCache[fontFamily];
303
- return cache !== undefined ? cache.data : null;
304
- };
305
- /**
306
- * Get maximum character height for a font family
307
- * @param {string} fontFamily - Font family name
308
- * @returns {number} Max character height or 0
309
- */
310
- export const getMaxCharHeight = (fontFamily) => {
311
- const cache = fontCache[fontFamily];
312
- return cache !== undefined ? cache.maxCharHeight : 0;
313
- };
314
- /**
315
- * Get all loaded font families
316
- * @returns {string[]} Array of font family names
317
- */
318
- export const getLoadedFonts = () => {
319
- return Array.from(loadedFonts);
320
- };
321
- /**
322
- * Unload a font and free resources
323
- * @param {string} fontFamily - Font family name
324
- */
325
- export const unloadFont = (fontFamily) => {
326
- const cache = fontCache[fontFamily];
327
- if (cache !== undefined) {
328
- // Free texture if needed
329
- if (typeof cache.atlasTexture.free === 'function') {
330
- cache.atlasTexture.free();
331
- }
332
- delete fontCache[fontFamily];
333
- loadedFonts.delete(fontFamily);
334
- }
335
- };
336
- //# sourceMappingURL=SdfFontHandler.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"SdfFontHandler.js","sourceRoot":"","sources":["../../../../src/core/text-rendering/SdfFontHandler.ts"],"names":[],"mappings":"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"}
@@ -1,21 +0,0 @@
1
- import type { Stage } from '../Stage.js';
2
- import { TextRenderers, type FontHandler, type TextRenderProps, type TrProps } from './TextRenderer.js';
3
- import type { CoreRenderer } from '../renderers/CoreRenderer.js';
4
- import type { TextLayout } from './TextRenderer.js';
5
- /**
6
- * SDF Text Renderer - implements TextRenderer interface
7
- */
8
- declare const SdfTextRenderer: {
9
- type: TextRenderers;
10
- font: FontHandler;
11
- renderText: (stage: Stage, props: TrProps) => {
12
- imageData: ImageData | null;
13
- width: number;
14
- height: number;
15
- layout?: TextLayout;
16
- };
17
- addQuads: (layout?: TextLayout) => Float32Array | null;
18
- renderQuads: (renderer: CoreRenderer, layout: TextLayout, vertexBuffer: Float32Array, renderProps: TextRenderProps) => void;
19
- init: (stage: Stage) => void;
20
- };
21
- export default SdfTextRenderer;
@@ -1,324 +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 2025 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 { TextRenderers } from './TextRenderer.js';
20
- import * as SdfFontHandler from './SdfFontHandler.js';
21
- import { WebGlRenderer } from '../renderers/webgl/WebGlRenderer.js';
22
- import { WebGlRenderOp } from '../renderers/webgl/WebGlRenderOp.js';
23
- import { Sdf } from '../shaders/webgl/SdfShader.js';
24
- import { BufferCollection } from '../renderers/webgl/internal/BufferCollection.js';
25
- import { mergeColorAlpha } from '../../utils.js';
26
- // Each glyph requires 6 vertices (2 triangles) with 4 floats each (x, y, u, v)
27
- const FLOATS_PER_VERTEX = 4;
28
- const VERTICES_PER_GLYPH = 6;
29
- // Type definition to match interface
30
- const type = TextRenderers.sdf;
31
- let sdfShader = null;
32
- // Initialize the SDF text renderer
33
- const init = (stage) => {
34
- SdfFontHandler.init();
35
- // Register SDF shader with the shader manager
36
- stage.shManager.registerShaderType('Sdf', Sdf);
37
- sdfShader = stage.shManager.createShader('Sdf');
38
- };
39
- const font = SdfFontHandler;
40
- /**
41
- * SDF text renderer using MSDF/SDF fonts with WebGL
42
- *
43
- * @param stage - Stage instance for font resolution
44
- * @param props - Text rendering properties
45
- * @returns Object containing ImageData and dimensions
46
- */
47
- const renderText = (stage, props) => {
48
- // Early return if no text
49
- if (props.text.length === 0) {
50
- return {
51
- imageData: null,
52
- width: 0,
53
- height: 0,
54
- };
55
- }
56
- // Get font cache for this font family
57
- const fontData = SdfFontHandler.getFontData(props.fontFamily);
58
- if (fontData === null) {
59
- // Font not loaded, return empty result
60
- return {
61
- imageData: null,
62
- width: 0,
63
- height: 0,
64
- };
65
- }
66
- // Calculate text layout and generate glyph data for caching
67
- const layout = generateTextLayout(props, fontData);
68
- // For SDF renderer, ImageData is null since we render via WebGL
69
- return {
70
- imageData: null,
71
- width: layout.width,
72
- height: layout.height,
73
- layout, // Cache layout for addQuads
74
- };
75
- };
76
- /**
77
- * Add quads for rendering using cached layout data
78
- */
79
- const addQuads = (layout) => {
80
- if (layout === undefined) {
81
- return null; // No layout data available
82
- }
83
- const glyphs = layout.glyphs;
84
- const glyphsLength = glyphs.length;
85
- if (glyphsLength === 0) {
86
- return null;
87
- }
88
- const vertexBuffer = new Float32Array(glyphsLength * VERTICES_PER_GLYPH * FLOATS_PER_VERTEX);
89
- let bufferIndex = 0;
90
- let glyphIndex = 0;
91
- while (glyphIndex < glyphsLength) {
92
- const glyph = glyphs[glyphIndex];
93
- glyphIndex++;
94
- if (glyph === undefined) {
95
- continue;
96
- }
97
- const x1 = glyph.x;
98
- const y1 = glyph.y;
99
- const x2 = x1 + glyph.width;
100
- const y2 = y1 + glyph.height;
101
- const u1 = glyph.atlasX;
102
- const v1 = glyph.atlasY;
103
- const u2 = u1 + glyph.atlasWidth;
104
- const v2 = v1 + glyph.atlasHeight;
105
- // Triangle 1: Top-left, top-right, bottom-left
106
- // Vertex 1: Top-left
107
- vertexBuffer[bufferIndex++] = x1;
108
- vertexBuffer[bufferIndex++] = y1;
109
- vertexBuffer[bufferIndex++] = u1;
110
- vertexBuffer[bufferIndex++] = v1;
111
- // Vertex 2: Top-right
112
- vertexBuffer[bufferIndex++] = x2;
113
- vertexBuffer[bufferIndex++] = y1;
114
- vertexBuffer[bufferIndex++] = u2;
115
- vertexBuffer[bufferIndex++] = v1;
116
- // Vertex 3: Bottom-left
117
- vertexBuffer[bufferIndex++] = x1;
118
- vertexBuffer[bufferIndex++] = y2;
119
- vertexBuffer[bufferIndex++] = u1;
120
- vertexBuffer[bufferIndex++] = v2;
121
- // Triangle 2: Top-right, bottom-right, bottom-left
122
- // Vertex 4: Top-right (duplicate)
123
- vertexBuffer[bufferIndex++] = x2;
124
- vertexBuffer[bufferIndex++] = y1;
125
- vertexBuffer[bufferIndex++] = u2;
126
- vertexBuffer[bufferIndex++] = v1;
127
- // Vertex 5: Bottom-right
128
- vertexBuffer[bufferIndex++] = x2;
129
- vertexBuffer[bufferIndex++] = y2;
130
- vertexBuffer[bufferIndex++] = u2;
131
- vertexBuffer[bufferIndex++] = v2;
132
- // Vertex 6: Bottom-left (duplicate)
133
- vertexBuffer[bufferIndex++] = x1;
134
- vertexBuffer[bufferIndex++] = y2;
135
- vertexBuffer[bufferIndex++] = u1;
136
- vertexBuffer[bufferIndex++] = v2;
137
- }
138
- return vertexBuffer;
139
- };
140
- /**
141
- * Create and submit WebGL render operations for SDF text
142
- * This is called from CoreTextNode during rendering to add SDF text to the render pipeline
143
- */
144
- const renderQuads = (renderer, layout, vertexBuffer, renderProps) => {
145
- const fontFamily = renderProps.fontFamily;
146
- const fontSize = renderProps.fontSize;
147
- const color = renderProps.color;
148
- const offsetY = renderProps.offsetY;
149
- const worldAlpha = renderProps.worldAlpha;
150
- const globalTransform = renderProps.globalTransform;
151
- const atlasTexture = SdfFontHandler.getAtlas(fontFamily);
152
- if (atlasTexture === null) {
153
- console.warn(`SDF atlas texture not found for font: ${fontFamily}`);
154
- return;
155
- }
156
- const fontData = SdfFontHandler.getFontData(fontFamily);
157
- if (fontData === null) {
158
- console.warn(`SDF font data not found for font: ${fontFamily}`);
159
- return;
160
- }
161
- // We can safely assume this is a WebGL renderer else this wouldn't be called
162
- const glw = renderer.glw;
163
- const stride = 4 * Float32Array.BYTES_PER_ELEMENT;
164
- const webGlBuffer = glw.createBuffer();
165
- if (!webGlBuffer) {
166
- console.warn('Failed to create WebGL buffer for SDF text');
167
- return;
168
- }
169
- const webGlBuffers = new BufferCollection([
170
- {
171
- buffer: webGlBuffer,
172
- attributes: {
173
- a_position: {
174
- name: 'a_position',
175
- size: 2,
176
- type: glw.FLOAT,
177
- normalized: false,
178
- stride,
179
- offset: 0,
180
- },
181
- a_textureCoords: {
182
- name: 'a_textureCoords',
183
- size: 2,
184
- type: glw.FLOAT,
185
- normalized: false,
186
- stride,
187
- offset: 2 * Float32Array.BYTES_PER_ELEMENT,
188
- },
189
- },
190
- },
191
- ]);
192
- const buffer = webGlBuffers.getBuffer('a_position');
193
- if (buffer !== undefined) {
194
- glw.arrayBufferData(buffer, vertexBuffer, glw.STATIC_DRAW);
195
- }
196
- const renderOp = new WebGlRenderOp(renderer, {
197
- sdfShaderProps: {
198
- transform: globalTransform,
199
- color: mergeColorAlpha(color || 0xffffffff, worldAlpha),
200
- size: fontSize / (fontData.info?.size || fontData.common.lineHeight), // Use proper font scaling in shader
201
- scrollY: offsetY || 0,
202
- distanceRange: fontData.distanceField?.distanceRange || 1.0,
203
- debug: false, // Disable debug mode
204
- },
205
- sdfBuffers: webGlBuffers,
206
- shader: sdfShader,
207
- alpha: worldAlpha,
208
- // eslint-disable-next-line @typescript-eslint/no-explicit-any, @typescript-eslint/no-unsafe-assignment
209
- clippingRect: renderProps.clippingRect,
210
- height: layout.height,
211
- width: layout.width,
212
- rtt: false,
213
- parentHasRenderTexture: renderProps.parentHasRenderTexture,
214
- // eslint-disable-next-line @typescript-eslint/no-explicit-any, @typescript-eslint/no-unsafe-assignment
215
- framebufferDimensions: renderProps.framebufferDimensions,
216
- }, 0);
217
- // Add atlas texture and set quad count
218
- renderOp.addTexture(atlasTexture.ctxTexture);
219
- renderOp.numQuads = layout.glyphs.length;
220
- renderer.addRenderOp(renderOp);
221
- };
222
- /**
223
- * Generate complete text layout with glyph positioning for caching
224
- */
225
- const generateTextLayout = (props, fontData) => {
226
- const text = props.text;
227
- const fontSize = props.fontSize;
228
- const letterSpacing = props.letterSpacing || 0;
229
- const fontFamily = props.fontFamily;
230
- // Use the font's design size for proper scaling
231
- const designLineHeight = fontData.common.lineHeight;
232
- const lineHeight = props.lineHeight ||
233
- (designLineHeight * fontSize) /
234
- (fontData.info?.size || fontData.common.lineHeight);
235
- const atlasWidth = fontData.common.scaleW;
236
- const atlasHeight = fontData.common.scaleH;
237
- // Split text into lines
238
- const lines = text.split('\n');
239
- const glyphs = [];
240
- let maxWidth = 0;
241
- let currentY = 0;
242
- let lineIndex = 0;
243
- const linesLength = lines.length;
244
- while (lineIndex < linesLength) {
245
- const line = lines[lineIndex];
246
- lineIndex++;
247
- if (line === undefined) {
248
- currentY += lineHeight;
249
- continue;
250
- }
251
- let currentX = 0;
252
- let charIndex = 0;
253
- const lineLength = line.length;
254
- let prevCodepoint = 0;
255
- while (charIndex < lineLength) {
256
- const char = line.charAt(charIndex);
257
- const codepoint = char.codePointAt(0);
258
- charIndex++;
259
- if (codepoint === undefined) {
260
- continue;
261
- }
262
- // Get glyph data from font handler
263
- const glyph = SdfFontHandler.getGlyph(fontFamily, codepoint);
264
- if (glyph === null) {
265
- continue;
266
- }
267
- // Calculate advance with kerning (in design units)
268
- let advance = glyph.xadvance;
269
- // Add kerning if there's a previous character
270
- if (prevCodepoint !== 0) {
271
- const kerning = SdfFontHandler.getKerning(fontFamily, prevCodepoint, codepoint);
272
- advance += kerning;
273
- }
274
- // Calculate glyph position and atlas coordinates (in design units)
275
- const glyphLayout = {
276
- codepoint,
277
- glyphId: glyph.id,
278
- x: currentX + glyph.xoffset,
279
- y: currentY + glyph.yoffset,
280
- width: glyph.width,
281
- height: glyph.height,
282
- xOffset: glyph.xoffset,
283
- yOffset: glyph.yoffset,
284
- atlasX: glyph.x / atlasWidth,
285
- atlasY: glyph.y / atlasHeight,
286
- atlasWidth: glyph.width / atlasWidth,
287
- atlasHeight: glyph.height / atlasHeight,
288
- };
289
- glyphs.push(glyphLayout);
290
- // Advance position with letter spacing (in design units)
291
- const designLetterSpacing = (letterSpacing * (fontData.info?.size || fontData.common.lineHeight)) /
292
- fontSize;
293
- currentX += advance + designLetterSpacing;
294
- prevCodepoint = codepoint;
295
- }
296
- if (currentX > maxWidth) {
297
- maxWidth = currentX;
298
- }
299
- currentY += designLineHeight;
300
- }
301
- // Convert final dimensions to pixel space for the layout
302
- const finalScale = fontSize / (fontData.info?.size || fontData.common.lineHeight);
303
- return {
304
- glyphs,
305
- width: Math.ceil(maxWidth * finalScale),
306
- height: Math.ceil(designLineHeight * lines.length * finalScale), // Include baseline in height
307
- fontScale: finalScale,
308
- lineHeight,
309
- fontFamily,
310
- };
311
- };
312
- /**
313
- * SDF Text Renderer - implements TextRenderer interface
314
- */
315
- const SdfTextRenderer = {
316
- type,
317
- font,
318
- renderText,
319
- addQuads,
320
- renderQuads,
321
- init,
322
- };
323
- export default SdfTextRenderer;
324
- //# sourceMappingURL=SdfTextRenderer.js.map