@lightningtv/renderer 3.0.0-beta1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (481) hide show
  1. package/LICENSE +202 -0
  2. package/NOTICE +3 -0
  3. package/README.md +147 -0
  4. package/dist/exports/canvas-shaders.d.ts +10 -0
  5. package/dist/exports/canvas-shaders.js +27 -0
  6. package/dist/exports/canvas-shaders.js.map +1 -0
  7. package/dist/exports/canvas.d.ts +26 -0
  8. package/dist/exports/canvas.js +45 -0
  9. package/dist/exports/canvas.js.map +1 -0
  10. package/dist/exports/index.d.ts +53 -0
  11. package/dist/exports/index.js +62 -0
  12. package/dist/exports/index.js.map +1 -0
  13. package/dist/exports/inspector.d.ts +4 -0
  14. package/dist/exports/inspector.js +23 -0
  15. package/dist/exports/inspector.js.map +1 -0
  16. package/dist/exports/utils.d.ts +26 -0
  17. package/dist/exports/utils.js +45 -0
  18. package/dist/exports/utils.js.map +1 -0
  19. package/dist/exports/webgl-shaders.d.ts +11 -0
  20. package/dist/exports/webgl-shaders.js +28 -0
  21. package/dist/exports/webgl-shaders.js.map +1 -0
  22. package/dist/exports/webgl.d.ts +27 -0
  23. package/dist/exports/webgl.js +46 -0
  24. package/dist/exports/webgl.js.map +1 -0
  25. package/dist/src/common/CommonTypes.d.ts +97 -0
  26. package/dist/src/common/CommonTypes.js +20 -0
  27. package/dist/src/common/CommonTypes.js.map +1 -0
  28. package/dist/src/common/EventEmitter.d.ts +12 -0
  29. package/dist/src/common/EventEmitter.js +66 -0
  30. package/dist/src/common/EventEmitter.js.map +1 -0
  31. package/dist/src/common/IAnimationController.d.ts +66 -0
  32. package/dist/src/common/IAnimationController.js +2 -0
  33. package/dist/src/common/IAnimationController.js.map +1 -0
  34. package/dist/src/common/IEventEmitter.d.ts +8 -0
  35. package/dist/src/common/IEventEmitter.js +18 -0
  36. package/dist/src/common/IEventEmitter.js.map +1 -0
  37. package/dist/src/core/CoreNode.d.ts +860 -0
  38. package/dist/src/core/CoreNode.js +1527 -0
  39. package/dist/src/core/CoreNode.js.map +1 -0
  40. package/dist/src/core/CoreShaderManager.d.ts +38 -0
  41. package/dist/src/core/CoreShaderManager.js +141 -0
  42. package/dist/src/core/CoreShaderManager.js.map +1 -0
  43. package/dist/src/core/CoreTextNode.d.ts +103 -0
  44. package/dist/src/core/CoreTextNode.js +331 -0
  45. package/dist/src/core/CoreTextNode.js.map +1 -0
  46. package/dist/src/core/CoreTextureManager.d.ts +253 -0
  47. package/dist/src/core/CoreTextureManager.js +375 -0
  48. package/dist/src/core/CoreTextureManager.js.map +1 -0
  49. package/dist/src/core/Stage.d.ts +171 -0
  50. package/dist/src/core/Stage.js +566 -0
  51. package/dist/src/core/Stage.js.map +1 -0
  52. package/dist/src/core/TextureMemoryManager.d.ts +143 -0
  53. package/dist/src/core/TextureMemoryManager.js +259 -0
  54. package/dist/src/core/TextureMemoryManager.js.map +1 -0
  55. package/dist/src/core/animations/AnimationManager.d.ts +7 -0
  56. package/dist/src/core/animations/AnimationManager.js +34 -0
  57. package/dist/src/core/animations/AnimationManager.js.map +1 -0
  58. package/dist/src/core/animations/CoreAnimation.d.ts +37 -0
  59. package/dist/src/core/animations/CoreAnimation.js +210 -0
  60. package/dist/src/core/animations/CoreAnimation.js.map +1 -0
  61. package/dist/src/core/animations/CoreAnimationController.d.ts +26 -0
  62. package/dist/src/core/animations/CoreAnimationController.js +126 -0
  63. package/dist/src/core/animations/CoreAnimationController.js.map +1 -0
  64. package/dist/src/core/lib/ContextSpy.d.ts +12 -0
  65. package/dist/src/core/lib/ContextSpy.js +38 -0
  66. package/dist/src/core/lib/ContextSpy.js.map +1 -0
  67. package/dist/src/core/lib/ImageWorker.d.ts +16 -0
  68. package/dist/src/core/lib/ImageWorker.js +200 -0
  69. package/dist/src/core/lib/ImageWorker.js.map +1 -0
  70. package/dist/src/core/lib/Matrix3d.d.ts +73 -0
  71. package/dist/src/core/lib/Matrix3d.js +230 -0
  72. package/dist/src/core/lib/Matrix3d.js.map +1 -0
  73. package/dist/src/core/lib/RenderCoords.d.ts +13 -0
  74. package/dist/src/core/lib/RenderCoords.js +63 -0
  75. package/dist/src/core/lib/RenderCoords.js.map +1 -0
  76. package/dist/src/core/lib/WebGlContextWrapper.d.ts +707 -0
  77. package/dist/src/core/lib/WebGlContextWrapper.js +1018 -0
  78. package/dist/src/core/lib/WebGlContextWrapper.js.map +1 -0
  79. package/dist/src/core/lib/textureCompression.d.ts +16 -0
  80. package/dist/src/core/lib/textureCompression.js +128 -0
  81. package/dist/src/core/lib/textureCompression.js.map +1 -0
  82. package/dist/src/core/lib/textureSvg.d.ts +16 -0
  83. package/dist/src/core/lib/textureSvg.js +63 -0
  84. package/dist/src/core/lib/textureSvg.js.map +1 -0
  85. package/dist/src/core/lib/utils.d.ts +59 -0
  86. package/dist/src/core/lib/utils.js +244 -0
  87. package/dist/src/core/lib/utils.js.map +1 -0
  88. package/dist/src/core/lib/validateImageBitmap.d.ts +6 -0
  89. package/dist/src/core/lib/validateImageBitmap.js +68 -0
  90. package/dist/src/core/lib/validateImageBitmap.js.map +1 -0
  91. package/dist/src/core/platform.d.ts +10 -0
  92. package/dist/src/core/platform.js +56 -0
  93. package/dist/src/core/platform.js.map +1 -0
  94. package/dist/src/core/renderers/CoreContextTexture.d.ts +12 -0
  95. package/dist/src/core/renderers/CoreContextTexture.js +34 -0
  96. package/dist/src/core/renderers/CoreContextTexture.js.map +1 -0
  97. package/dist/src/core/renderers/CoreRenderOp.d.ts +3 -0
  98. package/dist/src/core/renderers/CoreRenderOp.js +21 -0
  99. package/dist/src/core/renderers/CoreRenderOp.js.map +1 -0
  100. package/dist/src/core/renderers/CoreRenderer.d.ts +68 -0
  101. package/dist/src/core/renderers/CoreRenderer.js +31 -0
  102. package/dist/src/core/renderers/CoreRenderer.js.map +1 -0
  103. package/dist/src/core/renderers/CoreShaderNode.d.ts +59 -0
  104. package/dist/src/core/renderers/CoreShaderNode.js +107 -0
  105. package/dist/src/core/renderers/CoreShaderNode.js.map +1 -0
  106. package/dist/src/core/renderers/CoreShaderProgram.d.ts +4 -0
  107. package/dist/src/core/renderers/CoreShaderProgram.js +20 -0
  108. package/dist/src/core/renderers/CoreShaderProgram.js.map +1 -0
  109. package/dist/src/core/renderers/canvas/CanvasRenderer.d.ts +36 -0
  110. package/dist/src/core/renderers/canvas/CanvasRenderer.js +212 -0
  111. package/dist/src/core/renderers/canvas/CanvasRenderer.js.map +1 -0
  112. package/dist/src/core/renderers/canvas/CanvasShaderNode.d.ts +21 -0
  113. package/dist/src/core/renderers/canvas/CanvasShaderNode.js +60 -0
  114. package/dist/src/core/renderers/canvas/CanvasShaderNode.js.map +1 -0
  115. package/dist/src/core/renderers/canvas/CanvasTexture.d.ts +16 -0
  116. package/dist/src/core/renderers/canvas/CanvasTexture.js +123 -0
  117. package/dist/src/core/renderers/canvas/CanvasTexture.js.map +1 -0
  118. package/dist/src/core/renderers/canvas/internal/C2DShaderUtils.d.ts +1 -0
  119. package/dist/src/core/renderers/canvas/internal/C2DShaderUtils.js +217 -0
  120. package/dist/src/core/renderers/canvas/internal/C2DShaderUtils.js.map +1 -0
  121. package/dist/src/core/renderers/canvas/internal/ColorUtils.d.ts +21 -0
  122. package/dist/src/core/renderers/canvas/internal/ColorUtils.js +72 -0
  123. package/dist/src/core/renderers/canvas/internal/ColorUtils.js.map +1 -0
  124. package/dist/src/core/renderers/webgl/WebGlCtxRenderTexture.d.ts +12 -0
  125. package/dist/src/core/renderers/webgl/WebGlCtxRenderTexture.js +55 -0
  126. package/dist/src/core/renderers/webgl/WebGlCtxRenderTexture.js.map +1 -0
  127. package/dist/src/core/renderers/webgl/WebGlCtxSubTexture.d.ts +9 -0
  128. package/dist/src/core/renderers/webgl/WebGlCtxSubTexture.js +38 -0
  129. package/dist/src/core/renderers/webgl/WebGlCtxSubTexture.js.map +1 -0
  130. package/dist/src/core/renderers/webgl/WebGlCtxTexture.d.ts +57 -0
  131. package/dist/src/core/renderers/webgl/WebGlCtxTexture.js +227 -0
  132. package/dist/src/core/renderers/webgl/WebGlCtxTexture.js.map +1 -0
  133. package/dist/src/core/renderers/webgl/WebGlRenderOp.d.ts +36 -0
  134. package/dist/src/core/renderers/webgl/WebGlRenderOp.js +107 -0
  135. package/dist/src/core/renderers/webgl/WebGlRenderOp.js.map +1 -0
  136. package/dist/src/core/renderers/webgl/WebGlRenderer.d.ts +134 -0
  137. package/dist/src/core/renderers/webgl/WebGlRenderer.js +546 -0
  138. package/dist/src/core/renderers/webgl/WebGlRenderer.js.map +1 -0
  139. package/dist/src/core/renderers/webgl/WebGlShaderNode.d.ts +221 -0
  140. package/dist/src/core/renderers/webgl/WebGlShaderNode.js +334 -0
  141. package/dist/src/core/renderers/webgl/WebGlShaderNode.js.map +1 -0
  142. package/dist/src/core/renderers/webgl/WebGlShaderProgram.d.ts +35 -0
  143. package/dist/src/core/renderers/webgl/WebGlShaderProgram.js +195 -0
  144. package/dist/src/core/renderers/webgl/WebGlShaderProgram.js.map +1 -0
  145. package/dist/src/core/renderers/webgl/internal/BufferCollection.d.ts +27 -0
  146. package/dist/src/core/renderers/webgl/internal/BufferCollection.js +48 -0
  147. package/dist/src/core/renderers/webgl/internal/BufferCollection.js.map +1 -0
  148. package/dist/src/core/renderers/webgl/internal/RendererUtils.d.ts +55 -0
  149. package/dist/src/core/renderers/webgl/internal/RendererUtils.js +106 -0
  150. package/dist/src/core/renderers/webgl/internal/RendererUtils.js.map +1 -0
  151. package/dist/src/core/renderers/webgl/internal/ShaderUtils.d.ts +74 -0
  152. package/dist/src/core/renderers/webgl/internal/ShaderUtils.js +101 -0
  153. package/dist/src/core/renderers/webgl/internal/ShaderUtils.js.map +1 -0
  154. package/dist/src/core/renderers/webgl/internal/WebGlUtils.d.ts +10 -0
  155. package/dist/src/core/renderers/webgl/internal/WebGlUtils.js +31 -0
  156. package/dist/src/core/renderers/webgl/internal/WebGlUtils.js.map +1 -0
  157. package/dist/src/core/shaders/canvas/Border.d.ts +9 -0
  158. package/dist/src/core/shaders/canvas/Border.js +57 -0
  159. package/dist/src/core/shaders/canvas/Border.js.map +1 -0
  160. package/dist/src/core/shaders/canvas/HolePunch.d.ts +7 -0
  161. package/dist/src/core/shaders/canvas/HolePunch.js +38 -0
  162. package/dist/src/core/shaders/canvas/HolePunch.js.map +1 -0
  163. package/dist/src/core/shaders/canvas/LinearGradient.d.ts +10 -0
  164. package/dist/src/core/shaders/canvas/LinearGradient.js +46 -0
  165. package/dist/src/core/shaders/canvas/LinearGradient.js.map +1 -0
  166. package/dist/src/core/shaders/canvas/RadialGradient.d.ts +11 -0
  167. package/dist/src/core/shaders/canvas/RadialGradient.js +68 -0
  168. package/dist/src/core/shaders/canvas/RadialGradient.js.map +1 -0
  169. package/dist/src/core/shaders/canvas/Rounded.d.ts +7 -0
  170. package/dist/src/core/shaders/canvas/Rounded.js +33 -0
  171. package/dist/src/core/shaders/canvas/Rounded.js.map +1 -0
  172. package/dist/src/core/shaders/canvas/RoundedWithBorder.d.ts +7 -0
  173. package/dist/src/core/shaders/canvas/RoundedWithBorder.js +35 -0
  174. package/dist/src/core/shaders/canvas/RoundedWithBorder.js.map +1 -0
  175. package/dist/src/core/shaders/canvas/RoundedWithBorderAndShadow.d.ts +8 -0
  176. package/dist/src/core/shaders/canvas/RoundedWithBorderAndShadow.js +39 -0
  177. package/dist/src/core/shaders/canvas/RoundedWithBorderAndShadow.js.map +1 -0
  178. package/dist/src/core/shaders/canvas/RoundedWithShadow.d.ts +7 -0
  179. package/dist/src/core/shaders/canvas/RoundedWithShadow.js +38 -0
  180. package/dist/src/core/shaders/canvas/RoundedWithShadow.js.map +1 -0
  181. package/dist/src/core/shaders/canvas/Shadow.d.ts +8 -0
  182. package/dist/src/core/shaders/canvas/Shadow.js +31 -0
  183. package/dist/src/core/shaders/canvas/Shadow.js.map +1 -0
  184. package/dist/src/core/shaders/canvas/utils/render.d.ts +5 -0
  185. package/dist/src/core/shaders/canvas/utils/render.js +84 -0
  186. package/dist/src/core/shaders/canvas/utils/render.js.map +1 -0
  187. package/dist/src/core/shaders/templates/BorderTemplate.d.ts +37 -0
  188. package/dist/src/core/shaders/templates/BorderTemplate.js +73 -0
  189. package/dist/src/core/shaders/templates/BorderTemplate.js.map +1 -0
  190. package/dist/src/core/shaders/templates/HolePunchTemplate.d.ts +46 -0
  191. package/dist/src/core/shaders/templates/HolePunchTemplate.js +35 -0
  192. package/dist/src/core/shaders/templates/HolePunchTemplate.js.map +1 -0
  193. package/dist/src/core/shaders/templates/LinearGradientTemplate.d.ts +23 -0
  194. package/dist/src/core/shaders/templates/LinearGradientTemplate.js +47 -0
  195. package/dist/src/core/shaders/templates/LinearGradientTemplate.js.map +1 -0
  196. package/dist/src/core/shaders/templates/RadialGradientTemplate.d.ts +31 -0
  197. package/dist/src/core/shaders/templates/RadialGradientTemplate.js +49 -0
  198. package/dist/src/core/shaders/templates/RadialGradientTemplate.js.map +1 -0
  199. package/dist/src/core/shaders/templates/RoundedTemplate.d.ts +29 -0
  200. package/dist/src/core/shaders/templates/RoundedTemplate.js +67 -0
  201. package/dist/src/core/shaders/templates/RoundedTemplate.js.map +1 -0
  202. package/dist/src/core/shaders/templates/RoundedWithBorderAndShadowTemplate.d.ts +7 -0
  203. package/dist/src/core/shaders/templates/RoundedWithBorderAndShadowTemplate.js +24 -0
  204. package/dist/src/core/shaders/templates/RoundedWithBorderAndShadowTemplate.js.map +1 -0
  205. package/dist/src/core/shaders/templates/RoundedWithBorderTemplate.d.ts +6 -0
  206. package/dist/src/core/shaders/templates/RoundedWithBorderTemplate.js +23 -0
  207. package/dist/src/core/shaders/templates/RoundedWithBorderTemplate.js.map +1 -0
  208. package/dist/src/core/shaders/templates/RoundedWithShadowTemplate.d.ts +6 -0
  209. package/dist/src/core/shaders/templates/RoundedWithShadowTemplate.js +23 -0
  210. package/dist/src/core/shaders/templates/RoundedWithShadowTemplate.js.map +1 -0
  211. package/dist/src/core/shaders/templates/ShadowTemplate.d.ts +34 -0
  212. package/dist/src/core/shaders/templates/ShadowTemplate.js +66 -0
  213. package/dist/src/core/shaders/templates/ShadowTemplate.js.map +1 -0
  214. package/dist/src/core/shaders/templates/shaderUtils.d.ts +5 -0
  215. package/dist/src/core/shaders/templates/shaderUtils.js +41 -0
  216. package/dist/src/core/shaders/templates/shaderUtils.js.map +1 -0
  217. package/dist/src/core/shaders/webgl/Border.d.ts +3 -0
  218. package/dist/src/core/shaders/webgl/Border.js +87 -0
  219. package/dist/src/core/shaders/webgl/Border.js.map +1 -0
  220. package/dist/src/core/shaders/webgl/Default.d.ts +2 -0
  221. package/dist/src/core/shaders/webgl/Default.js +86 -0
  222. package/dist/src/core/shaders/webgl/Default.js.map +1 -0
  223. package/dist/src/core/shaders/webgl/DefaultBatched.d.ts +2 -0
  224. package/dist/src/core/shaders/webgl/DefaultBatched.js +104 -0
  225. package/dist/src/core/shaders/webgl/DefaultBatched.js.map +1 -0
  226. package/dist/src/core/shaders/webgl/HolePunch.d.ts +3 -0
  227. package/dist/src/core/shaders/webgl/HolePunch.js +64 -0
  228. package/dist/src/core/shaders/webgl/HolePunch.js.map +1 -0
  229. package/dist/src/core/shaders/webgl/LinearGradient.d.ts +3 -0
  230. package/dist/src/core/shaders/webgl/LinearGradient.js +75 -0
  231. package/dist/src/core/shaders/webgl/LinearGradient.js.map +1 -0
  232. package/dist/src/core/shaders/webgl/RadialGradient.d.ts +3 -0
  233. package/dist/src/core/shaders/webgl/RadialGradient.js +73 -0
  234. package/dist/src/core/shaders/webgl/RadialGradient.js.map +1 -0
  235. package/dist/src/core/shaders/webgl/Rounded.d.ts +7 -0
  236. package/dist/src/core/shaders/webgl/Rounded.js +86 -0
  237. package/dist/src/core/shaders/webgl/Rounded.js.map +1 -0
  238. package/dist/src/core/shaders/webgl/RoundedWithBorder.d.ts +3 -0
  239. package/dist/src/core/shaders/webgl/RoundedWithBorder.js +97 -0
  240. package/dist/src/core/shaders/webgl/RoundedWithBorder.js.map +1 -0
  241. package/dist/src/core/shaders/webgl/RoundedWithBorderAndShadow.d.ts +3 -0
  242. package/dist/src/core/shaders/webgl/RoundedWithBorderAndShadow.js +112 -0
  243. package/dist/src/core/shaders/webgl/RoundedWithBorderAndShadow.js.map +1 -0
  244. package/dist/src/core/shaders/webgl/RoundedWithShadow.d.ts +3 -0
  245. package/dist/src/core/shaders/webgl/RoundedWithShadow.js +84 -0
  246. package/dist/src/core/shaders/webgl/RoundedWithShadow.js.map +1 -0
  247. package/dist/src/core/shaders/webgl/SdfShader.d.ts +32 -0
  248. package/dist/src/core/shaders/webgl/SdfShader.js +116 -0
  249. package/dist/src/core/shaders/webgl/SdfShader.js.map +1 -0
  250. package/dist/src/core/shaders/webgl/Shadow.d.ts +3 -0
  251. package/dist/src/core/shaders/webgl/Shadow.js +110 -0
  252. package/dist/src/core/shaders/webgl/Shadow.js.map +1 -0
  253. package/dist/src/core/text-rendering/TextRenderingUtils.d.ts +12 -0
  254. package/dist/src/core/text-rendering/TextRenderingUtils.js +14 -0
  255. package/dist/src/core/text-rendering/TextRenderingUtils.js.map +1 -0
  256. package/dist/src/core/text-rendering/TextTextureRendererUtils.d.ts +72 -0
  257. package/dist/src/core/text-rendering/TextTextureRendererUtils.js +217 -0
  258. package/dist/src/core/text-rendering/TextTextureRendererUtils.js.map +1 -0
  259. package/dist/src/core/text-rendering/TrFontManager.d.ts +26 -0
  260. package/dist/src/core/text-rendering/TrFontManager.js +131 -0
  261. package/dist/src/core/text-rendering/TrFontManager.js.map +1 -0
  262. package/dist/src/core/text-rendering/font-face-types/SdfTrFontFace/SdfTrFontFace.d.ts +39 -0
  263. package/dist/src/core/text-rendering/font-face-types/SdfTrFontFace/SdfTrFontFace.js +125 -0
  264. package/dist/src/core/text-rendering/font-face-types/SdfTrFontFace/SdfTrFontFace.js.map +1 -0
  265. package/dist/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/FontShaper.d.ts +103 -0
  266. package/dist/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/FontShaper.js +21 -0
  267. package/dist/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/FontShaper.js.map +1 -0
  268. package/dist/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/SdfFontShaper.d.ts +62 -0
  269. package/dist/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/SdfFontShaper.js +88 -0
  270. package/dist/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/SdfFontShaper.js.map +1 -0
  271. package/dist/src/core/text-rendering/font-face-types/TrFontFace.d.ts +118 -0
  272. package/dist/src/core/text-rendering/font-face-types/TrFontFace.js +63 -0
  273. package/dist/src/core/text-rendering/font-face-types/TrFontFace.js.map +1 -0
  274. package/dist/src/core/text-rendering/font-face-types/WebTrFontFace.d.ts +14 -0
  275. package/dist/src/core/text-rendering/font-face-types/WebTrFontFace.js +66 -0
  276. package/dist/src/core/text-rendering/font-face-types/WebTrFontFace.js.map +1 -0
  277. package/dist/src/core/text-rendering/font-face-types/utils.d.ts +1 -0
  278. package/dist/src/core/text-rendering/font-face-types/utils.js +38 -0
  279. package/dist/src/core/text-rendering/font-face-types/utils.js.map +1 -0
  280. package/dist/src/core/text-rendering/renderers/CanvasTextRenderer.d.ts +59 -0
  281. package/dist/src/core/text-rendering/renderers/CanvasTextRenderer.js +397 -0
  282. package/dist/src/core/text-rendering/renderers/CanvasTextRenderer.js.map +1 -0
  283. package/dist/src/core/text-rendering/renderers/LightningTextTextureRenderer.d.ts +126 -0
  284. package/dist/src/core/text-rendering/renderers/LightningTextTextureRenderer.js +551 -0
  285. package/dist/src/core/text-rendering/renderers/LightningTextTextureRenderer.js.map +1 -0
  286. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.d.ts +91 -0
  287. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.js +611 -0
  288. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.js.map +1 -0
  289. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/PeekableGenerator.d.ts +12 -0
  290. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/PeekableGenerator.js +61 -0
  291. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/PeekableGenerator.js.map +1 -0
  292. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/SpecialCodepoints.d.ts +33 -0
  293. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/SpecialCodepoints.js +52 -0
  294. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/SpecialCodepoints.js.map +1 -0
  295. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/constants.d.ts +13 -0
  296. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/constants.js +32 -0
  297. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/constants.js.map +1 -0
  298. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/getStartConditions.d.ts +23 -0
  299. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/getStartConditions.js +84 -0
  300. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/getStartConditions.js.map +1 -0
  301. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/getUnicodeCodepoints.d.ts +4 -0
  302. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/getUnicodeCodepoints.js +34 -0
  303. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/getUnicodeCodepoints.js.map +1 -0
  304. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText.d.ts +20 -0
  305. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText.js +308 -0
  306. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText.js.map +1 -0
  307. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/measureText.d.ts +10 -0
  308. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/measureText.js +40 -0
  309. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/measureText.js.map +1 -0
  310. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/setRenderWindow.d.ts +26 -0
  311. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/setRenderWindow.js +70 -0
  312. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/setRenderWindow.js.map +1 -0
  313. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/util.d.ts +16 -0
  314. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/util.js +39 -0
  315. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/util.js.map +1 -0
  316. package/dist/src/core/text-rendering/renderers/TextRenderer.d.ts +370 -0
  317. package/dist/src/core/text-rendering/renderers/TextRenderer.js +178 -0
  318. package/dist/src/core/text-rendering/renderers/TextRenderer.js.map +1 -0
  319. package/dist/src/core/textures/ColorTexture.d.ts +36 -0
  320. package/dist/src/core/textures/ColorTexture.js +76 -0
  321. package/dist/src/core/textures/ColorTexture.js.map +1 -0
  322. package/dist/src/core/textures/ImageTexture.d.ts +124 -0
  323. package/dist/src/core/textures/ImageTexture.js +220 -0
  324. package/dist/src/core/textures/ImageTexture.js.map +1 -0
  325. package/dist/src/core/textures/NoiseTexture.d.ts +43 -0
  326. package/dist/src/core/textures/NoiseTexture.js +68 -0
  327. package/dist/src/core/textures/NoiseTexture.js.map +1 -0
  328. package/dist/src/core/textures/RenderTexture.d.ts +29 -0
  329. package/dist/src/core/textures/RenderTexture.js +54 -0
  330. package/dist/src/core/textures/RenderTexture.js.map +1 -0
  331. package/dist/src/core/textures/SubTexture.d.ts +63 -0
  332. package/dist/src/core/textures/SubTexture.js +135 -0
  333. package/dist/src/core/textures/SubTexture.js.map +1 -0
  334. package/dist/src/core/textures/Texture.d.ts +197 -0
  335. package/dist/src/core/textures/Texture.js +201 -0
  336. package/dist/src/core/textures/Texture.js.map +1 -0
  337. package/dist/src/core/utils.d.ts +22 -0
  338. package/dist/src/core/utils.js +173 -0
  339. package/dist/src/core/utils.js.map +1 -0
  340. package/dist/src/main-api/INode.d.ts +63 -0
  341. package/dist/src/main-api/INode.js +2 -0
  342. package/dist/src/main-api/INode.js.map +1 -0
  343. package/dist/src/main-api/Inspector.d.ts +21 -0
  344. package/dist/src/main-api/Inspector.js +376 -0
  345. package/dist/src/main-api/Inspector.js.map +1 -0
  346. package/dist/src/main-api/Renderer.d.ts +414 -0
  347. package/dist/src/main-api/Renderer.js +342 -0
  348. package/dist/src/main-api/Renderer.js.map +1 -0
  349. package/dist/src/main-api/utils.d.ts +2 -0
  350. package/dist/src/main-api/utils.js +34 -0
  351. package/dist/src/main-api/utils.js.map +1 -0
  352. package/dist/src/utils.d.ts +110 -0
  353. package/dist/src/utils.js +229 -0
  354. package/dist/src/utils.js.map +1 -0
  355. package/dist/tsconfig.dist.tsbuildinfo +1 -0
  356. package/exports/canvas-shaders.ts +28 -0
  357. package/exports/canvas.ts +45 -0
  358. package/exports/index.ts +90 -0
  359. package/exports/inspector.ts +24 -0
  360. package/exports/utils.ts +44 -0
  361. package/exports/webgl-shaders.ts +28 -0
  362. package/exports/webgl.ts +50 -0
  363. package/package.json +93 -0
  364. package/scripts/please-use-pnpm.js +13 -0
  365. package/src/common/CommonTypes.ts +146 -0
  366. package/src/common/EventEmitter.ts +77 -0
  367. package/src/common/IAnimationController.ts +92 -0
  368. package/src/common/IEventEmitter.ts +28 -0
  369. package/src/core/CoreNode.test.ts +203 -0
  370. package/src/core/CoreNode.ts +2476 -0
  371. package/src/core/CoreShaderManager.ts +188 -0
  372. package/src/core/CoreTextNode.ts +448 -0
  373. package/src/core/CoreTextureManager.ts +597 -0
  374. package/src/core/Stage.ts +740 -0
  375. package/src/core/TextureMemoryManager.ts +395 -0
  376. package/src/core/animations/AnimationManager.ts +38 -0
  377. package/src/core/animations/CoreAnimation.ts +284 -0
  378. package/src/core/animations/CoreAnimationController.ts +157 -0
  379. package/src/core/lib/ContextSpy.ts +41 -0
  380. package/src/core/lib/ImageWorker.ts +279 -0
  381. package/src/core/lib/Matrix3d.ts +244 -0
  382. package/src/core/lib/RenderCoords.ts +86 -0
  383. package/src/core/lib/WebGlContextWrapper.ts +1324 -0
  384. package/src/core/lib/textureCompression.ts +152 -0
  385. package/src/core/lib/textureSvg.ts +78 -0
  386. package/src/core/lib/utils.ts +361 -0
  387. package/src/core/lib/validateImageBitmap.ts +76 -0
  388. package/src/core/platform.ts +64 -0
  389. package/src/core/renderers/CoreContextTexture.ts +43 -0
  390. package/src/core/renderers/CoreRenderOp.ts +22 -0
  391. package/src/core/renderers/CoreRenderer.ts +107 -0
  392. package/src/core/renderers/CoreShaderNode.ts +171 -0
  393. package/src/core/renderers/CoreShaderProgram.ts +23 -0
  394. package/src/core/renderers/canvas/CanvasRenderer.ts +299 -0
  395. package/src/core/renderers/canvas/CanvasShaderNode.ts +99 -0
  396. package/src/core/renderers/canvas/CanvasTexture.ts +153 -0
  397. package/src/core/renderers/canvas/internal/C2DShaderUtils.ts +220 -0
  398. package/src/core/renderers/canvas/internal/ColorUtils.ts +85 -0
  399. package/src/core/renderers/webgl/WebGlCtxRenderTexture.ts +86 -0
  400. package/src/core/renderers/webgl/WebGlCtxSubTexture.ts +50 -0
  401. package/src/core/renderers/webgl/WebGlCtxTexture.ts +301 -0
  402. package/src/core/renderers/webgl/WebGlRenderOp.ts +145 -0
  403. package/src/core/renderers/webgl/WebGlRenderer.ts +715 -0
  404. package/src/core/renderers/webgl/WebGlShaderNode.ts +433 -0
  405. package/src/core/renderers/webgl/WebGlShaderProgram.ts +310 -0
  406. package/src/core/renderers/webgl/internal/BufferCollection.ts +54 -0
  407. package/src/core/renderers/webgl/internal/RendererUtils.ts +155 -0
  408. package/src/core/renderers/webgl/internal/ShaderUtils.ts +281 -0
  409. package/src/core/renderers/webgl/internal/WebGlUtils.ts +35 -0
  410. package/src/core/shaders/canvas/Border.ts +78 -0
  411. package/src/core/shaders/canvas/HolePunch.ts +62 -0
  412. package/src/core/shaders/canvas/LinearGradient.ts +69 -0
  413. package/src/core/shaders/canvas/RadialGradient.ts +113 -0
  414. package/src/core/shaders/canvas/Rounded.ts +55 -0
  415. package/src/core/shaders/canvas/RoundedWithBorder.ts +68 -0
  416. package/src/core/shaders/canvas/RoundedWithBorderAndShadow.ts +88 -0
  417. package/src/core/shaders/canvas/RoundedWithShadow.ts +69 -0
  418. package/src/core/shaders/canvas/Shadow.ts +52 -0
  419. package/src/core/shaders/canvas/utils/render.ts +151 -0
  420. package/src/core/shaders/templates/BorderTemplate.ts +115 -0
  421. package/src/core/shaders/templates/HolePunchTemplate.ts +82 -0
  422. package/src/core/shaders/templates/LinearGradientTemplate.ts +71 -0
  423. package/src/core/shaders/templates/RadialGradientTemplate.ts +81 -0
  424. package/src/core/shaders/templates/RoundedTemplate.ts +98 -0
  425. package/src/core/shaders/templates/RoundedWithBorderAndShadowTemplate.ts +38 -0
  426. package/src/core/shaders/templates/RoundedWithBorderTemplate.ts +35 -0
  427. package/src/core/shaders/templates/RoundedWithShadowTemplate.ts +35 -0
  428. package/src/core/shaders/templates/ShadowTemplate.ts +106 -0
  429. package/src/core/shaders/templates/shaderUtils.ts +47 -0
  430. package/src/core/shaders/webgl/Border.ts +96 -0
  431. package/src/core/shaders/webgl/Default.ts +89 -0
  432. package/src/core/shaders/webgl/DefaultBatched.ts +129 -0
  433. package/src/core/shaders/webgl/HolePunch.ts +78 -0
  434. package/src/core/shaders/webgl/LinearGradient.ts +81 -0
  435. package/src/core/shaders/webgl/RadialGradient.ts +84 -0
  436. package/src/core/shaders/webgl/Rounded.ts +117 -0
  437. package/src/core/shaders/webgl/RoundedWithBorder.ts +114 -0
  438. package/src/core/shaders/webgl/RoundedWithBorderAndShadow.ts +133 -0
  439. package/src/core/shaders/webgl/RoundedWithShadow.ts +98 -0
  440. package/src/core/shaders/webgl/SdfShader.ts +137 -0
  441. package/src/core/shaders/webgl/Shadow.ts +115 -0
  442. package/src/core/text-rendering/TextRenderingUtils.ts +36 -0
  443. package/src/core/text-rendering/TextTextureRendererUtils.ts +263 -0
  444. package/src/core/text-rendering/TrFontManager.ts +183 -0
  445. package/src/core/text-rendering/font-face-types/SdfTrFontFace/SdfTrFontFace.ts +176 -0
  446. package/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/FontShaper.ts +139 -0
  447. package/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/SdfFontShaper.test.ts +173 -0
  448. package/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/SdfFontShaper.ts +171 -0
  449. package/src/core/text-rendering/font-face-types/TrFontFace.ts +187 -0
  450. package/src/core/text-rendering/font-face-types/WebTrFontFace.ts +94 -0
  451. package/src/core/text-rendering/font-face-types/utils.ts +39 -0
  452. package/src/core/text-rendering/renderers/CanvasTextRenderer.ts +509 -0
  453. package/src/core/text-rendering/renderers/LightningTextTextureRenderer.ts +815 -0
  454. package/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.ts +841 -0
  455. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/PeekableGenerator.test.ts +48 -0
  456. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/PeekableGenerator.ts +66 -0
  457. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/SpecialCodepoints.ts +52 -0
  458. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/constants.ts +32 -0
  459. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/getStartConditions.ts +117 -0
  460. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/getUnicodeCodepoints.test.ts +133 -0
  461. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/getUnicodeCodepoints.ts +38 -0
  462. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText.ts +408 -0
  463. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/measureText.test.ts +49 -0
  464. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/measureText.ts +52 -0
  465. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/setRenderWindow.test.ts +205 -0
  466. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/setRenderWindow.ts +93 -0
  467. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/util.ts +40 -0
  468. package/src/core/text-rendering/renderers/TextRenderer.ts +550 -0
  469. package/src/core/textures/ColorTexture.ts +102 -0
  470. package/src/core/textures/ImageTexture.ts +376 -0
  471. package/src/core/textures/NoiseTexture.ts +104 -0
  472. package/src/core/textures/RenderTexture.ts +85 -0
  473. package/src/core/textures/SubTexture.ts +205 -0
  474. package/src/core/textures/Texture.ts +337 -0
  475. package/src/core/utils.ts +227 -0
  476. package/src/env.d.ts +7 -0
  477. package/src/main-api/INode.ts +100 -0
  478. package/src/main-api/Inspector.ts +522 -0
  479. package/src/main-api/Renderer.ts +649 -0
  480. package/src/main-api/utils.ts +45 -0
  481. package/src/utils.ts +267 -0
@@ -0,0 +1,815 @@
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
+ /* eslint-disable @typescript-eslint/no-non-null-assertion */
21
+
22
+ import { assertTruthy } from '../../../utils.js';
23
+ import { getRgbaString, type RGBA } from '../../lib/utils.js';
24
+ import { calcDefaultLineHeight } from '../TextRenderingUtils.js';
25
+ import {
26
+ getWebFontMetrics,
27
+ isZeroWidthSpace,
28
+ } from '../TextTextureRendererUtils.js';
29
+ import type { NormalizedFontMetrics } from '../font-face-types/TrFontFace.js';
30
+ import type { WebTrFontFace } from '../font-face-types/WebTrFontFace.js';
31
+
32
+ const MAX_TEXTURE_DIMENSION = 2048;
33
+
34
+ /**
35
+ * Text Overflow Values
36
+ */
37
+ export type TextOverflow =
38
+ | 'ellipsis'
39
+ | 'clip'
40
+ | (string & Record<never, never>);
41
+
42
+ /***
43
+ * Text Horizontal Align Values
44
+ */
45
+ export type TextAlign = 'left' | 'center' | 'right';
46
+
47
+ /***
48
+ * Text Baseline Values
49
+ */
50
+ export type TextBaseline =
51
+ | 'alphabetic'
52
+ | 'top'
53
+ | 'hanging'
54
+ | 'middle'
55
+ | 'ideographic'
56
+ | 'bottom';
57
+
58
+ /***
59
+ * Text Vertical Align Values
60
+ */
61
+ export type TextVerticalAlign = 'top' | 'middle' | 'bottom';
62
+
63
+ /**
64
+ * Text Texture Settings
65
+ */
66
+ export interface Settings {
67
+ w: number;
68
+ h: number;
69
+ text: string;
70
+ fontStyle: string;
71
+ fontSize: number;
72
+ fontBaselineRatio: number;
73
+ fontFamily: string | null;
74
+ trFontFace: WebTrFontFace | null;
75
+ wordWrap: boolean;
76
+ wordWrapWidth: number;
77
+ wordBreak: boolean;
78
+ textOverflow: TextOverflow | null;
79
+ lineHeight: number | null;
80
+ textBaseline: TextBaseline;
81
+ textAlign: TextAlign;
82
+ verticalAlign: TextVerticalAlign;
83
+ offsetY: number | null;
84
+ maxLines: number;
85
+ maxHeight: number | null;
86
+ overflowSuffix: string;
87
+ precision: number;
88
+ textColor: RGBA;
89
+ paddingLeft: number;
90
+ paddingRight: number;
91
+ shadow: boolean;
92
+ shadowColor: RGBA;
93
+ shadowOffsetX: number;
94
+ shadowOffsetY: number;
95
+ shadowBlur: number;
96
+ highlight: boolean;
97
+ highlightHeight: number;
98
+ highlightColor: RGBA;
99
+ highlightOffset: number;
100
+ highlightPaddingLeft: number;
101
+ highlightPaddingRight: number;
102
+ letterSpacing: number;
103
+ textIndent: number;
104
+ cutSx: number;
105
+ cutSy: number;
106
+ cutEx: number;
107
+ cutEy: number;
108
+ advancedRenderer: boolean;
109
+
110
+ // Normally stage options
111
+ textRenderIssueMargin: number;
112
+ }
113
+
114
+ export interface RenderInfo {
115
+ w: number;
116
+ h: number;
117
+ lines: string[];
118
+ precision: number;
119
+ remainingText: string;
120
+ moreTextLines: boolean;
121
+ width: number;
122
+ innerWidth: number;
123
+ height: number;
124
+ fontSize: number;
125
+ cutSx: number;
126
+ cutSy: number;
127
+ cutEx: number;
128
+ cutEy: number;
129
+ lineHeight: number;
130
+ defLineHeight: number;
131
+ lineWidths: number[];
132
+ offsetY: number;
133
+ paddingLeft: number;
134
+ paddingRight: number;
135
+ letterSpacing: number;
136
+ textIndent: number;
137
+ metrics: NormalizedFontMetrics;
138
+ }
139
+
140
+ export interface LineType {
141
+ text: string;
142
+ x: number;
143
+ y: number;
144
+ w: number;
145
+ }
146
+
147
+ /**
148
+ * Calculate height for the canvas
149
+ *
150
+ * @param textBaseline
151
+ * @param fontSize
152
+ * @param lineHeight
153
+ * @param numLines
154
+ * @param offsetY
155
+ * @returns
156
+ */
157
+ function calcHeight(
158
+ textBaseline: TextBaseline,
159
+ fontSize: number,
160
+ lineHeight: number,
161
+ numLines: number,
162
+ offsetY: number | null,
163
+ ) {
164
+ const baselineOffset = textBaseline !== 'bottom' ? 0.5 * fontSize : 0;
165
+ return (
166
+ lineHeight * (numLines - 1) +
167
+ baselineOffset +
168
+ Math.max(lineHeight, fontSize) +
169
+ (offsetY || 0)
170
+ );
171
+ }
172
+
173
+ export class LightningTextTextureRenderer {
174
+ private _canvas: OffscreenCanvas | HTMLCanvasElement;
175
+ private _context:
176
+ | OffscreenCanvasRenderingContext2D
177
+ | CanvasRenderingContext2D;
178
+ private _settings: Settings;
179
+
180
+ constructor(
181
+ canvas: OffscreenCanvas | HTMLCanvasElement,
182
+ context: OffscreenCanvasRenderingContext2D | CanvasRenderingContext2D,
183
+ ) {
184
+ this._canvas = canvas;
185
+ this._context = context;
186
+ this._settings = this.mergeDefaults({});
187
+ }
188
+
189
+ set settings(v: Partial<Settings>) {
190
+ this._settings = this.mergeDefaults(v);
191
+ }
192
+
193
+ get settings(): Settings {
194
+ return this._settings;
195
+ }
196
+
197
+ getPrecision() {
198
+ return this._settings.precision;
199
+ }
200
+
201
+ setFontProperties() {
202
+ this._context.font = this._getFontSetting();
203
+ this._context.textBaseline = this._settings.textBaseline;
204
+ }
205
+
206
+ _getFontSetting() {
207
+ const ff = [this._settings.fontFamily];
208
+
209
+ const ffs: string[] = [];
210
+ for (let i = 0, n = ff.length; i < n; i++) {
211
+ if (ff[i] === 'serif' || ff[i] === 'sans-serif') {
212
+ ffs.push(ff[i]!);
213
+ } else {
214
+ ffs.push(`"${ff[i]!}"`);
215
+ }
216
+ }
217
+
218
+ return `${this._settings.fontStyle} ${
219
+ this._settings.fontSize * this.getPrecision()
220
+ }px ${ffs.join(',')}`;
221
+ }
222
+
223
+ _load() {
224
+ if (true && document.fonts) {
225
+ const fontSetting = this._getFontSetting();
226
+ try {
227
+ if (!document.fonts.check(fontSetting, this._settings.text)) {
228
+ // Use a promise that waits for loading.
229
+ return document.fonts
230
+ .load(fontSetting, this._settings.text)
231
+ .catch((err) => {
232
+ // Just load the fallback font.
233
+ console.warn('[Lightning] Font load error', err, fontSetting);
234
+ })
235
+ .then(() => {
236
+ if (!document.fonts.check(fontSetting, this._settings.text)) {
237
+ console.warn('[Lightning] Font not found', fontSetting);
238
+ }
239
+ });
240
+ }
241
+ } catch (e) {
242
+ console.warn("[Lightning] Can't check font loading for " + fontSetting);
243
+ }
244
+ }
245
+ }
246
+
247
+ calculateRenderInfo(): RenderInfo {
248
+ const renderInfo: Partial<RenderInfo> = {};
249
+
250
+ const precision = this.getPrecision();
251
+
252
+ const paddingLeft = this._settings.paddingLeft * precision;
253
+ const paddingRight = this._settings.paddingRight * precision;
254
+ const fontSize = this._settings.fontSize * precision;
255
+ let offsetY =
256
+ this._settings.offsetY === null
257
+ ? null
258
+ : this._settings.offsetY * precision;
259
+ const w = this._settings.w * precision;
260
+ const h = this._settings.h * precision;
261
+ let wordWrapWidth = this._settings.wordWrapWidth * precision;
262
+ const cutSx = this._settings.cutSx * precision;
263
+ const cutEx = this._settings.cutEx * precision;
264
+ const cutSy = this._settings.cutSy * precision;
265
+ const cutEy = this._settings.cutEy * precision;
266
+ const letterSpacing = (this._settings.letterSpacing || 0) * precision;
267
+ const textIndent = this._settings.textIndent * precision;
268
+ const trFontFace = this._settings.trFontFace;
269
+
270
+ // Set font properties.
271
+ this.setFontProperties();
272
+
273
+ assertTruthy(trFontFace);
274
+ const metrics = getWebFontMetrics(this._context, trFontFace, fontSize);
275
+ const defLineHeight = calcDefaultLineHeight(metrics, fontSize) * precision;
276
+ const lineHeight =
277
+ this._settings.lineHeight !== null
278
+ ? this._settings.lineHeight * precision
279
+ : defLineHeight;
280
+
281
+ const maxHeight = this._settings.maxHeight;
282
+ const containedMaxLines =
283
+ maxHeight !== null && lineHeight > 0
284
+ ? Math.floor(maxHeight / lineHeight)
285
+ : 0;
286
+
287
+ const setMaxLines = this._settings.maxLines;
288
+ const calcMaxLines =
289
+ containedMaxLines > 0 && setMaxLines > 0
290
+ ? Math.min(containedMaxLines, setMaxLines)
291
+ : Math.max(containedMaxLines, setMaxLines);
292
+
293
+ // Total width.
294
+ let width = w || 2048 / this.getPrecision();
295
+
296
+ // Inner width.
297
+ let innerWidth = width - paddingLeft;
298
+ if (innerWidth < 10) {
299
+ width += 10 - innerWidth;
300
+ innerWidth = 10;
301
+ }
302
+
303
+ if (!wordWrapWidth) {
304
+ wordWrapWidth = innerWidth;
305
+ }
306
+
307
+ // Text overflow
308
+ if (this._settings.textOverflow && !this._settings.wordWrap) {
309
+ let suffix;
310
+ switch (this._settings.textOverflow) {
311
+ case 'clip':
312
+ suffix = '';
313
+ break;
314
+ case 'ellipsis':
315
+ suffix = this._settings.overflowSuffix;
316
+ break;
317
+ default:
318
+ suffix = this._settings.textOverflow;
319
+ }
320
+ this._settings.text = this.wrapWord(
321
+ this._settings.text,
322
+ wordWrapWidth - textIndent,
323
+ suffix,
324
+ );
325
+ }
326
+
327
+ // word wrap
328
+ // preserve original text
329
+ let linesInfo: { n: number[]; l: string[] };
330
+ if (this._settings.wordWrap) {
331
+ linesInfo = this.wrapText(
332
+ this._settings.text,
333
+ wordWrapWidth,
334
+ letterSpacing,
335
+ textIndent,
336
+ );
337
+ } else {
338
+ linesInfo = { l: this._settings.text.split(/(?:\r\n|\r|\n)/), n: [] };
339
+ const n = linesInfo.l.length;
340
+ for (let i = 0; i < n - 1; i++) {
341
+ linesInfo.n.push(i);
342
+ }
343
+ }
344
+ let lines = linesInfo.l;
345
+
346
+ if (calcMaxLines && lines.length > calcMaxLines) {
347
+ const usedLines = lines.slice(0, calcMaxLines);
348
+
349
+ let otherLines: string[] | null = null;
350
+ if (this._settings.overflowSuffix) {
351
+ // Wrap again with max lines suffix enabled.
352
+ const w = this._settings.overflowSuffix
353
+ ? this.measureText(this._settings.overflowSuffix)
354
+ : 0;
355
+ const al = this.wrapText(
356
+ usedLines[usedLines.length - 1]!,
357
+ wordWrapWidth - w,
358
+ letterSpacing,
359
+ textIndent,
360
+ );
361
+ usedLines[usedLines.length - 1] = `${al.l[0]!}${
362
+ this._settings.overflowSuffix
363
+ }`;
364
+ otherLines = [al.l.length > 1 ? al.l[1]! : ''];
365
+ } else {
366
+ otherLines = [''];
367
+ }
368
+
369
+ // Re-assemble the remaining text.
370
+ let i;
371
+ const n = lines.length;
372
+ let j = 0;
373
+ const m = linesInfo.n.length;
374
+ for (i = calcMaxLines; i < n; i++) {
375
+ otherLines[j] += `${otherLines[j] ? ' ' : ''}${lines[i]!}`;
376
+ if (i + 1 < m && linesInfo.n[i + 1]) {
377
+ j++;
378
+ }
379
+ }
380
+
381
+ renderInfo.remainingText = otherLines.join('\n');
382
+
383
+ renderInfo.moreTextLines = true;
384
+
385
+ lines = usedLines;
386
+ } else {
387
+ renderInfo.moreTextLines = false;
388
+ renderInfo.remainingText = '';
389
+ }
390
+
391
+ // calculate text width
392
+ let maxLineWidth = 0;
393
+ const lineWidths: number[] = [];
394
+ for (let i = 0; i < lines.length; i++) {
395
+ const lineWidth =
396
+ this.measureText(lines[i]!, letterSpacing) + (i === 0 ? textIndent : 0);
397
+ lineWidths.push(lineWidth);
398
+ maxLineWidth = Math.max(maxLineWidth, lineWidth);
399
+ }
400
+
401
+ renderInfo.lineWidths = lineWidths;
402
+
403
+ if (!w) {
404
+ // Auto-set width to max text length.
405
+ width = maxLineWidth + paddingLeft + paddingRight;
406
+ innerWidth = maxLineWidth;
407
+ }
408
+
409
+ // If word wrap is enabled the width needs to be the width of the text.
410
+ if (
411
+ this._settings.wordWrap &&
412
+ w > maxLineWidth &&
413
+ this._settings.textAlign === 'left' &&
414
+ lines.length === 1
415
+ ) {
416
+ width = maxLineWidth + paddingLeft + paddingRight;
417
+ }
418
+
419
+ let height;
420
+ if (h) {
421
+ height = h;
422
+ } else {
423
+ height = calcHeight(
424
+ this._settings.textBaseline,
425
+ fontSize,
426
+ lineHeight,
427
+ lines.length,
428
+ offsetY,
429
+ );
430
+ }
431
+
432
+ if (offsetY === null) {
433
+ offsetY = fontSize;
434
+ }
435
+
436
+ renderInfo.w = width;
437
+ renderInfo.h = height;
438
+ renderInfo.lines = lines;
439
+ renderInfo.precision = precision;
440
+
441
+ if (!width) {
442
+ // To prevent canvas errors.
443
+ width = 1;
444
+ }
445
+
446
+ if (!height) {
447
+ // To prevent canvas errors.
448
+ height = 1;
449
+ }
450
+
451
+ if (cutSx || cutEx) {
452
+ width = Math.min(width, cutEx - cutSx);
453
+ }
454
+
455
+ if (cutSy || cutEy) {
456
+ height = Math.min(height, cutEy - cutSy);
457
+ }
458
+
459
+ renderInfo.width = width;
460
+ renderInfo.innerWidth = innerWidth;
461
+ renderInfo.height = height;
462
+ renderInfo.fontSize = fontSize;
463
+ renderInfo.cutSx = cutSx;
464
+ renderInfo.cutSy = cutSy;
465
+ renderInfo.cutEx = cutEx;
466
+ renderInfo.cutEy = cutEy;
467
+ renderInfo.lineHeight = lineHeight;
468
+ renderInfo.defLineHeight = defLineHeight;
469
+ renderInfo.lineWidths = lineWidths;
470
+ renderInfo.offsetY = offsetY;
471
+ renderInfo.paddingLeft = paddingLeft;
472
+ renderInfo.paddingRight = paddingRight;
473
+ renderInfo.letterSpacing = letterSpacing;
474
+ renderInfo.textIndent = textIndent;
475
+ renderInfo.metrics = metrics;
476
+
477
+ return renderInfo as RenderInfo;
478
+ }
479
+
480
+ draw(
481
+ renderInfo: RenderInfo,
482
+ linesOverride?: { lines: string[]; lineWidths: number[] },
483
+ ) {
484
+ const precision = this.getPrecision();
485
+
486
+ // Allow lines to be overriden for partial rendering.
487
+ const lines = linesOverride?.lines || renderInfo.lines;
488
+ const lineWidths = linesOverride?.lineWidths || renderInfo.lineWidths;
489
+ const height = linesOverride
490
+ ? calcHeight(
491
+ this._settings.textBaseline,
492
+ renderInfo.fontSize,
493
+ renderInfo.lineHeight,
494
+ linesOverride.lines.length,
495
+ this._settings.offsetY === null
496
+ ? null
497
+ : this._settings.offsetY * precision,
498
+ )
499
+ : renderInfo.height;
500
+
501
+ // Add extra margin to prevent issue with clipped text when scaling.
502
+ this._canvas.width = Math.min(
503
+ Math.ceil(renderInfo.width + this._settings.textRenderIssueMargin),
504
+ MAX_TEXTURE_DIMENSION,
505
+ );
506
+ this._canvas.height = Math.min(Math.ceil(height), MAX_TEXTURE_DIMENSION);
507
+
508
+ // Canvas context has been reset.
509
+ this.setFontProperties();
510
+
511
+ if (renderInfo.fontSize >= 128) {
512
+ // WpeWebKit bug: must force compositing because cairo-traps-compositor will not work with text first.
513
+ this._context.globalAlpha = 0.01;
514
+ this._context.fillRect(0, 0, 0.01, 0.01);
515
+ this._context.globalAlpha = 1.0;
516
+ }
517
+
518
+ if (renderInfo.cutSx || renderInfo.cutSy) {
519
+ this._context.translate(-renderInfo.cutSx, -renderInfo.cutSy);
520
+ }
521
+
522
+ let linePositionX;
523
+ let linePositionY;
524
+
525
+ const drawLines: LineType[] = [];
526
+
527
+ const { metrics } = renderInfo;
528
+
529
+ /**
530
+ * Ascender (in pixels)
531
+ */
532
+ const ascenderPx = metrics
533
+ ? metrics.ascender * renderInfo.fontSize
534
+ : renderInfo.fontSize;
535
+
536
+ /**
537
+ * Bare line height is the distance between the ascender and descender of the font.
538
+ * without the line gap metric.
539
+ */
540
+ const bareLineHeightPx =
541
+ (metrics.ascender - metrics.descender) * renderInfo.fontSize;
542
+
543
+ // Draw lines line by line.
544
+ for (let i = 0, n = lines.length; i < n; i++) {
545
+ linePositionX = i === 0 ? renderInfo.textIndent : 0;
546
+
547
+ // By default, text is aligned to top
548
+ linePositionY = i * renderInfo.lineHeight + ascenderPx;
549
+
550
+ if (this._settings.verticalAlign == 'middle') {
551
+ linePositionY += (renderInfo.lineHeight - bareLineHeightPx) / 2;
552
+ } else if (this._settings.verticalAlign == 'bottom') {
553
+ linePositionY += renderInfo.lineHeight - bareLineHeightPx;
554
+ }
555
+
556
+ if (this._settings.textAlign === 'right') {
557
+ linePositionX += renderInfo.innerWidth - lineWidths[i]!;
558
+ } else if (this._settings.textAlign === 'center') {
559
+ linePositionX += (renderInfo.innerWidth - lineWidths[i]!) / 2;
560
+ }
561
+ linePositionX += renderInfo.paddingLeft;
562
+
563
+ drawLines.push({
564
+ text: lines[i]!,
565
+ x: linePositionX,
566
+ y: linePositionY,
567
+ w: lineWidths[i]!,
568
+ });
569
+ }
570
+
571
+ // Highlight.
572
+ if (this._settings.highlight) {
573
+ const color = this._settings.highlightColor;
574
+
575
+ const hlHeight =
576
+ this._settings.highlightHeight * precision || renderInfo.fontSize * 1.5;
577
+ const offset = this._settings.highlightOffset * precision;
578
+ const hlPaddingLeft =
579
+ this._settings.highlightPaddingLeft !== null
580
+ ? this._settings.highlightPaddingLeft * precision
581
+ : renderInfo.paddingLeft;
582
+ const hlPaddingRight =
583
+ this._settings.highlightPaddingRight !== null
584
+ ? this._settings.highlightPaddingRight * precision
585
+ : renderInfo.paddingRight;
586
+
587
+ this._context.fillStyle = getRgbaString(color);
588
+ for (let i = 0; i < drawLines.length; i++) {
589
+ const drawLine = drawLines[i]!;
590
+ this._context.fillRect(
591
+ drawLine.x - hlPaddingLeft,
592
+ drawLine.y - renderInfo.offsetY + offset,
593
+ drawLine.w + hlPaddingRight + hlPaddingLeft,
594
+ hlHeight,
595
+ );
596
+ }
597
+ }
598
+
599
+ // Text shadow.
600
+ let prevShadowSettings: null | [string, number, number, number] = null;
601
+ if (this._settings.shadow) {
602
+ prevShadowSettings = [
603
+ this._context.shadowColor,
604
+ this._context.shadowOffsetX,
605
+ this._context.shadowOffsetY,
606
+ this._context.shadowBlur,
607
+ ];
608
+
609
+ this._context.shadowColor = getRgbaString(this._settings.shadowColor);
610
+ this._context.shadowOffsetX = this._settings.shadowOffsetX * precision;
611
+ this._context.shadowOffsetY = this._settings.shadowOffsetY * precision;
612
+ this._context.shadowBlur = this._settings.shadowBlur * precision;
613
+ }
614
+
615
+ this._context.fillStyle = getRgbaString(this._settings.textColor);
616
+ for (let i = 0, n = drawLines.length; i < n; i++) {
617
+ const drawLine = drawLines[i]!;
618
+
619
+ if (renderInfo.letterSpacing === 0) {
620
+ this._context.fillText(drawLine.text, drawLine.x, drawLine.y);
621
+ } else {
622
+ const textSplit = drawLine.text.split('');
623
+ let x = drawLine.x;
624
+ for (let i = 0, j = textSplit.length; i < j; i++) {
625
+ this._context.fillText(textSplit[i]!, x, drawLine.y);
626
+ x += this.measureText(textSplit[i]!, renderInfo.letterSpacing);
627
+ }
628
+ }
629
+ }
630
+
631
+ if (prevShadowSettings) {
632
+ this._context.shadowColor = prevShadowSettings[0];
633
+ this._context.shadowOffsetX = prevShadowSettings[1];
634
+ this._context.shadowOffsetY = prevShadowSettings[2];
635
+ this._context.shadowBlur = prevShadowSettings[3];
636
+ }
637
+
638
+ if (renderInfo.cutSx || renderInfo.cutSy) {
639
+ this._context.translate(renderInfo.cutSx, renderInfo.cutSy);
640
+ }
641
+ }
642
+
643
+ wrapWord(word: string, wordWrapWidth: number, suffix: string) {
644
+ const suffixWidth = this._context.measureText(suffix).width;
645
+ const wordLen = word.length;
646
+ const wordWidth = this._context.measureText(word).width;
647
+
648
+ /* If word fits wrapWidth, do nothing */
649
+ if (wordWidth <= wordWrapWidth) {
650
+ return word;
651
+ }
652
+
653
+ /* Make initial guess for text cuttoff */
654
+ let cutoffIndex = Math.floor((wordWrapWidth * wordLen) / wordWidth);
655
+ let truncWordWidth =
656
+ this._context.measureText(word.substring(0, cutoffIndex)).width +
657
+ suffixWidth;
658
+
659
+ /* In case guess was overestimated, shrink it letter by letter. */
660
+ if (truncWordWidth > wordWrapWidth) {
661
+ while (cutoffIndex > 0) {
662
+ truncWordWidth =
663
+ this._context.measureText(word.substring(0, cutoffIndex)).width +
664
+ suffixWidth;
665
+ if (truncWordWidth > wordWrapWidth) {
666
+ cutoffIndex -= 1;
667
+ } else {
668
+ break;
669
+ }
670
+ }
671
+
672
+ /* In case guess was underestimated, extend it letter by letter. */
673
+ } else {
674
+ while (cutoffIndex < wordLen) {
675
+ truncWordWidth =
676
+ this._context.measureText(word.substring(0, cutoffIndex)).width +
677
+ suffixWidth;
678
+ if (truncWordWidth < wordWrapWidth) {
679
+ cutoffIndex += 1;
680
+ } else {
681
+ // Finally, when bound is crossed, retract last letter.
682
+ cutoffIndex -= 1;
683
+ break;
684
+ }
685
+ }
686
+ }
687
+
688
+ /* If wrapWidth is too short to even contain suffix alone, return empty string */
689
+ return (
690
+ word.substring(0, cutoffIndex) +
691
+ (wordWrapWidth >= suffixWidth ? suffix : '')
692
+ );
693
+ }
694
+
695
+ /**
696
+ * Applies newlines to a string to have it optimally fit into the horizontal
697
+ * bounds set by the Text object's wordWrapWidth property.
698
+ */
699
+ wrapText(
700
+ text: string,
701
+ wordWrapWidth: number,
702
+ letterSpacing: number,
703
+ indent = 0,
704
+ ) {
705
+ const spaceRegex = / |\u200B/g; // ZWSP and spaces
706
+ const lines = text.split(/\r?\n/g);
707
+ let allLines: string[] = [];
708
+ const realNewlines: number[] = [];
709
+
710
+ for (let i = 0; i < lines.length; i++) {
711
+ const resultLines: string[] = [];
712
+ let result = '';
713
+ let spaceLeft = wordWrapWidth - indent;
714
+
715
+ // Split the line into words, considering ZWSP
716
+ const words = lines[i]!.split(spaceRegex);
717
+ const spaces = lines[i]!.match(spaceRegex) || [];
718
+
719
+ for (let j = 0; j < words.length; j++) {
720
+ const space = spaces[j - 1] || '';
721
+ const word = words[j]!;
722
+ const wordWidth = this.measureText(word, letterSpacing);
723
+ const wordWidthWithSpace = isZeroWidthSpace(space)
724
+ ? wordWidth
725
+ : wordWidth + this.measureText(space, letterSpacing);
726
+
727
+ if (j === 0 || wordWidthWithSpace > spaceLeft) {
728
+ if (j > 0) {
729
+ resultLines.push(result);
730
+ result = '';
731
+ }
732
+ result += word;
733
+ spaceLeft = wordWrapWidth - wordWidth - (j === 0 ? indent : 0);
734
+ } else {
735
+ spaceLeft -= wordWidthWithSpace;
736
+ result += space + word;
737
+ }
738
+ }
739
+
740
+ resultLines.push(result);
741
+ result = '';
742
+ allLines = allLines.concat(resultLines);
743
+
744
+ if (i < lines.length - 1) {
745
+ realNewlines.push(allLines.length);
746
+ }
747
+ }
748
+
749
+ return { l: allLines, n: realNewlines };
750
+ }
751
+
752
+ measureText(word: string, space = 0) {
753
+ if (!space) {
754
+ return this._context.measureText(word).width;
755
+ }
756
+
757
+ // Split word into characters, but skip ZWSP in the width calculation
758
+ return word.split('').reduce((acc, char) => {
759
+ // Check if the character is a zero-width space and skip it
760
+ if (isZeroWidthSpace(char)) {
761
+ return acc;
762
+ }
763
+ return acc + this._context.measureText(char).width + space;
764
+ }, 0);
765
+ }
766
+
767
+ mergeDefaults(settings: Partial<Settings>): Settings {
768
+ return {
769
+ text: '',
770
+ w: 0,
771
+ h: 0,
772
+ fontStyle: 'normal',
773
+ fontSize: 40,
774
+ fontFamily: null,
775
+ trFontFace: null,
776
+ wordWrap: true,
777
+ wordWrapWidth: 0,
778
+ wordBreak: false,
779
+ textOverflow: '',
780
+ lineHeight: null,
781
+ textBaseline: 'alphabetic',
782
+ textAlign: 'left',
783
+ verticalAlign: 'top',
784
+ offsetY: null,
785
+ maxLines: 0,
786
+ maxHeight: null,
787
+ overflowSuffix: '...',
788
+ textColor: [1.0, 1.0, 1.0, 1.0],
789
+ paddingLeft: 0,
790
+ paddingRight: 0,
791
+ shadow: false,
792
+ shadowColor: [0.0, 0.0, 0.0, 1.0],
793
+ shadowOffsetX: 0,
794
+ shadowOffsetY: 0,
795
+ shadowBlur: 5,
796
+ highlight: false,
797
+ highlightHeight: 0,
798
+ highlightColor: [0.0, 0.0, 0.0, 1.0],
799
+ highlightOffset: 0,
800
+ highlightPaddingLeft: 0,
801
+ highlightPaddingRight: 0,
802
+ letterSpacing: 0,
803
+ textIndent: 0,
804
+ cutSx: 0,
805
+ cutEx: 0,
806
+ cutSy: 0,
807
+ cutEy: 0,
808
+ advancedRenderer: false,
809
+ fontBaselineRatio: 0,
810
+ precision: 1,
811
+ textRenderIssueMargin: 0,
812
+ ...settings,
813
+ };
814
+ }
815
+ }