@lightningjs/renderer 3.0.0-beta3 → 3.0.0-beta4

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 (379) hide show
  1. package/COPYING +1 -0
  2. package/LICENSE +202 -202
  3. package/NOTICE +3 -3
  4. package/README.md +147 -147
  5. package/dist/src/core/CoreNode.d.ts +3 -2
  6. package/dist/src/core/CoreNode.js +13 -7
  7. package/dist/src/core/CoreNode.js.map +1 -1
  8. package/dist/src/core/CoreTextNode.d.ts +2 -0
  9. package/dist/src/core/CoreTextNode.js +7 -0
  10. package/dist/src/core/CoreTextNode.js.map +1 -1
  11. package/dist/src/core/CoreTextureManager.d.ts +2 -0
  12. package/dist/src/core/CoreTextureManager.js +7 -5
  13. package/dist/src/core/CoreTextureManager.js.map +1 -1
  14. package/dist/src/core/Stage.d.ts +5 -0
  15. package/dist/src/core/Stage.js +10 -5
  16. package/dist/src/core/Stage.js.map +1 -1
  17. package/dist/src/core/lib/validateImageBitmap.d.ts +2 -1
  18. package/dist/src/core/lib/validateImageBitmap.js +4 -4
  19. package/dist/src/core/lib/validateImageBitmap.js.map +1 -1
  20. package/dist/src/core/platforms/Platform.d.ts +37 -0
  21. package/dist/src/{main-api/IRenderDriver.js → core/platforms/Platform.js} +4 -2
  22. package/dist/src/core/platforms/Platform.js.map +1 -0
  23. package/dist/src/core/platforms/web/WebPlatform.d.ts +9 -0
  24. package/dist/src/core/platforms/web/WebPlatform.js +58 -0
  25. package/dist/src/core/platforms/web/WebPlatform.js.map +1 -0
  26. package/dist/src/core/renderers/CoreRenderer.d.ts +3 -1
  27. package/dist/src/core/renderers/CoreRenderer.js.map +1 -1
  28. package/dist/src/core/renderers/canvas/CanvasRenderer.js.map +1 -1
  29. package/dist/src/core/renderers/webgl/WebGlRenderer.d.ts +3 -1
  30. package/dist/src/core/renderers/webgl/WebGlRenderer.js +86 -60
  31. package/dist/src/core/renderers/webgl/WebGlRenderer.js.map +1 -1
  32. package/dist/src/core/renderers/webgl/internal/ShaderUtils.js +35 -35
  33. package/dist/src/core/renderers/webgl/shaders/DefaultShader.js +45 -45
  34. package/dist/src/core/renderers/webgl/shaders/DefaultShaderBatched.js +61 -61
  35. package/dist/src/core/renderers/webgl/shaders/DynamicShader.js +93 -93
  36. package/dist/src/core/renderers/webgl/shaders/RoundedRectangle.js +63 -63
  37. package/dist/src/core/renderers/webgl/shaders/SdfShader.js +62 -62
  38. package/dist/src/core/renderers/webgl/shaders/effects/BorderBottomEffect.js +15 -15
  39. package/dist/src/core/renderers/webgl/shaders/effects/BorderEffect.js +6 -6
  40. package/dist/src/core/renderers/webgl/shaders/effects/BorderLeftEffect.js +15 -15
  41. package/dist/src/core/renderers/webgl/shaders/effects/BorderRightEffect.js +15 -15
  42. package/dist/src/core/renderers/webgl/shaders/effects/BorderTopEffect.js +15 -15
  43. package/dist/src/core/renderers/webgl/shaders/effects/FadeOutEffect.js +42 -42
  44. package/dist/src/core/renderers/webgl/shaders/effects/GlitchEffect.js +44 -44
  45. package/dist/src/core/renderers/webgl/shaders/effects/GrayscaleEffect.js +3 -3
  46. package/dist/src/core/renderers/webgl/shaders/effects/HolePunchEffect.js +22 -22
  47. package/dist/src/core/renderers/webgl/shaders/effects/LinearGradientEffect.js +28 -28
  48. package/dist/src/core/renderers/webgl/shaders/effects/RadialGradientEffect.js +10 -10
  49. package/dist/src/core/renderers/webgl/shaders/effects/RadialProgressEffect.js +37 -37
  50. package/dist/src/core/renderers/webgl/shaders/effects/RadiusEffect.js +19 -19
  51. package/dist/src/core/shaders/webgl/Border.js +59 -59
  52. package/dist/src/core/shaders/webgl/Default.js +47 -47
  53. package/dist/src/core/shaders/webgl/DefaultBatched.js +61 -61
  54. package/dist/src/core/shaders/webgl/HolePunch.js +32 -32
  55. package/dist/src/core/shaders/webgl/LinearGradient.js +36 -36
  56. package/dist/src/core/shaders/webgl/RadialGradient.js +33 -33
  57. package/dist/src/core/shaders/webgl/Rounded.js +71 -71
  58. package/dist/src/core/shaders/webgl/RoundedWithBorder.js +66 -66
  59. package/dist/src/core/shaders/webgl/RoundedWithBorderAndShadow.js +79 -79
  60. package/dist/src/core/shaders/webgl/RoundedWithShadow.js +54 -54
  61. package/dist/src/core/shaders/webgl/SdfShader.js +62 -62
  62. package/dist/src/core/shaders/webgl/Shadow.js +83 -83
  63. package/dist/src/core/temp.js +77 -0
  64. package/dist/src/core/temp.js.map +1 -0
  65. package/dist/src/core/text-rendering/renderers/CanvasTextRenderer.js +5 -0
  66. package/dist/src/core/text-rendering/renderers/CanvasTextRenderer.js.map +1 -1
  67. package/dist/src/core/text-rendering/renderers/LightningTextTextureRenderer.d.ts +1 -1
  68. package/dist/src/core/text-rendering/renderers/LightningTextTextureRenderer.js +50 -2
  69. package/dist/src/core/text-rendering/renderers/LightningTextTextureRenderer.js.map +1 -1
  70. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.js +6 -2
  71. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.js.map +1 -1
  72. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText.d.ts +1 -1
  73. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText.js +66 -8
  74. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText.js.map +1 -1
  75. package/dist/src/core/text-rendering/renderers/TextRenderer.d.ts +13 -0
  76. package/dist/src/core/text-rendering/renderers/TextRenderer.js +3 -0
  77. package/dist/src/core/text-rendering/renderers/TextRenderer.js.map +1 -1
  78. package/dist/src/core/textures/ImageTexture.d.ts +1 -0
  79. package/dist/src/core/textures/ImageTexture.js +5 -3
  80. package/dist/src/core/textures/ImageTexture.js.map +1 -1
  81. package/dist/src/core/textures/Texture.d.ts +9 -2
  82. package/dist/src/core/textures/Texture.js +18 -6
  83. package/dist/src/core/textures/Texture.js.map +1 -1
  84. package/dist/src/main-api/Renderer.d.ts +12 -0
  85. package/dist/src/main-api/Renderer.js +14 -2
  86. package/dist/src/main-api/Renderer.js.map +1 -1
  87. package/dist/tsconfig.dist.tsbuildinfo +1 -1
  88. package/exports/canvas-shaders.ts +28 -28
  89. package/exports/canvas.ts +45 -45
  90. package/exports/index.ts +90 -90
  91. package/exports/inspector.ts +24 -24
  92. package/exports/utils.ts +44 -44
  93. package/exports/webgl-shaders.ts +28 -28
  94. package/exports/webgl.ts +50 -50
  95. package/package.json +1 -2
  96. package/scripts/please-use-pnpm.js +13 -13
  97. package/src/common/CommonTypes.ts +146 -146
  98. package/src/common/EventEmitter.ts +77 -77
  99. package/src/common/IAnimationController.ts +92 -92
  100. package/src/common/IEventEmitter.ts +28 -28
  101. package/src/core/CoreNode.test.ts +203 -203
  102. package/src/core/CoreNode.ts +2494 -2486
  103. package/src/core/CoreShaderManager.ts +188 -188
  104. package/src/core/CoreTextNode.ts +448 -439
  105. package/src/core/CoreTextureManager.ts +601 -597
  106. package/src/core/Stage.ts +754 -738
  107. package/src/core/TextureMemoryManager.ts +395 -395
  108. package/src/core/animations/AnimationManager.ts +38 -38
  109. package/src/core/animations/CoreAnimation.ts +284 -284
  110. package/src/core/animations/CoreAnimationController.ts +157 -157
  111. package/src/core/lib/ContextSpy.ts +41 -41
  112. package/src/core/lib/ImageWorker.ts +280 -280
  113. package/src/core/lib/Matrix3d.ts +244 -244
  114. package/src/core/lib/RenderCoords.ts +71 -71
  115. package/src/core/lib/WebGlContextWrapper.ts +1374 -1374
  116. package/src/core/lib/textureCompression.ts +152 -152
  117. package/src/core/lib/textureSvg.ts +78 -78
  118. package/src/core/lib/utils.ts +386 -386
  119. package/src/core/lib/validateImageBitmap.ts +87 -76
  120. package/src/core/platform.ts +64 -64
  121. package/src/core/platforms/Platform.ts +77 -0
  122. package/src/core/platforms/web/WebPlatform.ts +84 -0
  123. package/src/core/renderers/CoreContextTexture.ts +43 -43
  124. package/src/core/renderers/CoreRenderOp.ts +22 -22
  125. package/src/core/renderers/CoreRenderer.ts +109 -107
  126. package/src/core/renderers/CoreShaderNode.ts +165 -165
  127. package/src/core/renderers/CoreShaderProgram.ts +23 -23
  128. package/src/core/renderers/canvas/CanvasRenderer.ts +298 -298
  129. package/src/core/renderers/canvas/CanvasShaderNode.ts +99 -99
  130. package/src/core/renderers/canvas/CanvasTexture.ts +156 -156
  131. package/src/core/renderers/canvas/internal/C2DShaderUtils.ts +220 -220
  132. package/src/core/renderers/canvas/internal/ColorUtils.ts +85 -85
  133. package/src/core/renderers/webgl/WebGlCtxRenderTexture.ts +86 -86
  134. package/src/core/renderers/webgl/WebGlCtxSubTexture.ts +50 -50
  135. package/src/core/renderers/webgl/WebGlCtxTexture.ts +301 -301
  136. package/src/core/renderers/webgl/WebGlRenderOp.ts +161 -161
  137. package/src/core/renderers/webgl/WebGlRenderer.ts +750 -720
  138. package/src/core/renderers/webgl/WebGlShaderNode.ts +437 -437
  139. package/src/core/renderers/webgl/WebGlShaderProgram.ts +318 -318
  140. package/src/core/renderers/webgl/internal/BufferCollection.ts +54 -54
  141. package/src/core/renderers/webgl/internal/RendererUtils.ts +155 -155
  142. package/src/core/renderers/webgl/internal/ShaderUtils.ts +281 -281
  143. package/src/core/renderers/webgl/internal/WebGlUtils.ts +35 -35
  144. package/src/core/shaders/canvas/Border.ts +78 -78
  145. package/src/core/shaders/canvas/HolePunch.ts +62 -62
  146. package/src/core/shaders/canvas/LinearGradient.ts +69 -69
  147. package/src/core/shaders/canvas/RadialGradient.ts +113 -113
  148. package/src/core/shaders/canvas/Rounded.ts +55 -55
  149. package/src/core/shaders/canvas/RoundedWithBorder.ts +68 -68
  150. package/src/core/shaders/canvas/RoundedWithBorderAndShadow.ts +88 -88
  151. package/src/core/shaders/canvas/RoundedWithShadow.ts +69 -69
  152. package/src/core/shaders/canvas/Shadow.ts +52 -52
  153. package/src/core/shaders/canvas/utils/render.ts +151 -151
  154. package/src/core/shaders/templates/BorderTemplate.ts +115 -115
  155. package/src/core/shaders/templates/HolePunchTemplate.ts +82 -82
  156. package/src/core/shaders/templates/LinearGradientTemplate.ts +71 -71
  157. package/src/core/shaders/templates/RadialGradientTemplate.ts +81 -81
  158. package/src/core/shaders/templates/RoundedTemplate.ts +98 -98
  159. package/src/core/shaders/templates/RoundedWithBorderAndShadowTemplate.ts +38 -38
  160. package/src/core/shaders/templates/RoundedWithBorderTemplate.ts +35 -35
  161. package/src/core/shaders/templates/RoundedWithShadowTemplate.ts +35 -35
  162. package/src/core/shaders/templates/ShadowTemplate.ts +106 -106
  163. package/src/core/shaders/templates/shaderUtils.ts +47 -47
  164. package/src/core/shaders/webgl/Border.ts +96 -96
  165. package/src/core/shaders/webgl/Default.ts +89 -89
  166. package/src/core/shaders/webgl/DefaultBatched.ts +129 -129
  167. package/src/core/shaders/webgl/HolePunch.ts +78 -78
  168. package/src/core/shaders/webgl/LinearGradient.ts +81 -81
  169. package/src/core/shaders/webgl/RadialGradient.ts +84 -84
  170. package/src/core/shaders/webgl/Rounded.ts +117 -117
  171. package/src/core/shaders/webgl/RoundedWithBorder.ts +114 -114
  172. package/src/core/shaders/webgl/RoundedWithBorderAndShadow.ts +133 -133
  173. package/src/core/shaders/webgl/RoundedWithShadow.ts +98 -98
  174. package/src/core/shaders/webgl/SdfShader.ts +134 -134
  175. package/src/core/shaders/webgl/Shadow.ts +115 -115
  176. package/src/core/text-rendering/TextRenderingUtils.ts +36 -36
  177. package/src/core/text-rendering/TextTextureRendererUtils.ts +263 -263
  178. package/src/core/text-rendering/TrFontManager.ts +183 -183
  179. package/src/core/text-rendering/font-face-types/SdfTrFontFace/SdfTrFontFace.ts +176 -176
  180. package/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/FontShaper.ts +139 -139
  181. package/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/SdfFontShaper.test.ts +173 -173
  182. package/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/SdfFontShaper.ts +171 -171
  183. package/src/core/text-rendering/font-face-types/TrFontFace.ts +187 -187
  184. package/src/core/text-rendering/font-face-types/WebTrFontFace.ts +94 -94
  185. package/src/core/text-rendering/font-face-types/utils.ts +39 -39
  186. package/src/core/text-rendering/renderers/CanvasTextRenderer.ts +514 -509
  187. package/src/core/text-rendering/renderers/LightningTextTextureRenderer.ts +863 -815
  188. package/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.ts +846 -840
  189. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/PeekableGenerator.test.ts +48 -48
  190. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/PeekableGenerator.ts +66 -66
  191. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/SpecialCodepoints.ts +52 -52
  192. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/constants.ts +32 -32
  193. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/getStartConditions.ts +117 -117
  194. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/getUnicodeCodepoints.test.ts +133 -133
  195. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/getUnicodeCodepoints.ts +38 -38
  196. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText.ts +497 -408
  197. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/measureText.test.ts +49 -49
  198. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/measureText.ts +52 -52
  199. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/setRenderWindow.test.ts +205 -205
  200. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/setRenderWindow.ts +93 -93
  201. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/util.ts +40 -40
  202. package/src/core/text-rendering/renderers/TextRenderer.ts +567 -550
  203. package/src/core/textures/ColorTexture.ts +102 -102
  204. package/src/core/textures/ImageTexture.ts +410 -399
  205. package/src/core/textures/NoiseTexture.ts +104 -104
  206. package/src/core/textures/RenderTexture.ts +85 -85
  207. package/src/core/textures/SubTexture.ts +205 -205
  208. package/src/core/textures/Texture.ts +358 -337
  209. package/src/core/utils.ts +227 -227
  210. package/src/env.d.ts +7 -7
  211. package/src/main-api/INode.ts +100 -100
  212. package/src/main-api/Inspector.ts +522 -522
  213. package/src/main-api/Renderer.ts +675 -649
  214. package/src/main-api/utils.ts +45 -45
  215. package/src/utils.ts +267 -267
  216. package/dist/exports/core-api.d.ts +0 -74
  217. package/dist/exports/core-api.js +0 -96
  218. package/dist/exports/core-api.js.map +0 -1
  219. package/dist/exports/main-api.d.ts +0 -30
  220. package/dist/exports/main-api.js +0 -45
  221. package/dist/exports/main-api.js.map +0 -1
  222. package/dist/src/core/CoreExtension.d.ts +0 -12
  223. package/dist/src/core/CoreExtension.js +0 -29
  224. package/dist/src/core/CoreExtension.js.map +0 -1
  225. package/dist/src/core/CoreStuff.js +0 -138
  226. package/dist/src/core/CoreStuff.js.map +0 -1
  227. package/dist/src/core/CoreTexturizer.d.ts +0 -14
  228. package/dist/src/core/CoreTexturizer.js +0 -47
  229. package/dist/src/core/CoreTexturizer.js.map +0 -1
  230. package/dist/src/core/LngNode.d.ts +0 -736
  231. package/dist/src/core/LngNode.js +0 -1174
  232. package/dist/src/core/LngNode.js.map +0 -1
  233. package/dist/src/core/Matrix2DContext.d.ts +0 -15
  234. package/dist/src/core/Matrix2DContext.js +0 -45
  235. package/dist/src/core/Matrix2DContext.js.map +0 -1
  236. package/dist/src/core/ShaderNode.d.ts +0 -10
  237. package/dist/src/core/ShaderNode.js +0 -30
  238. package/dist/src/core/ShaderNode.js.map +0 -1
  239. package/dist/src/core/TextNode.d.ts +0 -103
  240. package/dist/src/core/TextNode.js +0 -331
  241. package/dist/src/core/TextNode.js.map +0 -1
  242. package/dist/src/core/lib/Coords.d.ts +0 -14
  243. package/dist/src/core/lib/Coords.js +0 -55
  244. package/dist/src/core/lib/Coords.js.map +0 -1
  245. package/dist/src/core/lib/glm/common.d.ts +0 -162
  246. package/dist/src/core/lib/glm/common.js +0 -81
  247. package/dist/src/core/lib/glm/common.js.map +0 -1
  248. package/dist/src/core/lib/glm/index.d.ts +0 -11
  249. package/dist/src/core/lib/glm/index.js +0 -30
  250. package/dist/src/core/lib/glm/index.js.map +0 -1
  251. package/dist/src/core/lib/glm/mat2.d.ts +0 -219
  252. package/dist/src/core/lib/glm/mat2.js +0 -396
  253. package/dist/src/core/lib/glm/mat2.js.map +0 -1
  254. package/dist/src/core/lib/glm/mat2d.d.ts +0 -237
  255. package/dist/src/core/lib/glm/mat2d.js +0 -442
  256. package/dist/src/core/lib/glm/mat2d.js.map +0 -1
  257. package/dist/src/core/lib/glm/mat3.d.ts +0 -283
  258. package/dist/src/core/lib/glm/mat3.js +0 -680
  259. package/dist/src/core/lib/glm/mat3.js.map +0 -1
  260. package/dist/src/core/lib/glm/mat4.d.ts +0 -550
  261. package/dist/src/core/lib/glm/mat4.js +0 -1802
  262. package/dist/src/core/lib/glm/mat4.js.map +0 -1
  263. package/dist/src/core/lib/glm/quat.d.ts +0 -363
  264. package/dist/src/core/lib/glm/quat.js +0 -693
  265. package/dist/src/core/lib/glm/quat.js.map +0 -1
  266. package/dist/src/core/lib/glm/quat2.d.ts +0 -356
  267. package/dist/src/core/lib/glm/quat2.js +0 -754
  268. package/dist/src/core/lib/glm/quat2.js.map +0 -1
  269. package/dist/src/core/lib/glm/vec2.d.ts +0 -365
  270. package/dist/src/core/lib/glm/vec2.js +0 -569
  271. package/dist/src/core/lib/glm/vec2.js.map +0 -1
  272. package/dist/src/core/lib/glm/vec3.d.ts +0 -406
  273. package/dist/src/core/lib/glm/vec3.js +0 -720
  274. package/dist/src/core/lib/glm/vec3.js.map +0 -1
  275. package/dist/src/core/lib/glm/vec4.d.ts +0 -330
  276. package/dist/src/core/lib/glm/vec4.js +0 -608
  277. package/dist/src/core/lib/glm/vec4.js.map +0 -1
  278. package/dist/src/core/renderers/CoreShaderManager.d.ts +0 -19
  279. package/dist/src/core/renderers/CoreShaderManager.js +0 -33
  280. package/dist/src/core/renderers/CoreShaderManager.js.map +0 -1
  281. package/dist/src/core/renderers/webgl/WebGlCoreShaderManager.d.ts +0 -27
  282. package/dist/src/core/renderers/webgl/WebGlCoreShaderManager.js +0 -82
  283. package/dist/src/core/renderers/webgl/WebGlCoreShaderManager.js.map +0 -1
  284. package/dist/src/core/renderers/webgl/WebGlCoreShaderProgram.d.ts +0 -11
  285. package/dist/src/core/renderers/webgl/WebGlCoreShaderProgram.js +0 -34
  286. package/dist/src/core/renderers/webgl/WebGlCoreShaderProgram.js.map +0 -1
  287. package/dist/src/core/scene/Scene.d.ts +0 -59
  288. package/dist/src/core/scene/Scene.js +0 -106
  289. package/dist/src/core/scene/Scene.js.map +0 -1
  290. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/makeRenderWindow.d.ts +0 -20
  291. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/makeRenderWindow.js +0 -55
  292. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/makeRenderWindow.js.map +0 -1
  293. package/dist/src/main-api/ICoreDriver.d.ts +0 -27
  294. package/dist/src/main-api/ICoreDriver.js +0 -20
  295. package/dist/src/main-api/ICoreDriver.js.map +0 -1
  296. package/dist/src/main-api/IRenderDriver.d.ts +0 -20
  297. package/dist/src/main-api/IRenderDriver.js.map +0 -1
  298. package/dist/src/main-api/IShaderController.d.ts +0 -14
  299. package/dist/src/main-api/IShaderController.js +0 -30
  300. package/dist/src/main-api/IShaderController.js.map +0 -1
  301. package/dist/src/main-api/IShaderNode.d.ts +0 -17
  302. package/dist/src/main-api/IShaderNode.js +0 -19
  303. package/dist/src/main-api/IShaderNode.js.map +0 -1
  304. package/dist/src/main-api/RendererMain.d.ts +0 -375
  305. package/dist/src/main-api/RendererMain.js +0 -365
  306. package/dist/src/main-api/RendererMain.js.map +0 -1
  307. package/dist/src/main-api/texture-usage-trackers/FinalizationRegistryTextureUsageTracker.d.ts +0 -9
  308. package/dist/src/main-api/texture-usage-trackers/FinalizationRegistryTextureUsageTracker.js +0 -38
  309. package/dist/src/main-api/texture-usage-trackers/FinalizationRegistryTextureUsageTracker.js.map +0 -1
  310. package/dist/src/main-api/texture-usage-trackers/ManualCountTextureUsageTracker.d.ts +0 -56
  311. package/dist/src/main-api/texture-usage-trackers/ManualCountTextureUsageTracker.js +0 -101
  312. package/dist/src/main-api/texture-usage-trackers/ManualCountTextureUsageTracker.js.map +0 -1
  313. package/dist/src/main-api/texture-usage-trackers/TextureUsageTracker.d.ts +0 -32
  314. package/dist/src/main-api/texture-usage-trackers/TextureUsageTracker.js +0 -28
  315. package/dist/src/main-api/texture-usage-trackers/TextureUsageTracker.js.map +0 -1
  316. package/dist/src/render-drivers/main/MainCoreDriver.d.ts +0 -24
  317. package/dist/src/render-drivers/main/MainCoreDriver.js +0 -118
  318. package/dist/src/render-drivers/main/MainCoreDriver.js.map +0 -1
  319. package/dist/src/render-drivers/main/MainOnlyNode.d.ts +0 -99
  320. package/dist/src/render-drivers/main/MainOnlyNode.js +0 -396
  321. package/dist/src/render-drivers/main/MainOnlyNode.js.map +0 -1
  322. package/dist/src/render-drivers/main/MainOnlyShaderController.d.ts +0 -6
  323. package/dist/src/render-drivers/main/MainOnlyShaderController.js +0 -15
  324. package/dist/src/render-drivers/main/MainOnlyShaderController.js.map +0 -1
  325. package/dist/src/render-drivers/main/MainOnlyShaderNode.d.ts +0 -7
  326. package/dist/src/render-drivers/main/MainOnlyShaderNode.js +0 -34
  327. package/dist/src/render-drivers/main/MainOnlyShaderNode.js.map +0 -1
  328. package/dist/src/render-drivers/main/MainOnlyTextNode.d.ts +0 -47
  329. package/dist/src/render-drivers/main/MainOnlyTextNode.js +0 -205
  330. package/dist/src/render-drivers/main/MainOnlyTextNode.js.map +0 -1
  331. package/dist/src/render-drivers/main/MainRenderDriver.d.ts +0 -17
  332. package/dist/src/render-drivers/main/MainRenderDriver.js +0 -88
  333. package/dist/src/render-drivers/main/MainRenderDriver.js.map +0 -1
  334. package/dist/src/render-drivers/threadx/NodeStruct.d.ts +0 -90
  335. package/dist/src/render-drivers/threadx/NodeStruct.js +0 -281
  336. package/dist/src/render-drivers/threadx/NodeStruct.js.map +0 -1
  337. package/dist/src/render-drivers/threadx/SharedNode.d.ts +0 -39
  338. package/dist/src/render-drivers/threadx/SharedNode.js +0 -60
  339. package/dist/src/render-drivers/threadx/SharedNode.js.map +0 -1
  340. package/dist/src/render-drivers/threadx/TextNodeStruct.d.ts +0 -44
  341. package/dist/src/render-drivers/threadx/TextNodeStruct.js +0 -201
  342. package/dist/src/render-drivers/threadx/TextNodeStruct.js.map +0 -1
  343. package/dist/src/render-drivers/threadx/ThreadXCoreDriver.d.ts +0 -28
  344. package/dist/src/render-drivers/threadx/ThreadXCoreDriver.js +0 -234
  345. package/dist/src/render-drivers/threadx/ThreadXCoreDriver.js.map +0 -1
  346. package/dist/src/render-drivers/threadx/ThreadXMainAnimationController.d.ts +0 -20
  347. package/dist/src/render-drivers/threadx/ThreadXMainAnimationController.js +0 -84
  348. package/dist/src/render-drivers/threadx/ThreadXMainAnimationController.js.map +0 -1
  349. package/dist/src/render-drivers/threadx/ThreadXMainNode.d.ts +0 -44
  350. package/dist/src/render-drivers/threadx/ThreadXMainNode.js +0 -154
  351. package/dist/src/render-drivers/threadx/ThreadXMainNode.js.map +0 -1
  352. package/dist/src/render-drivers/threadx/ThreadXMainShaderController.d.ts +0 -6
  353. package/dist/src/render-drivers/threadx/ThreadXMainShaderController.js +0 -16
  354. package/dist/src/render-drivers/threadx/ThreadXMainShaderController.js.map +0 -1
  355. package/dist/src/render-drivers/threadx/ThreadXMainShaderNode.d.ts +0 -7
  356. package/dist/src/render-drivers/threadx/ThreadXMainShaderNode.js +0 -15
  357. package/dist/src/render-drivers/threadx/ThreadXMainShaderNode.js.map +0 -1
  358. package/dist/src/render-drivers/threadx/ThreadXMainTextNode.d.ts +0 -28
  359. package/dist/src/render-drivers/threadx/ThreadXMainTextNode.js +0 -55
  360. package/dist/src/render-drivers/threadx/ThreadXMainTextNode.js.map +0 -1
  361. package/dist/src/render-drivers/threadx/ThreadXRenderDriver.d.ts +0 -21
  362. package/dist/src/render-drivers/threadx/ThreadXRenderDriver.js +0 -198
  363. package/dist/src/render-drivers/threadx/ThreadXRenderDriver.js.map +0 -1
  364. package/dist/src/render-drivers/threadx/ThreadXRendererMessage.d.ts +0 -70
  365. package/dist/src/render-drivers/threadx/ThreadXRendererMessage.js +0 -32
  366. package/dist/src/render-drivers/threadx/ThreadXRendererMessage.js.map +0 -1
  367. package/dist/src/render-drivers/threadx/worker/ThreadXRendererNode.d.ts +0 -19
  368. package/dist/src/render-drivers/threadx/worker/ThreadXRendererNode.js +0 -177
  369. package/dist/src/render-drivers/threadx/worker/ThreadXRendererNode.js.map +0 -1
  370. package/dist/src/render-drivers/threadx/worker/ThreadXRendererTextNode.d.ts +0 -27
  371. package/dist/src/render-drivers/threadx/worker/ThreadXRendererTextNode.js +0 -108
  372. package/dist/src/render-drivers/threadx/worker/ThreadXRendererTextNode.js.map +0 -1
  373. package/dist/src/render-drivers/threadx/worker/renderer.d.ts +0 -1
  374. package/dist/src/render-drivers/threadx/worker/renderer.js +0 -145
  375. package/dist/src/render-drivers/threadx/worker/renderer.js.map +0 -1
  376. package/dist/src/render-drivers/utils.d.ts +0 -12
  377. package/dist/src/render-drivers/utils.js +0 -69
  378. package/dist/src/render-drivers/utils.js.map +0 -1
  379. /package/dist/src/core/{CoreStuff.d.ts → temp.d.ts} +0 -0
@@ -1,550 +1,567 @@
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 { Dimensions } from '../../../common/CommonTypes.js';
21
- import type { EventEmitter } from '../../../common/EventEmitter.js';
22
- import type { CoreTextNode } from '../../CoreTextNode.js';
23
- import type { Stage } from '../../Stage.js';
24
- import type { Matrix3d } from '../../lib/Matrix3d.js';
25
- import type { Rect, RectWithValid } from '../../lib/utils.js';
26
- import type {
27
- TrFontFace,
28
- TrFontFaceDescriptors,
29
- } from '../font-face-types/TrFontFace.js';
30
- import type {
31
- TextBaseline,
32
- TextVerticalAlign,
33
- } from './LightningTextTextureRenderer.js';
34
-
35
- /**
36
- * Augmentable map of text renderer type IDs to text renderer types.
37
- *
38
- * @example
39
- * ```ts
40
- * declare module './TextRenderer' {
41
- * interface TextRendererMap {
42
- * canvas: CanvasTextRenderer;
43
- * }
44
- * }
45
- * ```
46
- */
47
-
48
- export interface TextRendererMap {}
49
-
50
- export interface TextRendererState {
51
- props: TrProps;
52
- /**
53
- * Whether or not the text renderer state is scheduled to be updated
54
- * via queueMicrotask.
55
- */
56
- updateScheduled: boolean;
57
- status: 'initialState' | 'loading' | 'loaded' | 'failed' | 'destroyed';
58
- /**
59
- * Event emitter for the text renderer
60
- */
61
- emitter: EventEmitter;
62
-
63
- /**
64
- * Force a full layout pass for the calculation of the
65
- * total dimensions of the text
66
- */
67
- forceFullLayoutCalc: boolean;
68
- textW: number | undefined;
69
- textH: number | undefined;
70
-
71
- isRenderable: boolean;
72
-
73
- debugData: {
74
- updateCount: number;
75
- layoutCount: number;
76
- drawCount: number;
77
- lastLayoutNumCharacters: number;
78
- layoutSum: number;
79
- drawSum: number;
80
- bufferSize: number;
81
- };
82
- }
83
-
84
- export interface TextRendererDebugProps {
85
- showRenderWindow: boolean;
86
- showVisibleRect: boolean;
87
- showElementRect: boolean;
88
- disableScissor: boolean;
89
- printLayoutTime: boolean;
90
- }
91
-
92
- /**
93
- * Text renderer properties that are used in resolving appropriate font faces
94
- *
95
- * @remarks
96
- * Extended by {@link TrProps}
97
- */
98
- export interface TrFontProps {
99
- /**
100
- * Font Family
101
- *
102
- * @internalRemarks
103
- * `fontFamily` is defined currently as single string, but in the future we may want to
104
- * support multiple font family fallbacks, as this is supported by CSS / Canvas2d. We can
105
- * do this in a backwards compatible way by unioning an array of strings to the
106
- * `fontFamily` property.
107
- */
108
- fontFamily: string;
109
- /**
110
- * Font Weight
111
- *
112
- * @remarks
113
- * The font weight to use when looking up the font face. This can be a numeric
114
- * value between 1 and 1000, or one of the following strings:
115
- * - `'normal'` - same as 400
116
- * - `'bold'` - same as 700
117
- * - `'bolder'` - (Not yet properly supported)
118
- */
119
- fontWeight: TrFontFaceDescriptors['weight'] | 'bolder' | 'lighter';
120
- /**
121
- * Font Style
122
- *
123
- * @remarks
124
- * The font style to use when looking up the font face. This can be one of the
125
- * following strings:
126
- * - `'normal'`
127
- * - `'italic'`
128
- * - `'oblique'`
129
- */
130
- fontStyle: TrFontFaceDescriptors['style'];
131
- /**
132
- * Font Stretch
133
- *
134
- * @remarks
135
- * The font stretch to use when looking up the font face. This can be one of the
136
- * following strings:
137
- * - `'normal'`
138
- * - `'ultra-condensed'`
139
- * - `'extra-condensed'`
140
- * - `'condensed'`
141
- * - `'semi-condensed'`
142
- * - `'semi-expanded'`
143
- * - `'expanded'`
144
- * - `'extra-expanded'`
145
- * - `'ultra-expanded'`
146
- *
147
- * @default 'normal'
148
- */
149
- fontStretch: TrFontFaceDescriptors['stretch'];
150
- /**
151
- * Font Size
152
- *
153
- * @remarks
154
- * The font size to use when looking up the font face.
155
- *
156
- * The font size is specified in pixels and is the height of the font's
157
- * em-square. The em-square is essentially the height of the capital letters
158
- * for the font. The actual height of the text can be larger than the
159
- * specified font size, as the font may have ascenders and descenders that
160
- * extend beyond the em-square.
161
- *
162
- * @default 16
163
- */
164
- fontSize: number;
165
- }
166
-
167
- export interface TrProps extends TrFontProps {
168
- /**
169
- * Text to display
170
- *
171
- * @default ''
172
- */
173
- text: string;
174
- /**
175
- * Text alignment
176
- *
177
- * @remarks
178
- * Alignment of the text relative to it's contained bounds. For best results,
179
- * use {@link contain} mode `'width'` or `'both'` and a set an explicit
180
- * {@link width} for the text to be aligned within.
181
- *
182
- * @default 'left'
183
- */
184
- textAlign: 'left' | 'center' | 'right';
185
- /**
186
- * Color of text
187
- *
188
- * @remarks
189
- * The color value is a number in the format 0xRRGGBBAA, where RR is the red
190
- * component, GG is the green component, BB is the blue component, and AA is
191
- * the alpha component.
192
- *
193
- * @default 0xffffffff (opaque white)
194
- */
195
- color: number;
196
- x: number;
197
- y: number;
198
- /**
199
- * Contain mode for text
200
- *
201
- * @remarks
202
- * The contain mode determines how the text is contained within the bounds
203
- * of the Text Node. The default value is `'none'`, which means that the
204
- * Text Renderer will not constrain the text in any way. `'width'` mode will
205
- * constrain the text to the set width wrapping lines as necessary, and
206
- * `'both'` mode will constrain the text to both the set width and height
207
- * wrapping lines and truncating text as necessary.
208
- *
209
- * ## Text Auto-size Behavior
210
- * Depending on the set contain mode, after the text 'loaded' event is emitted,
211
- * the text node may have either its {@link width} and {@link height} updated
212
- * to match the rendered size of the text.
213
- *
214
- * When contain mode is 'none', both the {@link width} and {@link height}
215
- * properties are updated.
216
- *
217
- * When contain mode is 'width', only the {@link height} property is updated.
218
- *
219
- * When contain mode is 'both', neither property is updated.
220
- *
221
- * @default 'none'
222
- */
223
- contain: 'none' | 'width' | 'both';
224
- width: number;
225
- height: number;
226
- /**
227
- * Whether or not the text is scrollable
228
- *
229
- * @remarks
230
- * If `scrollable` is `true`, the text can be scrolled vertically within the
231
- * bounds of the Text Node. You can set the scroll position using the
232
- * {@link scrollY} property.
233
- *
234
- * @default false
235
- */
236
- scrollable: boolean;
237
- /**
238
- * Vertical scroll position for text
239
- *
240
- * @remarks
241
- * The vertical scroll position of the text. This property is only used if
242
- * {@link scrollable} is `true`.
243
- *
244
- * @default 0
245
- */
246
- scrollY: number;
247
- /**
248
- * Vertical offset for text
249
- *
250
- * @remarks
251
- * The vertical offset of the text. This property is only used if
252
- * {@link scrollable} is `true`.
253
- *
254
- * @default 0
255
- */
256
- offsetY: number;
257
- /**
258
- * Letter spacing for text (in pixels)
259
- *
260
- * @remarks
261
- * This property sets additional (or reduced, if value is negative) spacing
262
- * between characters in the text.
263
- *
264
- * @default 0
265
- */
266
- letterSpacing: number;
267
- /**
268
- * Line height for text (in pixels)
269
- *
270
- * @remarks
271
- * This property sets the height of each line. If set to `undefined`, the
272
- * line height will be calculated based on the font and font size to be the
273
- * minimal height required to completely contain a line of text.
274
- *
275
- * See: https://github.com/lightning-js/renderer/issues/170
276
- *
277
- * @default `undefined`
278
- */
279
- lineHeight: number | undefined;
280
- /**
281
- * Max lines for text
282
- *
283
- * @remarks
284
- * This property sets max number of lines of a text paragraph.
285
- * Not yet implemented in the SDF renderer.
286
- *
287
- * @default 0
288
- */
289
- maxLines: number;
290
- /**
291
- * Baseline for text
292
- *
293
- * @remarks
294
- * This property sets the text baseline used when drawing text.
295
- * Not yet implemented in the SDF renderer.
296
- *
297
- * @default alphabetic
298
- */
299
- textBaseline: TextBaseline;
300
- /**
301
- * Vertical Align for text when lineHeight > fontSize
302
- *
303
- * @remarks
304
- * This property sets the vertical align of the text.
305
- * Not yet implemented in the SDF renderer.
306
- *
307
- * @default middle
308
- */
309
- verticalAlign: TextVerticalAlign;
310
- /**
311
- * Overflow Suffix for text
312
- *
313
- * @remarks
314
- * The suffix to be added when text is cropped due to overflow.
315
- * Not yet implemented in the SDF renderer.
316
- *
317
- * @default "..."
318
- */
319
- overflowSuffix: string;
320
-
321
- zIndex: number;
322
-
323
- debug: Partial<TextRendererDebugProps>;
324
- }
325
-
326
- export type TrPropSetters<StateT = TextRendererState> = {
327
- [key in keyof TrProps]: (state: StateT, value: TrProps[key]) => void;
328
- };
329
-
330
- const trPropSetterDefaults: TrPropSetters = {
331
- x: (state, value) => {
332
- state.props.x = value;
333
- },
334
- y: (state, value) => {
335
- state.props.y = value;
336
- },
337
- width: (state, value) => {
338
- state.props.width = value;
339
- },
340
- height: (state, value) => {
341
- state.props.height = value;
342
- },
343
- color: (state, value) => {
344
- state.props.color = value;
345
- },
346
- zIndex: (state, value) => {
347
- state.props.zIndex = value;
348
- },
349
- fontFamily: (state, value) => {
350
- state.props.fontFamily = value;
351
- },
352
- fontWeight: (state, value) => {
353
- state.props.fontWeight = value;
354
- },
355
- fontStyle: (state, value) => {
356
- state.props.fontStyle = value;
357
- },
358
- fontStretch: (state, value) => {
359
- state.props.fontStretch = value;
360
- },
361
- fontSize: (state, value) => {
362
- state.props.fontSize = value;
363
- },
364
- text: (state, value) => {
365
- state.props.text = value;
366
- },
367
- textAlign: (state, value) => {
368
- state.props.textAlign = value;
369
- },
370
- contain: (state, value) => {
371
- state.props.contain = value;
372
- },
373
- offsetY: (state, value) => {
374
- state.props.offsetY = value;
375
- },
376
- scrollable: (state, value) => {
377
- state.props.scrollable = value;
378
- },
379
- scrollY: (state, value) => {
380
- state.props.scrollY = value;
381
- },
382
- letterSpacing: (state, value) => {
383
- state.props.letterSpacing = value;
384
- },
385
- lineHeight: (state, value) => {
386
- state.props.lineHeight = value;
387
- },
388
- maxLines: (state, value) => {
389
- state.props.maxLines = value;
390
- },
391
- textBaseline: (state, value) => {
392
- state.props.textBaseline = value;
393
- },
394
- verticalAlign: (state, value) => {
395
- state.props.verticalAlign = value;
396
- },
397
- overflowSuffix: (state, value) => {
398
- state.props.overflowSuffix = value;
399
- },
400
- debug: (state, value) => {
401
- state.props.debug = value;
402
- },
403
- };
404
-
405
- /**
406
- * Event handler for when text is loaded
407
- *
408
- * @remarks
409
- * Emitted by state.emitter
410
- */
411
- export type TrLoadedEventHandler = (target: any) => void;
412
-
413
- /**
414
- * Event handler for when text failed to load
415
- *
416
- * @remarks
417
- * Emitted by state.emitter
418
- */
419
- export type TrFailedEventHandler = (target: any, error: Error) => void;
420
-
421
- export abstract class TextRenderer<
422
- StateT extends TextRendererState = TextRendererState,
423
- > {
424
- readonly set: Readonly<TrPropSetters<StateT>>;
425
- abstract type: 'canvas' | 'sdf';
426
-
427
- constructor(protected stage: Stage) {
428
- const propSetters = {
429
- ...trPropSetterDefaults,
430
- ...this.getPropertySetters(),
431
- };
432
- // For each prop setter add a wrapper method that checks if the prop is
433
- // different before calling the setter
434
- const propSet = {};
435
- Object.keys(propSetters).forEach((key) => {
436
- Object.defineProperty(propSet, key, {
437
- value: (state: StateT, value: TrProps[keyof TrProps]) => {
438
- // Check if the current prop value is different before calling the setter
439
- if (state.props[key as keyof TrProps] !== value) {
440
- propSetters[key as keyof TrPropSetters](state, value as never);
441
-
442
- // Assume any prop change will require a render
443
- // This ensures that renders are triggered appropriately even with RAF paused
444
- this.stage.requestRender();
445
- }
446
- },
447
- writable: false, // Prevents property from being changed
448
- configurable: false, // Prevents property from being deleted
449
- });
450
- });
451
- this.set = propSet as Readonly<TrPropSetters<StateT>>;
452
- }
453
-
454
- setStatus(state: StateT, status: StateT['status'], error?: Error) {
455
- // Don't emit the same status twice
456
- if (state.status === status) {
457
- return;
458
- }
459
- state.status = status;
460
- state.emitter.emit(status, error);
461
- }
462
-
463
- /**
464
- * Allows the CoreTextNode to communicate changes to the isRenderable state of
465
- * the itself.
466
- *
467
- * @param state
468
- * @param renderable
469
- */
470
- setIsRenderable(state: StateT, renderable: boolean) {
471
- state.isRenderable = renderable;
472
- }
473
-
474
- /**
475
- * Called by constructor to get a map of property setter functions for this renderer.
476
- */
477
- abstract getPropertySetters(): Partial<TrPropSetters<StateT>>;
478
-
479
- /**
480
- * Given text renderer properties (particularly the specific properties related to font selection)
481
- * returns whether or not the renderer can render it.
482
- *
483
- * @param props
484
- */
485
- abstract canRenderFont(props: TrFontProps): boolean;
486
-
487
- /**
488
- * Called by the TrFontManager to find out if a newly added font face is supported
489
- * by this renderer.
490
- *
491
- * @param fontFace
492
- */
493
- abstract isFontFaceSupported(fontFace: TrFontFace): boolean;
494
-
495
- /**
496
- * Called by the TrFontManager to add a font face to the renderer's font registry.
497
- *
498
- * @remarks
499
- * This method MUST ONLY be called for a fontFace that previously passed the
500
- * {@link isFontFaceSupported} check.
501
- *
502
- * @param fontFace
503
- */
504
- abstract addFontFace(fontFace: TrFontFace): void;
505
-
506
- abstract createState(props: TrProps, node: CoreTextNode): StateT;
507
-
508
- /**
509
- * Destroy/Clean up the state object
510
- *
511
- * @remarks
512
- * Opposite of createState(). Frees any event listeners / resources held by
513
- * the state that may not reliably get garbage collected.
514
- *
515
- * @param state
516
- */
517
- destroyState(state: StateT) {
518
- this.setStatus(state, 'destroyed');
519
- state.emitter.removeAllListeners();
520
- }
521
-
522
- /**
523
- * Schedule a state update via queueMicrotask
524
- *
525
- * @remarks
526
- * This method is used to schedule a state update via queueMicrotask. This
527
- * method should be called whenever a state update is needed, and it will
528
- * ensure that the state is only updated once per microtask.
529
- * @param state
530
- * @returns
531
- */
532
- scheduleUpdateState(state: StateT): void {
533
- if (state.updateScheduled) {
534
- return;
535
- }
536
- state.updateScheduled = true;
537
- queueMicrotask(() => {
538
- // If the state has been destroyed, don't update it
539
- if (state.status === 'destroyed') {
540
- return;
541
- }
542
- state.updateScheduled = false;
543
- this.updateState(state);
544
- });
545
- }
546
-
547
- abstract updateState(state: StateT): void;
548
-
549
- renderQuads?(node: CoreTextNode): void;
550
- }
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 { Dimensions } from '../../../common/CommonTypes.js';
21
+ import type { EventEmitter } from '../../../common/EventEmitter.js';
22
+ import type { CoreTextNode } from '../../CoreTextNode.js';
23
+ import type { Stage } from '../../Stage.js';
24
+ import type { Matrix3d } from '../../lib/Matrix3d.js';
25
+ import type { Rect, RectWithValid } from '../../lib/utils.js';
26
+ import type {
27
+ TrFontFace,
28
+ TrFontFaceDescriptors,
29
+ } from '../font-face-types/TrFontFace.js';
30
+ import type {
31
+ TextBaseline,
32
+ TextVerticalAlign,
33
+ } from './LightningTextTextureRenderer.js';
34
+
35
+ /**
36
+ * Augmentable map of text renderer type IDs to text renderer types.
37
+ *
38
+ * @example
39
+ * ```ts
40
+ * declare module './TextRenderer' {
41
+ * interface TextRendererMap {
42
+ * canvas: CanvasTextRenderer;
43
+ * }
44
+ * }
45
+ * ```
46
+ */
47
+
48
+ export interface TextRendererMap {}
49
+
50
+ export interface TextRendererState {
51
+ props: TrProps;
52
+ /**
53
+ * Whether or not the text renderer state is scheduled to be updated
54
+ * via queueMicrotask.
55
+ */
56
+ updateScheduled: boolean;
57
+ status: 'initialState' | 'loading' | 'loaded' | 'failed' | 'destroyed';
58
+ /**
59
+ * Event emitter for the text renderer
60
+ */
61
+ emitter: EventEmitter;
62
+
63
+ /**
64
+ * Force a full layout pass for the calculation of the
65
+ * total dimensions of the text
66
+ */
67
+ forceFullLayoutCalc: boolean;
68
+ textW: number | undefined;
69
+ textH: number | undefined;
70
+
71
+ isRenderable: boolean;
72
+
73
+ debugData: {
74
+ updateCount: number;
75
+ layoutCount: number;
76
+ drawCount: number;
77
+ lastLayoutNumCharacters: number;
78
+ layoutSum: number;
79
+ drawSum: number;
80
+ bufferSize: number;
81
+ };
82
+ }
83
+
84
+ export interface TextRendererDebugProps {
85
+ showRenderWindow: boolean;
86
+ showVisibleRect: boolean;
87
+ showElementRect: boolean;
88
+ disableScissor: boolean;
89
+ printLayoutTime: boolean;
90
+ }
91
+
92
+ /**
93
+ * Text renderer properties that are used in resolving appropriate font faces
94
+ *
95
+ * @remarks
96
+ * Extended by {@link TrProps}
97
+ */
98
+ export interface TrFontProps {
99
+ /**
100
+ * Font Family
101
+ *
102
+ * @internalRemarks
103
+ * `fontFamily` is defined currently as single string, but in the future we may want to
104
+ * support multiple font family fallbacks, as this is supported by CSS / Canvas2d. We can
105
+ * do this in a backwards compatible way by unioning an array of strings to the
106
+ * `fontFamily` property.
107
+ */
108
+ fontFamily: string;
109
+ /**
110
+ * Font Weight
111
+ *
112
+ * @remarks
113
+ * The font weight to use when looking up the font face. This can be a numeric
114
+ * value between 1 and 1000, or one of the following strings:
115
+ * - `'normal'` - same as 400
116
+ * - `'bold'` - same as 700
117
+ * - `'bolder'` - (Not yet properly supported)
118
+ */
119
+ fontWeight: TrFontFaceDescriptors['weight'] | 'bolder' | 'lighter';
120
+ /**
121
+ * Font Style
122
+ *
123
+ * @remarks
124
+ * The font style to use when looking up the font face. This can be one of the
125
+ * following strings:
126
+ * - `'normal'`
127
+ * - `'italic'`
128
+ * - `'oblique'`
129
+ */
130
+ fontStyle: TrFontFaceDescriptors['style'];
131
+ /**
132
+ * Font Stretch
133
+ *
134
+ * @remarks
135
+ * The font stretch to use when looking up the font face. This can be one of the
136
+ * following strings:
137
+ * - `'normal'`
138
+ * - `'ultra-condensed'`
139
+ * - `'extra-condensed'`
140
+ * - `'condensed'`
141
+ * - `'semi-condensed'`
142
+ * - `'semi-expanded'`
143
+ * - `'expanded'`
144
+ * - `'extra-expanded'`
145
+ * - `'ultra-expanded'`
146
+ *
147
+ * @default 'normal'
148
+ */
149
+ fontStretch: TrFontFaceDescriptors['stretch'];
150
+ /**
151
+ * Font Size
152
+ *
153
+ * @remarks
154
+ * The font size to use when looking up the font face.
155
+ *
156
+ * The font size is specified in pixels and is the height of the font's
157
+ * em-square. The em-square is essentially the height of the capital letters
158
+ * for the font. The actual height of the text can be larger than the
159
+ * specified font size, as the font may have ascenders and descenders that
160
+ * extend beyond the em-square.
161
+ *
162
+ * @default 16
163
+ */
164
+ fontSize: number;
165
+ }
166
+
167
+ export interface TrProps extends TrFontProps {
168
+ /**
169
+ * Text to display
170
+ *
171
+ * @default ''
172
+ */
173
+ text: string;
174
+ /**
175
+ * Text alignment
176
+ *
177
+ * @remarks
178
+ * Alignment of the text relative to it's contained bounds. For best results,
179
+ * use {@link contain} mode `'width'` or `'both'` and a set an explicit
180
+ * {@link width} for the text to be aligned within.
181
+ *
182
+ * @default 'left'
183
+ */
184
+ textAlign: 'left' | 'center' | 'right';
185
+ /**
186
+ * Color of text
187
+ *
188
+ * @remarks
189
+ * The color value is a number in the format 0xRRGGBBAA, where RR is the red
190
+ * component, GG is the green component, BB is the blue component, and AA is
191
+ * the alpha component.
192
+ *
193
+ * @default 0xffffffff (opaque white)
194
+ */
195
+ color: number;
196
+ x: number;
197
+ y: number;
198
+ /**
199
+ * Contain mode for text
200
+ *
201
+ * @remarks
202
+ * The contain mode determines how the text is contained within the bounds
203
+ * of the Text Node. The default value is `'none'`, which means that the
204
+ * Text Renderer will not constrain the text in any way. `'width'` mode will
205
+ * constrain the text to the set width wrapping lines as necessary, and
206
+ * `'both'` mode will constrain the text to both the set width and height
207
+ * wrapping lines and truncating text as necessary.
208
+ *
209
+ * ## Text Auto-size Behavior
210
+ * Depending on the set contain mode, after the text 'loaded' event is emitted,
211
+ * the text node may have either its {@link width} and {@link height} updated
212
+ * to match the rendered size of the text.
213
+ *
214
+ * When contain mode is 'none', both the {@link width} and {@link height}
215
+ * properties are updated.
216
+ *
217
+ * When contain mode is 'width', only the {@link height} property is updated.
218
+ *
219
+ * When contain mode is 'both', neither property is updated.
220
+ *
221
+ * @default 'none'
222
+ */
223
+ contain: 'none' | 'width' | 'both';
224
+ width: number;
225
+ height: number;
226
+ /**
227
+ * Whether or not the text is scrollable
228
+ *
229
+ * @remarks
230
+ * If `scrollable` is `true`, the text can be scrolled vertically within the
231
+ * bounds of the Text Node. You can set the scroll position using the
232
+ * {@link scrollY} property.
233
+ *
234
+ * @default false
235
+ */
236
+ scrollable: boolean;
237
+ /**
238
+ * Vertical scroll position for text
239
+ *
240
+ * @remarks
241
+ * The vertical scroll position of the text. This property is only used if
242
+ * {@link scrollable} is `true`.
243
+ *
244
+ * @default 0
245
+ */
246
+ scrollY: number;
247
+ /**
248
+ * Vertical offset for text
249
+ *
250
+ * @remarks
251
+ * The vertical offset of the text. This property is only used if
252
+ * {@link scrollable} is `true`.
253
+ *
254
+ * @default 0
255
+ */
256
+ offsetY: number;
257
+ /**
258
+ * Letter spacing for text (in pixels)
259
+ *
260
+ * @remarks
261
+ * This property sets additional (or reduced, if value is negative) spacing
262
+ * between characters in the text.
263
+ *
264
+ * @default 0
265
+ */
266
+ letterSpacing: number;
267
+ /**
268
+ * Line height for text (in pixels)
269
+ *
270
+ * @remarks
271
+ * This property sets the height of each line. If set to `undefined`, the
272
+ * line height will be calculated based on the font and font size to be the
273
+ * minimal height required to completely contain a line of text.
274
+ *
275
+ * See: https://github.com/lightning-js/renderer/issues/170
276
+ *
277
+ * @default `undefined`
278
+ */
279
+ lineHeight: number | undefined;
280
+ /**
281
+ * Max lines for text
282
+ *
283
+ * @remarks
284
+ * This property sets max number of lines of a text paragraph.
285
+ * Not yet implemented in the SDF renderer.
286
+ *
287
+ * @default 0
288
+ */
289
+ maxLines: number;
290
+ /**
291
+ * Baseline for text
292
+ *
293
+ * @remarks
294
+ * This property sets the text baseline used when drawing text.
295
+ * Not yet implemented in the SDF renderer.
296
+ *
297
+ * @default alphabetic
298
+ */
299
+ textBaseline: TextBaseline;
300
+ /**
301
+ * Vertical Align for text when lineHeight > fontSize
302
+ *
303
+ * @remarks
304
+ * This property sets the vertical align of the text.
305
+ * Not yet implemented in the SDF renderer.
306
+ *
307
+ * @default middle
308
+ */
309
+ verticalAlign: TextVerticalAlign;
310
+ /**
311
+ * Overflow Suffix for text
312
+ *
313
+ * @remarks
314
+ * The suffix to be added when text is cropped due to overflow.
315
+ * Not yet implemented in the SDF renderer.
316
+ *
317
+ * @default "..."
318
+ */
319
+ overflowSuffix: string;
320
+
321
+ /**
322
+ * Word Break for text
323
+ *
324
+ * @remarks
325
+ * This property sets how words should break when reaching the end of a line.
326
+ *
327
+ * - `'normal'`: Use the default line break rule.
328
+ * - `'break-all'`: To prevent overflow, word breaks should happen between any two characters.
329
+ * - `'break-word'`: To prevent overflow, word breaks should happen between words. If words are too long word breaks happen between any two characters.
330
+ *
331
+ * @default "normal"
332
+ */
333
+ wordBreak: 'normal' | 'break-all' | 'break-word';
334
+
335
+ zIndex: number;
336
+
337
+ debug: Partial<TextRendererDebugProps>;
338
+ }
339
+
340
+ export type TrPropSetters<StateT = TextRendererState> = {
341
+ [key in keyof TrProps]: (state: StateT, value: TrProps[key]) => void;
342
+ };
343
+
344
+ const trPropSetterDefaults: TrPropSetters = {
345
+ x: (state, value) => {
346
+ state.props.x = value;
347
+ },
348
+ y: (state, value) => {
349
+ state.props.y = value;
350
+ },
351
+ width: (state, value) => {
352
+ state.props.width = value;
353
+ },
354
+ height: (state, value) => {
355
+ state.props.height = value;
356
+ },
357
+ color: (state, value) => {
358
+ state.props.color = value;
359
+ },
360
+ zIndex: (state, value) => {
361
+ state.props.zIndex = value;
362
+ },
363
+ fontFamily: (state, value) => {
364
+ state.props.fontFamily = value;
365
+ },
366
+ fontWeight: (state, value) => {
367
+ state.props.fontWeight = value;
368
+ },
369
+ fontStyle: (state, value) => {
370
+ state.props.fontStyle = value;
371
+ },
372
+ fontStretch: (state, value) => {
373
+ state.props.fontStretch = value;
374
+ },
375
+ fontSize: (state, value) => {
376
+ state.props.fontSize = value;
377
+ },
378
+ text: (state, value) => {
379
+ state.props.text = value;
380
+ },
381
+ textAlign: (state, value) => {
382
+ state.props.textAlign = value;
383
+ },
384
+ contain: (state, value) => {
385
+ state.props.contain = value;
386
+ },
387
+ offsetY: (state, value) => {
388
+ state.props.offsetY = value;
389
+ },
390
+ scrollable: (state, value) => {
391
+ state.props.scrollable = value;
392
+ },
393
+ scrollY: (state, value) => {
394
+ state.props.scrollY = value;
395
+ },
396
+ letterSpacing: (state, value) => {
397
+ state.props.letterSpacing = value;
398
+ },
399
+ lineHeight: (state, value) => {
400
+ state.props.lineHeight = value;
401
+ },
402
+ maxLines: (state, value) => {
403
+ state.props.maxLines = value;
404
+ },
405
+ textBaseline: (state, value) => {
406
+ state.props.textBaseline = value;
407
+ },
408
+ verticalAlign: (state, value) => {
409
+ state.props.verticalAlign = value;
410
+ },
411
+ overflowSuffix: (state, value) => {
412
+ state.props.overflowSuffix = value;
413
+ },
414
+ wordBreak: (state, value) => {
415
+ state.props.wordBreak = value;
416
+ },
417
+ debug: (state, value) => {
418
+ state.props.debug = value;
419
+ },
420
+ };
421
+
422
+ /**
423
+ * Event handler for when text is loaded
424
+ *
425
+ * @remarks
426
+ * Emitted by state.emitter
427
+ */
428
+ export type TrLoadedEventHandler = (target: any) => void;
429
+
430
+ /**
431
+ * Event handler for when text failed to load
432
+ *
433
+ * @remarks
434
+ * Emitted by state.emitter
435
+ */
436
+ export type TrFailedEventHandler = (target: any, error: Error) => void;
437
+
438
+ export abstract class TextRenderer<
439
+ StateT extends TextRendererState = TextRendererState,
440
+ > {
441
+ readonly set: Readonly<TrPropSetters<StateT>>;
442
+ abstract type: 'canvas' | 'sdf';
443
+
444
+ constructor(protected stage: Stage) {
445
+ const propSetters = {
446
+ ...trPropSetterDefaults,
447
+ ...this.getPropertySetters(),
448
+ };
449
+ // For each prop setter add a wrapper method that checks if the prop is
450
+ // different before calling the setter
451
+ const propSet = {};
452
+ Object.keys(propSetters).forEach((key) => {
453
+ Object.defineProperty(propSet, key, {
454
+ value: (state: StateT, value: TrProps[keyof TrProps]) => {
455
+ // Check if the current prop value is different before calling the setter
456
+ if (state.props[key as keyof TrProps] !== value) {
457
+ propSetters[key as keyof TrPropSetters](state, value as never);
458
+
459
+ // Assume any prop change will require a render
460
+ // This ensures that renders are triggered appropriately even with RAF paused
461
+ this.stage.requestRender();
462
+ }
463
+ },
464
+ writable: false, // Prevents property from being changed
465
+ configurable: false, // Prevents property from being deleted
466
+ });
467
+ });
468
+ this.set = propSet as Readonly<TrPropSetters<StateT>>;
469
+ }
470
+
471
+ setStatus(state: StateT, status: StateT['status'], error?: Error) {
472
+ // Don't emit the same status twice
473
+ if (state.status === status) {
474
+ return;
475
+ }
476
+ state.status = status;
477
+ state.emitter.emit(status, error);
478
+ }
479
+
480
+ /**
481
+ * Allows the CoreTextNode to communicate changes to the isRenderable state of
482
+ * the itself.
483
+ *
484
+ * @param state
485
+ * @param renderable
486
+ */
487
+ setIsRenderable(state: StateT, renderable: boolean) {
488
+ state.isRenderable = renderable;
489
+ }
490
+
491
+ /**
492
+ * Called by constructor to get a map of property setter functions for this renderer.
493
+ */
494
+ abstract getPropertySetters(): Partial<TrPropSetters<StateT>>;
495
+
496
+ /**
497
+ * Given text renderer properties (particularly the specific properties related to font selection)
498
+ * returns whether or not the renderer can render it.
499
+ *
500
+ * @param props
501
+ */
502
+ abstract canRenderFont(props: TrFontProps): boolean;
503
+
504
+ /**
505
+ * Called by the TrFontManager to find out if a newly added font face is supported
506
+ * by this renderer.
507
+ *
508
+ * @param fontFace
509
+ */
510
+ abstract isFontFaceSupported(fontFace: TrFontFace): boolean;
511
+
512
+ /**
513
+ * Called by the TrFontManager to add a font face to the renderer's font registry.
514
+ *
515
+ * @remarks
516
+ * This method MUST ONLY be called for a fontFace that previously passed the
517
+ * {@link isFontFaceSupported} check.
518
+ *
519
+ * @param fontFace
520
+ */
521
+ abstract addFontFace(fontFace: TrFontFace): void;
522
+
523
+ abstract createState(props: TrProps, node: CoreTextNode): StateT;
524
+
525
+ /**
526
+ * Destroy/Clean up the state object
527
+ *
528
+ * @remarks
529
+ * Opposite of createState(). Frees any event listeners / resources held by
530
+ * the state that may not reliably get garbage collected.
531
+ *
532
+ * @param state
533
+ */
534
+ destroyState(state: StateT) {
535
+ this.setStatus(state, 'destroyed');
536
+ state.emitter.removeAllListeners();
537
+ }
538
+
539
+ /**
540
+ * Schedule a state update via queueMicrotask
541
+ *
542
+ * @remarks
543
+ * This method is used to schedule a state update via queueMicrotask. This
544
+ * method should be called whenever a state update is needed, and it will
545
+ * ensure that the state is only updated once per microtask.
546
+ * @param state
547
+ * @returns
548
+ */
549
+ scheduleUpdateState(state: StateT): void {
550
+ if (state.updateScheduled) {
551
+ return;
552
+ }
553
+ state.updateScheduled = true;
554
+ queueMicrotask(() => {
555
+ // If the state has been destroyed, don't update it
556
+ if (state.status === 'destroyed') {
557
+ return;
558
+ }
559
+ state.updateScheduled = false;
560
+ this.updateState(state);
561
+ });
562
+ }
563
+
564
+ abstract updateState(state: StateT): void;
565
+
566
+ renderQuads?(node: CoreTextNode): void;
567
+ }