@lightningjs/renderer 2.20.0 → 2.20.1

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 (207) hide show
  1. package/dist/exports/canvas-shaders.d.ts +10 -0
  2. package/dist/exports/canvas-shaders.js +27 -0
  3. package/dist/exports/canvas-shaders.js.map +1 -0
  4. package/dist/exports/webgl-shaders.d.ts +11 -0
  5. package/dist/exports/webgl-shaders.js +28 -0
  6. package/dist/exports/webgl-shaders.js.map +1 -0
  7. package/dist/src/common/CommonTypes.d.ts +11 -0
  8. package/dist/src/core/AutosizeManager.d.ts +29 -0
  9. package/dist/src/core/AutosizeManager.js +171 -0
  10. package/dist/src/core/AutosizeManager.js.map +1 -0
  11. package/dist/src/core/CoreNode.d.ts +1 -1
  12. package/dist/src/core/CoreNode.js +8 -0
  13. package/dist/src/core/CoreNode.js.map +1 -1
  14. package/dist/src/core/Stage.js +2 -1
  15. package/dist/src/core/Stage.js.map +1 -1
  16. package/dist/src/core/animations/Animation.d.ts +16 -0
  17. package/dist/src/core/animations/Animation.js +111 -0
  18. package/dist/src/core/animations/Animation.js.map +1 -0
  19. package/dist/src/core/animations/CoreTransition.d.ts +24 -0
  20. package/dist/src/core/animations/CoreTransition.js +63 -0
  21. package/dist/src/core/animations/CoreTransition.js.map +1 -0
  22. package/dist/src/core/animations/Playback.d.ts +62 -0
  23. package/dist/src/core/animations/Playback.js +155 -0
  24. package/dist/src/core/animations/Playback.js.map +1 -0
  25. package/dist/src/core/animations/Transition.d.ts +25 -0
  26. package/dist/src/core/animations/Transition.js +63 -0
  27. package/dist/src/core/animations/Transition.js.map +1 -0
  28. package/dist/src/core/animations/utils.d.ts +2 -0
  29. package/dist/src/core/animations/utils.js +137 -0
  30. package/dist/src/core/animations/utils.js.map +1 -0
  31. package/dist/src/core/lib/WebGlContextWrapper.d.ts +5 -5
  32. package/dist/src/core/lib/collectionUtils.d.ts +5 -0
  33. package/dist/src/core/lib/collectionUtils.js +100 -0
  34. package/dist/src/core/lib/collectionUtils.js.map +1 -0
  35. package/dist/src/core/lib/colorCache.d.ts +1 -0
  36. package/dist/src/core/lib/colorCache.js +19 -0
  37. package/dist/src/core/lib/colorCache.js.map +1 -0
  38. package/dist/src/core/lib/colorParser.d.ts +21 -0
  39. package/dist/src/core/lib/colorParser.js +72 -0
  40. package/dist/src/core/lib/colorParser.js.map +1 -0
  41. package/dist/src/core/platforms/Platform.d.ts +42 -0
  42. package/dist/src/core/platforms/Platform.js +22 -0
  43. package/dist/src/core/platforms/Platform.js.map +1 -0
  44. package/dist/src/core/platforms/web/WebPlatform.d.ts +10 -0
  45. package/dist/src/core/platforms/web/WebPlatform.js +87 -0
  46. package/dist/src/core/platforms/web/WebPlatform.js.map +1 -0
  47. package/dist/src/core/renderers/CoreShaderNode.d.ts +59 -0
  48. package/dist/src/core/renderers/CoreShaderNode.js +113 -0
  49. package/dist/src/core/renderers/CoreShaderNode.js.map +1 -0
  50. package/dist/src/core/renderers/CoreShaderProgram.d.ts +4 -0
  51. package/dist/src/core/renderers/CoreShaderProgram.js +20 -0
  52. package/dist/src/core/renderers/CoreShaderProgram.js.map +1 -0
  53. package/dist/src/core/renderers/canvas/CanvasRenderer.d.ts +35 -0
  54. package/dist/src/core/renderers/canvas/CanvasRenderer.js +201 -0
  55. package/dist/src/core/renderers/canvas/CanvasRenderer.js.map +1 -0
  56. package/dist/src/core/renderers/canvas/CanvasShaderNode.d.ts +21 -0
  57. package/dist/src/core/renderers/canvas/CanvasShaderNode.js +58 -0
  58. package/dist/src/core/renderers/canvas/CanvasShaderNode.js.map +1 -0
  59. package/dist/src/core/renderers/canvas/CanvasTexture.d.ts +16 -0
  60. package/dist/src/core/renderers/canvas/CanvasTexture.js +125 -0
  61. package/dist/src/core/renderers/canvas/CanvasTexture.js.map +1 -0
  62. package/dist/src/core/renderers/webgl/WebGlCtxRenderTexture.d.ts +12 -0
  63. package/dist/src/core/renderers/webgl/WebGlCtxRenderTexture.js +57 -0
  64. package/dist/src/core/renderers/webgl/WebGlCtxRenderTexture.js.map +1 -0
  65. package/dist/src/core/renderers/webgl/WebGlCtxSubTexture.d.ts +22 -0
  66. package/dist/src/core/renderers/webgl/WebGlCtxSubTexture.js +67 -0
  67. package/dist/src/core/renderers/webgl/WebGlCtxSubTexture.js.map +1 -0
  68. package/dist/src/core/renderers/webgl/WebGlCtxTexture.d.ts +56 -0
  69. package/dist/src/core/renderers/webgl/WebGlCtxTexture.js +236 -0
  70. package/dist/src/core/renderers/webgl/WebGlCtxTexture.js.map +1 -0
  71. package/dist/src/core/renderers/webgl/WebGlRenderOp.d.ts +44 -0
  72. package/dist/src/core/renderers/webgl/WebGlRenderOp.js +125 -0
  73. package/dist/src/core/renderers/webgl/WebGlRenderOp.js.map +1 -0
  74. package/dist/src/core/renderers/webgl/WebGlRenderer.d.ts +136 -0
  75. package/dist/src/core/renderers/webgl/WebGlRenderer.js +573 -0
  76. package/dist/src/core/renderers/webgl/WebGlRenderer.js.map +1 -0
  77. package/dist/src/core/renderers/webgl/WebGlShaderNode.d.ts +222 -0
  78. package/dist/src/core/renderers/webgl/WebGlShaderNode.js +331 -0
  79. package/dist/src/core/renderers/webgl/WebGlShaderNode.js.map +1 -0
  80. package/dist/src/core/renderers/webgl/WebGlShaderProgram.d.ts +37 -0
  81. package/dist/src/core/renderers/webgl/WebGlShaderProgram.js +218 -0
  82. package/dist/src/core/renderers/webgl/WebGlShaderProgram.js.map +1 -0
  83. package/dist/src/core/renderers/webgl/shaders/effects/RadiusEffect.js +5 -5
  84. package/dist/src/core/shaders/canvas/Border.d.ts +9 -0
  85. package/dist/src/core/shaders/canvas/Border.js +57 -0
  86. package/dist/src/core/shaders/canvas/Border.js.map +1 -0
  87. package/dist/src/core/shaders/canvas/HolePunch.d.ts +7 -0
  88. package/dist/src/core/shaders/canvas/HolePunch.js +38 -0
  89. package/dist/src/core/shaders/canvas/HolePunch.js.map +1 -0
  90. package/dist/src/core/shaders/canvas/LinearGradient.d.ts +10 -0
  91. package/dist/src/core/shaders/canvas/LinearGradient.js +48 -0
  92. package/dist/src/core/shaders/canvas/LinearGradient.js.map +1 -0
  93. package/dist/src/core/shaders/canvas/RadialGradient.d.ts +11 -0
  94. package/dist/src/core/shaders/canvas/RadialGradient.js +70 -0
  95. package/dist/src/core/shaders/canvas/RadialGradient.js.map +1 -0
  96. package/dist/src/core/shaders/canvas/Rounded.d.ts +7 -0
  97. package/dist/src/core/shaders/canvas/Rounded.js +33 -0
  98. package/dist/src/core/shaders/canvas/Rounded.js.map +1 -0
  99. package/dist/src/core/shaders/canvas/RoundedWithBorder.d.ts +7 -0
  100. package/dist/src/core/shaders/canvas/RoundedWithBorder.js +43 -0
  101. package/dist/src/core/shaders/canvas/RoundedWithBorder.js.map +1 -0
  102. package/dist/src/core/shaders/canvas/RoundedWithBorderAndShadow.d.ts +8 -0
  103. package/dist/src/core/shaders/canvas/RoundedWithBorderAndShadow.js +41 -0
  104. package/dist/src/core/shaders/canvas/RoundedWithBorderAndShadow.js.map +1 -0
  105. package/dist/src/core/shaders/canvas/RoundedWithShadow.d.ts +7 -0
  106. package/dist/src/core/shaders/canvas/RoundedWithShadow.js +40 -0
  107. package/dist/src/core/shaders/canvas/RoundedWithShadow.js.map +1 -0
  108. package/dist/src/core/shaders/canvas/Shadow.d.ts +8 -0
  109. package/dist/src/core/shaders/canvas/Shadow.js +31 -0
  110. package/dist/src/core/shaders/canvas/Shadow.js.map +1 -0
  111. package/dist/src/core/shaders/canvas/utils/render.d.ts +5 -0
  112. package/dist/src/core/shaders/canvas/utils/render.js +84 -0
  113. package/dist/src/core/shaders/canvas/utils/render.js.map +1 -0
  114. package/dist/src/core/shaders/templates/BorderTemplate.d.ts +37 -0
  115. package/dist/src/core/shaders/templates/BorderTemplate.js +73 -0
  116. package/dist/src/core/shaders/templates/BorderTemplate.js.map +1 -0
  117. package/dist/src/core/shaders/templates/HolePunchTemplate.d.ts +46 -0
  118. package/dist/src/core/shaders/templates/HolePunchTemplate.js +35 -0
  119. package/dist/src/core/shaders/templates/HolePunchTemplate.js.map +1 -0
  120. package/dist/src/core/shaders/templates/LinearGradientTemplate.d.ts +23 -0
  121. package/dist/src/core/shaders/templates/LinearGradientTemplate.js +47 -0
  122. package/dist/src/core/shaders/templates/LinearGradientTemplate.js.map +1 -0
  123. package/dist/src/core/shaders/templates/RadialGradientTemplate.d.ts +31 -0
  124. package/dist/src/core/shaders/templates/RadialGradientTemplate.js +49 -0
  125. package/dist/src/core/shaders/templates/RadialGradientTemplate.js.map +1 -0
  126. package/dist/src/core/shaders/templates/RoundedTemplate.d.ts +29 -0
  127. package/dist/src/core/shaders/templates/RoundedTemplate.js +67 -0
  128. package/dist/src/core/shaders/templates/RoundedTemplate.js.map +1 -0
  129. package/dist/src/core/shaders/templates/RoundedWithBorderAndShadowTemplate.d.ts +7 -0
  130. package/dist/src/core/shaders/templates/RoundedWithBorderAndShadowTemplate.js +24 -0
  131. package/dist/src/core/shaders/templates/RoundedWithBorderAndShadowTemplate.js.map +1 -0
  132. package/dist/src/core/shaders/templates/RoundedWithBorderTemplate.d.ts +6 -0
  133. package/dist/src/core/shaders/templates/RoundedWithBorderTemplate.js +23 -0
  134. package/dist/src/core/shaders/templates/RoundedWithBorderTemplate.js.map +1 -0
  135. package/dist/src/core/shaders/templates/RoundedWithShadowTemplate.d.ts +6 -0
  136. package/dist/src/core/shaders/templates/RoundedWithShadowTemplate.js +23 -0
  137. package/dist/src/core/shaders/templates/RoundedWithShadowTemplate.js.map +1 -0
  138. package/dist/src/core/shaders/templates/ShadowTemplate.d.ts +34 -0
  139. package/dist/src/core/shaders/templates/ShadowTemplate.js +66 -0
  140. package/dist/src/core/shaders/templates/ShadowTemplate.js.map +1 -0
  141. package/dist/src/core/shaders/utils.d.ts +5 -0
  142. package/dist/src/core/shaders/utils.js +41 -0
  143. package/dist/src/core/shaders/utils.js.map +1 -0
  144. package/dist/src/core/shaders/webgl/Border.d.ts +3 -0
  145. package/dist/src/core/shaders/webgl/Border.js +110 -0
  146. package/dist/src/core/shaders/webgl/Border.js.map +1 -0
  147. package/dist/src/core/shaders/webgl/Default.d.ts +2 -0
  148. package/dist/src/core/shaders/webgl/Default.js +86 -0
  149. package/dist/src/core/shaders/webgl/Default.js.map +1 -0
  150. package/dist/src/core/shaders/webgl/DefaultBatched.d.ts +2 -0
  151. package/dist/src/core/shaders/webgl/DefaultBatched.js +104 -0
  152. package/dist/src/core/shaders/webgl/DefaultBatched.js.map +1 -0
  153. package/dist/src/core/shaders/webgl/HolePunch.d.ts +3 -0
  154. package/dist/src/core/shaders/webgl/HolePunch.js +65 -0
  155. package/dist/src/core/shaders/webgl/HolePunch.js.map +1 -0
  156. package/dist/src/core/shaders/webgl/LinearGradient.d.ts +3 -0
  157. package/dist/src/core/shaders/webgl/LinearGradient.js +100 -0
  158. package/dist/src/core/shaders/webgl/LinearGradient.js.map +1 -0
  159. package/dist/src/core/shaders/webgl/RadialGradient.d.ts +3 -0
  160. package/dist/src/core/shaders/webgl/RadialGradient.js +97 -0
  161. package/dist/src/core/shaders/webgl/RadialGradient.js.map +1 -0
  162. package/dist/src/core/shaders/webgl/Rounded.d.ts +7 -0
  163. package/dist/src/core/shaders/webgl/Rounded.js +86 -0
  164. package/dist/src/core/shaders/webgl/Rounded.js.map +1 -0
  165. package/dist/src/core/shaders/webgl/RoundedWithBorder.d.ts +3 -0
  166. package/dist/src/core/shaders/webgl/RoundedWithBorder.js +140 -0
  167. package/dist/src/core/shaders/webgl/RoundedWithBorder.js.map +1 -0
  168. package/dist/src/core/shaders/webgl/RoundedWithBorderAndShadow.d.ts +3 -0
  169. package/dist/src/core/shaders/webgl/RoundedWithBorderAndShadow.js +162 -0
  170. package/dist/src/core/shaders/webgl/RoundedWithBorderAndShadow.js.map +1 -0
  171. package/dist/src/core/shaders/webgl/RoundedWithShadow.d.ts +3 -0
  172. package/dist/src/core/shaders/webgl/RoundedWithShadow.js +84 -0
  173. package/dist/src/core/shaders/webgl/RoundedWithShadow.js.map +1 -0
  174. package/dist/src/core/shaders/webgl/SdfShader.d.ts +30 -0
  175. package/dist/src/core/shaders/webgl/SdfShader.js +107 -0
  176. package/dist/src/core/shaders/webgl/SdfShader.js.map +1 -0
  177. package/dist/src/core/shaders/webgl/Shadow.d.ts +3 -0
  178. package/dist/src/core/shaders/webgl/Shadow.js +110 -0
  179. package/dist/src/core/shaders/webgl/Shadow.js.map +1 -0
  180. package/dist/src/core/text-rendering/CanvasFontHandler.d.ts +59 -0
  181. package/dist/src/core/text-rendering/CanvasFontHandler.js +224 -0
  182. package/dist/src/core/text-rendering/CanvasFontHandler.js.map +1 -0
  183. package/dist/src/core/text-rendering/CanvasTextRenderer.d.ts +17 -0
  184. package/dist/src/core/text-rendering/CanvasTextRenderer.js +157 -0
  185. package/dist/src/core/text-rendering/CanvasTextRenderer.js.map +1 -0
  186. package/dist/src/core/text-rendering/SdfFontHandler.d.ts +182 -0
  187. package/dist/src/core/text-rendering/SdfFontHandler.js +391 -0
  188. package/dist/src/core/text-rendering/SdfFontHandler.js.map +1 -0
  189. package/dist/src/core/text-rendering/SdfTextRenderer.d.ts +17 -0
  190. package/dist/src/core/text-rendering/SdfTextRenderer.js +311 -0
  191. package/dist/src/core/text-rendering/SdfTextRenderer.js.map +1 -0
  192. package/dist/src/core/text-rendering/TextLayoutEngine.d.ts +18 -0
  193. package/dist/src/core/text-rendering/TextLayoutEngine.js +380 -0
  194. package/dist/src/core/text-rendering/TextLayoutEngine.js.map +1 -0
  195. package/dist/src/core/text-rendering/TextRenderer.d.ts +383 -0
  196. package/dist/src/core/text-rendering/TextRenderer.js +20 -0
  197. package/dist/src/core/text-rendering/TextRenderer.js.map +1 -0
  198. package/dist/src/core/text-rendering/Utils.d.ts +30 -0
  199. package/dist/src/core/text-rendering/Utils.js +84 -0
  200. package/dist/src/core/text-rendering/Utils.js.map +1 -0
  201. package/dist/tsconfig.dist.tsbuildinfo +1 -1
  202. package/package.json +1 -1
  203. package/src/common/CommonTypes.ts +16 -0
  204. package/src/core/CoreNode.test.ts +49 -0
  205. package/src/core/CoreNode.ts +10 -0
  206. package/src/core/Stage.ts +3 -1
  207. package/src/core/renderers/webgl/shaders/effects/RadiusEffect.ts +5 -5
@@ -0,0 +1,383 @@
1
+ import type { CoreTextNodeProps } from '../CoreTextNode.js';
2
+ import type { CoreRenderer } from '../renderers/CoreRenderer.js';
3
+ import type { Stage } from '../Stage.js';
4
+ export type TextBaseline = 'alphabetic' | 'hanging' | 'middle' | 'ideographic' | 'bottom';
5
+ export type TextVerticalAlign = 'top' | 'middle' | 'bottom';
6
+ export type TextRenderers = 'canvas' | 'sdf';
7
+ /**
8
+ * Structure mapping font family names to a set of font faces.
9
+ */
10
+ export interface FontFamilyMap {
11
+ [familyName: string]: FontFace;
12
+ }
13
+ /**
14
+ * Font metrics used for layout and default line height calculations.
15
+ */
16
+ export interface FontMetrics {
17
+ /**
18
+ * The distance, in font units, from the baseline to the highest point of the font.
19
+ */
20
+ ascender: number;
21
+ /**
22
+ * The distance, in font units, from the baseline to the lowest point of the font.
23
+ */
24
+ descender: number;
25
+ /**
26
+ * The additional space used in the calculation of the default line height in font units.
27
+ */
28
+ lineGap: number;
29
+ /**
30
+ * The number of font units per 1 EM.
31
+ */
32
+ unitsPerEm: number;
33
+ }
34
+ /**
35
+ * Normalized font metrics where values are expressed as a fraction of 1 EM.
36
+ */
37
+ export interface NormalizedFontMetrics {
38
+ /**
39
+ * The distance, as a fraction of 1 EM, from the baseline to the highest point of the font.
40
+ */
41
+ ascender: number;
42
+ /**
43
+ * The distance, as a fraction of 1 EM, from the baseline to the lowest point of the font.
44
+ */
45
+ descender: number;
46
+ /**
47
+ * The additional space used in the calculation of the default line height as a fraction of 1 EM
48
+ */
49
+ lineGap: number;
50
+ }
51
+ /**
52
+ * Text renderer properties that are used in resolving appropriate font faces
53
+ *
54
+ * @remarks
55
+ * Extended by {@link TrProps}
56
+ */
57
+ export interface TrFontProps {
58
+ /**
59
+ * Font Family
60
+ *
61
+ * @internalRemarks
62
+ * `fontFamily` is defined currently as single string, but in the future we may want to
63
+ * support multiple font family fallbacks, as this is supported by CSS / Canvas2d. We can
64
+ * do this in a backwards compatible way by unioning an array of strings to the
65
+ * `fontFamily` property.
66
+ */
67
+ fontFamily: string;
68
+ /**
69
+ * Font Style
70
+ *
71
+ * @remarks
72
+ * The font style to use when looking up the font face. This can be one of the
73
+ * following strings:
74
+ * - `'normal'`
75
+ * - `'italic'`
76
+ * - `'oblique'`
77
+ */
78
+ fontStyle: 'normal' | 'italic' | 'oblique';
79
+ /**
80
+ * Font Size
81
+ *
82
+ * @remarks
83
+ * The font size to use when looking up the font face.
84
+ *
85
+ * The font size is specified in pixels and is the height of the font's
86
+ * em-square. The em-square is essentially the height of the capital letters
87
+ * for the font. The actual height of the text can be larger than the
88
+ * specified font size, as the font may have ascenders and descenders that
89
+ * extend beyond the em-square.
90
+ *
91
+ * @default 16
92
+ */
93
+ fontSize: number;
94
+ }
95
+ export interface TrProps extends TrFontProps {
96
+ /**
97
+ * Text to display
98
+ *
99
+ * @default ''
100
+ */
101
+ text: string;
102
+ /**
103
+ * Text alignment
104
+ *
105
+ * @remarks
106
+ * Alignment of the text relative to it's contained bounds. For best results,
107
+ * use {@link contain} mode `'width'` or `'both'` and a set an explicit
108
+ * {@link width} for the text to be aligned within.
109
+ *
110
+ * @default 'left'
111
+ */
112
+ textAlign: 'left' | 'center' | 'right';
113
+ /**
114
+ * Color of text
115
+ *
116
+ * @remarks
117
+ * The color value is a number in the format 0xRRGGBBAA, where RR is the red
118
+ * component, GG is the green component, BB is the blue component, and AA is
119
+ * the alpha component.
120
+ *
121
+ * @default 0xffffffff (opaque white)
122
+ */
123
+ color: number;
124
+ x: number;
125
+ y: number;
126
+ maxWidth: number;
127
+ maxHeight: number;
128
+ /**
129
+ * Vertical offset for text
130
+ *
131
+ * @remarks
132
+ * The vertical offset of the text.
133
+ *
134
+ * @default 0
135
+ */
136
+ offsetY: number;
137
+ /**
138
+ * Letter spacing for text (in pixels)
139
+ *
140
+ * @remarks
141
+ * This property sets additional (or reduced, if value is negative) spacing
142
+ * between characters in the text.
143
+ *
144
+ * @default 0
145
+ */
146
+ letterSpacing: number;
147
+ /**
148
+ * Line height for text (in pixels)
149
+ *
150
+ * @remarks
151
+ * This property sets the height of each line. If set to `undefined`, the
152
+ * line height will be calculated based on the font and font size to be the
153
+ * minimal height required to completely contain a line of text.
154
+ *
155
+ * See: https://github.com/lightning-js/renderer/issues/170
156
+ *
157
+ * @default `undefined`
158
+ */
159
+ lineHeight: number;
160
+ /**
161
+ * Max lines for text
162
+ *
163
+ * @remarks
164
+ * This property sets max number of lines of a text paragraph.
165
+ * Not yet implemented in the SDF renderer.
166
+ *
167
+ * @default 0
168
+ */
169
+ maxLines: number;
170
+ /**
171
+ * Vertical Align for text when lineHeight > fontSize
172
+ *
173
+ * @remarks
174
+ * This property sets the vertical align of the text.
175
+ * Not yet implemented in the SDF renderer.
176
+ *
177
+ * @default middle
178
+ */
179
+ verticalAlign: TextVerticalAlign;
180
+ /**
181
+ * Overflow Suffix for text
182
+ *
183
+ * @remarks
184
+ * The suffix to be added when text is cropped due to overflow.
185
+ * Not yet implemented in the SDF renderer.
186
+ *
187
+ * @default "..."
188
+ */
189
+ overflowSuffix: string;
190
+ /**
191
+ * Word Break for text
192
+ *
193
+ * @remarks
194
+ * This property sets how words should break when reaching the end of a line.
195
+ *
196
+ * - `'overflow'`: Uses the Css/HTML normal word-break behavior, generally not used in app development.
197
+ * - `'break-all'`: To prevent overflow, word breaks should happen between any two characters.
198
+ * - `'break-word'`: To prevent overflow, word breaks should happen between words. If words are too long word breaks happen between any two characters.
199
+ *
200
+ * @default "break-word"
201
+ */
202
+ wordBreak: 'overflow' | 'break-all' | 'break-word';
203
+ /**
204
+ * contain mode for text
205
+ *
206
+ * @remarks
207
+ *
208
+ * This property sets how the text should be contained within its bounding box.
209
+ *
210
+ * - 'width': The text is contained within the specified maxWidth, horizontal position of text will adjust according to {@link textAlign}.
211
+ * - 'height': The text is contained within the specified maxHeight, vertical position of text will adjust according to {@link verticalAlign}.
212
+ * - 'both': The text is contained within both the specified maxWidth and maxHeight.
213
+ * - 'none': The text is not contained within any bounding box.
214
+ *
215
+ * @default 'none'
216
+ */
217
+ contain: 'width' | 'height' | 'both' | 'none';
218
+ }
219
+ /**
220
+ * Glyph layout information for WebGL rendering
221
+ */
222
+ export interface GlyphLayout {
223
+ /**
224
+ * Unicode codepoint
225
+ */
226
+ codepoint: number;
227
+ /**
228
+ * Glyph ID in the font atlas
229
+ */
230
+ glyphId: number;
231
+ /**
232
+ * X position relative to text origin
233
+ */
234
+ x: number;
235
+ /**
236
+ * Y position relative to text origin
237
+ */
238
+ y: number;
239
+ /**
240
+ * Width of glyph in font units
241
+ */
242
+ width: number;
243
+ /**
244
+ * Height of glyph in font units
245
+ */
246
+ height: number;
247
+ /**
248
+ * X offset for glyph positioning
249
+ */
250
+ xOffset: number;
251
+ /**
252
+ * Y offset for glyph positioning
253
+ */
254
+ yOffset: number;
255
+ /**
256
+ * Atlas texture coordinates (normalized 0-1)
257
+ */
258
+ atlasX: number;
259
+ atlasY: number;
260
+ atlasWidth: number;
261
+ atlasHeight: number;
262
+ }
263
+ /**
264
+ * Complete text layout information for caching
265
+ */
266
+ export interface TextLayout {
267
+ /**
268
+ * Individual glyph layouts
269
+ */
270
+ glyphs: GlyphLayout[];
271
+ /**
272
+ * Total text width
273
+ */
274
+ width: number;
275
+ /**
276
+ * Total text height
277
+ */
278
+ height: number;
279
+ /**
280
+ * Font scale factor
281
+ */
282
+ fontScale: number;
283
+ /**
284
+ * Line height
285
+ */
286
+ lineHeight: number;
287
+ /**
288
+ * Font family used
289
+ */
290
+ fontFamily: string;
291
+ /**
292
+ * distanceRange used
293
+ */
294
+ distanceRange: number;
295
+ }
296
+ export interface FontLoadOptions {
297
+ fontFamily: string;
298
+ metrics?: FontMetrics;
299
+ fontUrl?: string;
300
+ atlasUrl?: string;
301
+ atlasDataUrl?: string;
302
+ }
303
+ /**
304
+ * Measure Width of Text function to be defined in font handlers, used in TextLayoutEngine
305
+ */
306
+ export type MeasureTextFn = (text: string, fontFamily: string, letterSpacing: number) => number;
307
+ export interface FontHandler {
308
+ init: (c: CanvasRenderingContext2D | OffscreenCanvasRenderingContext2D) => void;
309
+ type: 'canvas' | 'sdf';
310
+ isFontLoaded: (fontFamily: string) => boolean;
311
+ loadFont: (stage: Stage, options: FontLoadOptions) => Promise<void>;
312
+ waitingForFont: (fontFamily: string, CoreTextNode: any) => void;
313
+ stopWaitingForFont: (fontFamily: string, CoreTextNode: any) => void;
314
+ getFontFamilies: () => FontFamilyMap;
315
+ canRenderFont: (trProps: TrProps) => boolean;
316
+ getFontMetrics: (fontFamily: string, fontSize: number) => NormalizedFontMetrics;
317
+ measureText: MeasureTextFn;
318
+ }
319
+ export interface TextRenderProps {
320
+ fontFamily: string;
321
+ fontSize: number;
322
+ color: number;
323
+ offsetY: number;
324
+ worldAlpha: number;
325
+ globalTransform: Float32Array;
326
+ clippingRect: unknown;
327
+ width: number;
328
+ height: number;
329
+ parentHasRenderTexture: boolean;
330
+ framebufferDimensions: unknown;
331
+ stage: Stage;
332
+ }
333
+ export interface TextRenderInfo {
334
+ width: number;
335
+ height: number;
336
+ hasRemainingText?: boolean;
337
+ remainingLines?: number;
338
+ imageData?: ImageData | null;
339
+ layout?: TextLayout;
340
+ }
341
+ export interface TextRenderer {
342
+ type: 'canvas' | 'sdf';
343
+ font: FontHandler;
344
+ renderText: (props: CoreTextNodeProps) => TextRenderInfo;
345
+ addQuads: (layout?: TextLayout) => Float32Array | null;
346
+ renderQuads: (renderer: CoreRenderer, layout: TextLayout, vertexBuffer: Float32Array, renderProps: TextRenderProps) => void;
347
+ init: (stage: Stage) => void;
348
+ }
349
+ /**
350
+ * Text line struct for text mapping
351
+ * 0 - text
352
+ * 1 - width
353
+ * 2 - truncated
354
+ * 3 - line offset x
355
+ * 4 - line offset y
356
+ */
357
+ export type TextLineStruct = [string, number, boolean, number, number];
358
+ /**
359
+ * Wrapped lines struct for text mapping
360
+ * 0 - line structs
361
+ * 1 - remaining lines
362
+ * 2 - remaining text
363
+ */
364
+ export type WrappedLinesStruct = [TextLineStruct[], number, boolean];
365
+ /**
366
+ * Wrapped lines struct for text mapping
367
+ * 0 - line structs
368
+ * 1 - remaining lines
369
+ * 2 - remaining text
370
+ * 3 - bare line height
371
+ * 4 - line height pixels
372
+ * 5 - effective width
373
+ * 6 - effective height
374
+ */
375
+ export type TextLayoutStruct = [
376
+ TextLineStruct[],
377
+ number,
378
+ boolean,
379
+ number,
380
+ number,
381
+ number,
382
+ number
383
+ ];
@@ -0,0 +1,20 @@
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
+ export {};
20
+ //# sourceMappingURL=TextRenderer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TextRenderer.js","sourceRoot":"","sources":["../../../../src/core/text-rendering/TextRenderer.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;GAiBG"}
@@ -0,0 +1,30 @@
1
+ /**
2
+ * Returns CSS font setting string for use in canvas context.
3
+ *
4
+ * @param fontFace
5
+ * @param fontStyle
6
+ * @param fontSize
7
+ * @param precision
8
+ * @param defaultFontFace
9
+ * @returns
10
+ */
11
+ export declare function getFontSetting(fontFace: string | string[], fontStyle: string, fontSize: number, precision: number, defaultFontFace: string): string;
12
+ /**
13
+ * Returns true if the given character is a zero-width space.
14
+ *
15
+ * @param space
16
+ */
17
+ export declare function hasZeroWidthSpace(space: string): boolean;
18
+ /**
19
+ * Returns true if the given character is a zero-width space or a regular space.
20
+ *
21
+ * @param space
22
+ */
23
+ export declare function isSpace(space: string): boolean;
24
+ /**
25
+ * Converts a string into an array of tokens and the words between them.
26
+ *
27
+ * @param tokenRegex
28
+ * @param text
29
+ */
30
+ export declare function tokenizeString(tokenRegex: RegExp, text: string): string[];
@@ -0,0 +1,84 @@
1
+ /*
2
+ * If not stated otherwise in this file or this component's LICENSE file the
3
+ * following copyright and licenses apply:
4
+ *
5
+ * Copyright 2025 Comcast Cable Communications Management, LLC.
6
+ *
7
+ * Licensed under the Apache License, Version 2.0 (the License);
8
+ * you may not use this file except in compliance with the License.
9
+ * You may obtain a copy of the License at
10
+ *
11
+ * http://www.apache.org/licenses/LICENSE-2.0
12
+ *
13
+ * Unless required by applicable law or agreed to in writing, software
14
+ * distributed under the License is distributed on an "AS IS" BASIS,
15
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16
+ * See the License for the specific language governing permissions and
17
+ * limitations under the License.
18
+ */
19
+ const invisibleChars = /[\u200B\u200C\u200D\uFEFF\u00AD\u2060]/g;
20
+ /**
21
+ * Returns CSS font setting string for use in canvas context.
22
+ *
23
+ * @param fontFace
24
+ * @param fontStyle
25
+ * @param fontSize
26
+ * @param precision
27
+ * @param defaultFontFace
28
+ * @returns
29
+ */
30
+ export function getFontSetting(fontFace, fontStyle, fontSize, precision, defaultFontFace) {
31
+ let ff = fontFace;
32
+ if (!Array.isArray(ff)) {
33
+ ff = [ff];
34
+ }
35
+ const ffs = [];
36
+ for (let i = 0, n = ff.length; i < n; i++) {
37
+ let curFf = ff[i];
38
+ // Replace the default font face `null` with the actual default font face set
39
+ // on the stage.
40
+ if (curFf === null || curFf === undefined) {
41
+ curFf = defaultFontFace;
42
+ }
43
+ if (curFf === 'serif' || curFf === 'sans-serif') {
44
+ ffs.push(curFf);
45
+ }
46
+ else {
47
+ ffs.push(`"${curFf}"`);
48
+ }
49
+ }
50
+ return `${fontStyle} ${fontSize * precision}px ${ffs.join(',')}`;
51
+ }
52
+ /**
53
+ * Returns true if the given character is a zero-width space.
54
+ *
55
+ * @param space
56
+ */
57
+ export function hasZeroWidthSpace(space) {
58
+ return invisibleChars.test(space) === true;
59
+ }
60
+ /**
61
+ * Returns true if the given character is a zero-width space or a regular space.
62
+ *
63
+ * @param space
64
+ */
65
+ export function isSpace(space) {
66
+ return hasZeroWidthSpace(space) || space === ' ';
67
+ }
68
+ /**
69
+ * Converts a string into an array of tokens and the words between them.
70
+ *
71
+ * @param tokenRegex
72
+ * @param text
73
+ */
74
+ export function tokenizeString(tokenRegex, text) {
75
+ const delimeters = text.match(tokenRegex) || [];
76
+ const words = text.split(tokenRegex) || [];
77
+ const final = [];
78
+ for (let i = 0; i < words.length; i++) {
79
+ final.push(words[i], delimeters[i]);
80
+ }
81
+ final.pop();
82
+ return final.filter((word) => word != '');
83
+ }
84
+ //# sourceMappingURL=Utils.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Utils.js","sourceRoot":"","sources":["../../../../src/core/text-rendering/Utils.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;GAiBG;AAIH,MAAM,cAAc,GAAG,yCAAyC,CAAC;AAEjE;;;;;;;;;GASG;AACH,MAAM,UAAU,cAAc,CAC5B,QAA2B,EAC3B,SAAiB,EACjB,QAAgB,EAChB,SAAiB,EACjB,eAAuB;IAEvB,IAAI,EAAE,GAAG,QAAQ,CAAC;IAElB,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,EAAE,CAAC,EAAE,CAAC;QACvB,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC;IACZ,CAAC;IAED,MAAM,GAAG,GAAa,EAAE,CAAC;IACzB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC;QAC1C,IAAI,KAAK,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC;QAClB,6EAA6E;QAC7E,gBAAgB;QAChB,IAAI,KAAK,KAAK,IAAI,IAAI,KAAK,KAAK,SAAS,EAAE,CAAC;YAC1C,KAAK,GAAG,eAAe,CAAC;QAC1B,CAAC;QACD,IAAI,KAAK,KAAK,OAAO,IAAI,KAAK,KAAK,YAAY,EAAE,CAAC;YAChD,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAClB,CAAC;aAAM,CAAC;YACN,GAAG,CAAC,IAAI,CAAC,IAAI,KAAK,GAAG,CAAC,CAAC;QACzB,CAAC;IACH,CAAC;IAED,OAAO,GAAG,SAAS,IAAI,QAAQ,GAAG,SAAS,MAAM,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC;AACnE,CAAC;AAED;;;;GAIG;AACH,MAAM,UAAU,iBAAiB,CAAC,KAAa;IAC7C,OAAO,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,IAAI,CAAC;AAC7C,CAAC;AAED;;;;GAIG;AACH,MAAM,UAAU,OAAO,CAAC,KAAa;IACnC,OAAO,iBAAiB,CAAC,KAAK,CAAC,IAAI,KAAK,KAAK,GAAG,CAAC;AACnD,CAAC;AAED;;;;;GAKG;AACH,MAAM,UAAU,cAAc,CAAC,UAAkB,EAAE,IAAY;IAC7D,MAAM,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;IAChD,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;IAE3C,MAAM,KAAK,GAAa,EAAE,CAAC;IAC3B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;QACtC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAE,EAAE,UAAU,CAAC,CAAC,CAAE,CAAC,CAAC;IACxC,CAAC;IACD,KAAK,CAAC,GAAG,EAAE,CAAC;IACZ,OAAO,KAAK,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC;AAC5C,CAAC"}