@lightningjs/renderer 0.8.3 → 0.9.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/src/core/CoreNode.d.ts +27 -1
- package/dist/src/core/CoreNode.js +130 -5
- package/dist/src/core/CoreNode.js.map +1 -1
- package/dist/src/core/CoreShaderManager.js +3 -2
- package/dist/src/core/CoreShaderManager.js.map +1 -1
- package/dist/src/core/CoreTextNode.js +20 -1
- package/dist/src/core/CoreTextNode.js.map +1 -1
- package/dist/src/core/CoreTextureManager.d.ts +2 -0
- package/dist/src/core/CoreTextureManager.js +2 -0
- package/dist/src/core/CoreTextureManager.js.map +1 -1
- package/dist/src/core/Stage.js +25 -9
- package/dist/src/core/Stage.js.map +1 -1
- package/dist/src/core/TextureMemoryManager.d.ts +1 -0
- package/dist/src/core/TextureMemoryManager.js +3 -1
- package/dist/src/core/TextureMemoryManager.js.map +1 -1
- package/dist/src/core/lib/ImageWorker.d.ts +2 -1
- package/dist/src/core/lib/ImageWorker.js +10 -6
- package/dist/src/core/lib/ImageWorker.js.map +1 -1
- package/dist/src/core/lib/Matrix3d.d.ts +38 -24
- package/dist/src/core/lib/Matrix3d.js +143 -166
- package/dist/src/core/lib/Matrix3d.js.map +1 -1
- package/dist/src/core/lib/WebGlContextWrapper.d.ts +26 -1
- package/dist/src/core/lib/WebGlContextWrapper.js +37 -1
- package/dist/src/core/lib/WebGlContextWrapper.js.map +1 -1
- package/dist/src/core/renderers/CoreRenderer.d.ts +11 -0
- package/dist/src/core/renderers/CoreRenderer.js +1 -0
- package/dist/src/core/renderers/CoreRenderer.js.map +1 -1
- package/dist/src/core/renderers/canvas/CanvasCoreRenderer.d.ts +10 -4
- package/dist/src/core/renderers/canvas/CanvasCoreRenderer.js +18 -7
- package/dist/src/core/renderers/canvas/CanvasCoreRenderer.js.map +1 -1
- package/dist/src/core/renderers/canvas/CanvasCoreTexture.d.ts +2 -2
- package/dist/src/core/renderers/canvas/CanvasCoreTexture.js +8 -6
- package/dist/src/core/renderers/canvas/CanvasCoreTexture.js.map +1 -1
- package/dist/src/core/renderers/canvas/internal/C2DShaderUtils.d.ts +1 -1
- package/dist/src/core/renderers/canvas/internal/C2DShaderUtils.js +1 -1
- package/dist/src/core/renderers/canvas/internal/C2DShaderUtils.js.map +1 -1
- package/dist/src/core/renderers/canvas/internal/ColorUtils.js +4 -4
- package/dist/src/core/renderers/canvas/internal/ColorUtils.js.map +1 -1
- package/dist/src/core/renderers/canvas/shaders/UnsupportedShader.d.ts +1 -1
- package/dist/src/core/renderers/canvas/shaders/UnsupportedShader.js +2 -2
- package/dist/src/core/renderers/canvas/shaders/UnsupportedShader.js.map +1 -1
- package/dist/src/core/renderers/webgl/WebGlCoreCtxRenderTexture.d.ts +11 -0
- package/dist/src/core/renderers/webgl/WebGlCoreCtxRenderTexture.js +51 -0
- package/dist/src/core/renderers/webgl/WebGlCoreCtxRenderTexture.js.map +1 -0
- package/dist/src/core/renderers/webgl/WebGlCoreCtxTexture.d.ts +11 -1
- package/dist/src/core/renderers/webgl/WebGlCoreCtxTexture.js +22 -11
- package/dist/src/core/renderers/webgl/WebGlCoreCtxTexture.js.map +1 -1
- package/dist/src/core/renderers/webgl/WebGlCoreRenderOp.d.ts +4 -1
- package/dist/src/core/renderers/webgl/WebGlCoreRenderOp.js +7 -2
- package/dist/src/core/renderers/webgl/WebGlCoreRenderOp.js.map +1 -1
- package/dist/src/core/renderers/webgl/WebGlCoreRenderer.d.ts +16 -1
- package/dist/src/core/renderers/webgl/WebGlCoreRenderer.js +119 -27
- package/dist/src/core/renderers/webgl/WebGlCoreRenderer.js.map +1 -1
- package/dist/src/core/renderers/webgl/WebGlCoreShader.js +19 -4
- package/dist/src/core/renderers/webgl/WebGlCoreShader.js.map +1 -1
- package/dist/src/core/renderers/webgl/shaders/DefaultShader.js +4 -6
- package/dist/src/core/renderers/webgl/shaders/DefaultShader.js.map +1 -1
- package/dist/src/core/renderers/webgl/shaders/SdfShader.js +6 -1
- package/dist/src/core/renderers/webgl/shaders/SdfShader.js.map +1 -1
- package/dist/src/core/text-rendering/TextRenderingUtils.d.ts +12 -0
- package/dist/src/core/text-rendering/TextRenderingUtils.js +14 -0
- package/dist/src/core/text-rendering/TextRenderingUtils.js.map +1 -0
- package/dist/src/core/text-rendering/TextTextureRendererUtils.d.ts +19 -0
- package/dist/src/core/text-rendering/TextTextureRendererUtils.js +61 -0
- package/dist/src/core/text-rendering/TextTextureRendererUtils.js.map +1 -1
- package/dist/src/core/text-rendering/font-face-types/SdfTrFontFace/SdfTrFontFace.d.ts +8 -2
- package/dist/src/core/text-rendering/font-face-types/SdfTrFontFace/SdfTrFontFace.js +24 -3
- package/dist/src/core/text-rendering/font-face-types/SdfTrFontFace/SdfTrFontFace.js.map +1 -1
- package/dist/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/SdfFontShaper.d.ts +2 -0
- package/dist/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/SdfFontShaper.js.map +1 -1
- package/dist/src/core/text-rendering/font-face-types/TrFontFace.d.ts +72 -1
- package/dist/src/core/text-rendering/font-face-types/TrFontFace.js +11 -1
- package/dist/src/core/text-rendering/font-face-types/TrFontFace.js.map +1 -1
- package/dist/src/core/text-rendering/font-face-types/WebTrFontFace.d.ts +5 -2
- package/dist/src/core/text-rendering/font-face-types/WebTrFontFace.js +4 -3
- package/dist/src/core/text-rendering/font-face-types/WebTrFontFace.js.map +1 -1
- package/dist/src/core/text-rendering/renderers/CanvasTextRenderer.d.ts +8 -0
- package/dist/src/core/text-rendering/renderers/CanvasTextRenderer.js +42 -16
- package/dist/src/core/text-rendering/renderers/CanvasTextRenderer.js.map +1 -1
- package/dist/src/core/text-rendering/renderers/LightningTextTextureRenderer.d.ts +7 -1
- package/dist/src/core/text-rendering/renderers/LightningTextTextureRenderer.js +42 -11
- package/dist/src/core/text-rendering/renderers/LightningTextTextureRenderer.js.map +1 -1
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.d.ts +6 -1
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.js +27 -9
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.js.map +1 -1
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/getStartConditions.d.ts +2 -1
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/getStartConditions.js +32 -5
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/getStartConditions.js.map +1 -1
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText.d.ts +2 -1
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText.js +2 -1
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText.js.map +1 -1
- package/dist/src/core/text-rendering/renderers/TextRenderer.d.ts +10 -5
- package/dist/src/core/text-rendering/renderers/TextRenderer.js +6 -5
- package/dist/src/core/text-rendering/renderers/TextRenderer.js.map +1 -1
- package/dist/src/core/textures/RenderTexture.d.ts +28 -0
- package/dist/src/core/textures/RenderTexture.js +52 -0
- package/dist/src/core/textures/RenderTexture.js.map +1 -0
- package/dist/src/core/utils.d.ts +6 -1
- package/dist/src/core/utils.js +74 -82
- package/dist/src/core/utils.js.map +1 -1
- package/dist/src/main-api/INode.d.ts +9 -0
- package/dist/src/main-api/RendererMain.js +4 -3
- package/dist/src/main-api/RendererMain.js.map +1 -1
- package/dist/src/render-drivers/main/MainOnlyNode.d.ts +3 -0
- package/dist/src/render-drivers/main/MainOnlyNode.js +29 -0
- package/dist/src/render-drivers/main/MainOnlyNode.js.map +1 -1
- package/dist/src/render-drivers/main/MainOnlyTextNode.js +2 -3
- package/dist/src/render-drivers/main/MainOnlyTextNode.js.map +1 -1
- package/dist/src/render-drivers/threadx/NodeStruct.d.ts +3 -0
- package/dist/src/render-drivers/threadx/NodeStruct.js +9 -0
- package/dist/src/render-drivers/threadx/NodeStruct.js.map +1 -1
- package/dist/src/render-drivers/threadx/SharedNode.d.ts +1 -0
- package/dist/src/render-drivers/threadx/SharedNode.js +1 -0
- package/dist/src/render-drivers/threadx/SharedNode.js.map +1 -1
- package/dist/src/render-drivers/threadx/TextNodeStruct.js +3 -1
- package/dist/src/render-drivers/threadx/TextNodeStruct.js.map +1 -1
- package/dist/src/render-drivers/threadx/ThreadXCoreDriver.js +2 -0
- package/dist/src/render-drivers/threadx/ThreadXCoreDriver.js.map +1 -1
- package/dist/src/render-drivers/threadx/ThreadXMainNode.d.ts +3 -0
- package/dist/src/render-drivers/threadx/ThreadXMainNode.js +7 -0
- package/dist/src/render-drivers/threadx/ThreadXMainNode.js.map +1 -1
- package/dist/src/render-drivers/threadx/worker/ThreadXRendererNode.js +1 -0
- package/dist/src/render-drivers/threadx/worker/ThreadXRendererNode.js.map +1 -1
- package/dist/src/render-drivers/threadx/worker/ThreadXRendererTextNode.js +1 -0
- package/dist/src/render-drivers/threadx/worker/ThreadXRendererTextNode.js.map +1 -1
- package/dist/src/render-drivers/threadx/worker/renderer.js +1 -0
- package/dist/src/render-drivers/threadx/worker/renderer.js.map +1 -1
- package/dist/tsconfig.dist.tsbuildinfo +1 -1
- package/package.json +2 -2
- package/src/core/CoreNode.ts +164 -8
- package/src/core/CoreShaderManager.ts +6 -3
- package/src/core/CoreTextNode.ts +25 -0
- package/src/core/CoreTextureManager.ts +3 -0
- package/src/core/Stage.ts +32 -11
- package/src/core/TextureMemoryManager.ts +3 -1
- package/src/core/lib/ImageWorker.ts +12 -7
- package/src/core/lib/Matrix3d.ts +144 -190
- package/src/core/lib/WebGlContextWrapper.ts +51 -1
- package/src/core/renderers/CoreRenderer.ts +15 -1
- package/src/core/renderers/canvas/CanvasCoreRenderer.ts +59 -14
- package/src/core/renderers/canvas/CanvasCoreTexture.ts +24 -18
- package/src/core/renderers/canvas/internal/C2DShaderUtils.ts +6 -3
- package/src/core/renderers/canvas/internal/ColorUtils.ts +6 -6
- package/src/core/renderers/canvas/shaders/UnsupportedShader.ts +2 -3
- package/src/core/renderers/webgl/WebGlCoreCtxRenderTexture.ts +79 -0
- package/src/core/renderers/webgl/WebGlCoreCtxTexture.ts +26 -24
- package/src/core/renderers/webgl/WebGlCoreRenderOp.ts +4 -2
- package/src/core/renderers/webgl/WebGlCoreRenderer.ts +166 -33
- package/src/core/renderers/webgl/WebGlCoreShader.ts +29 -4
- package/src/core/renderers/webgl/shaders/DefaultShader.ts +4 -6
- package/src/core/renderers/webgl/shaders/SdfShader.ts +6 -1
- package/src/core/text-rendering/TextRenderingUtils.ts +36 -0
- package/src/core/text-rendering/TextTextureRendererUtils.ts +74 -0
- package/src/core/text-rendering/font-face-types/SdfTrFontFace/SdfTrFontFace.ts +41 -12
- package/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/SdfFontShaper.ts +2 -0
- package/src/core/text-rendering/font-face-types/TrFontFace.ts +86 -1
- package/src/core/text-rendering/font-face-types/WebTrFontFace.ts +13 -7
- package/src/core/text-rendering/renderers/CanvasTextRenderer.ts +52 -20
- package/src/core/text-rendering/renderers/LightningTextTextureRenderer.ts +59 -13
- package/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.ts +36 -8
- package/src/core/text-rendering/renderers/SdfTextRenderer/internal/getStartConditions.ts +38 -5
- package/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText.ts +5 -2
- package/src/core/text-rendering/renderers/TextRenderer.ts +17 -10
- package/src/core/textures/RenderTexture.ts +81 -0
- package/src/core/utils.ts +101 -93
- package/src/main-api/INode.ts +11 -0
- package/src/main-api/RendererMain.ts +4 -3
- package/src/render-drivers/main/MainOnlyNode.ts +44 -0
- package/src/render-drivers/main/MainOnlyTextNode.ts +2 -3
- package/src/render-drivers/threadx/NodeStruct.ts +10 -0
- package/src/render-drivers/threadx/SharedNode.ts +2 -0
- package/src/render-drivers/threadx/TextNodeStruct.ts +3 -1
- package/src/render-drivers/threadx/ThreadXCoreDriver.ts +2 -0
- package/src/render-drivers/threadx/ThreadXMainNode.ts +9 -0
- package/src/render-drivers/threadx/worker/ThreadXRendererNode.ts +1 -0
- package/src/render-drivers/threadx/worker/ThreadXRendererTextNode.ts +1 -0
- package/src/render-drivers/threadx/worker/renderer.ts +1 -0
|
@@ -17,12 +17,12 @@
|
|
|
17
17
|
* limitations under the License.
|
|
18
18
|
*/
|
|
19
19
|
|
|
20
|
+
import { assertTruthy, createWebGLContext, hasOwn } from '../../../utils.js';
|
|
20
21
|
import {
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
} from '
|
|
25
|
-
import { CoreRenderer, type CoreRendererOptions, type QuadOptions } from '../CoreRenderer.js';
|
|
22
|
+
CoreRenderer,
|
|
23
|
+
type CoreRendererOptions,
|
|
24
|
+
type QuadOptions,
|
|
25
|
+
} from '../CoreRenderer.js';
|
|
26
26
|
import { WebGlCoreRenderOp } from './WebGlCoreRenderOp.js';
|
|
27
27
|
import type { CoreContextTexture } from '../CoreContextTexture.js';
|
|
28
28
|
import {
|
|
@@ -47,6 +47,9 @@ import {
|
|
|
47
47
|
import type { Dimensions } from '../../../common/CommonTypes.js';
|
|
48
48
|
import { WebGlCoreShader } from './WebGlCoreShader.js';
|
|
49
49
|
import { WebGlContextWrapper } from '../../lib/WebGlContextWrapper.js';
|
|
50
|
+
import { RenderTexture } from '../../textures/RenderTexture.js';
|
|
51
|
+
import type { CoreNode } from '../../CoreNode.js';
|
|
52
|
+
import { WebGlCoreCtxRenderTexture } from './WebGlCoreCtxRenderTexture.js';
|
|
50
53
|
|
|
51
54
|
const WORDS_PER_QUAD = 24;
|
|
52
55
|
// const BYTES_PER_QUAD = WORDS_PER_QUAD * 4;
|
|
@@ -72,7 +75,8 @@ export class WebGlCoreRenderer extends CoreRenderer {
|
|
|
72
75
|
//// Render Op / Buffer Filling State
|
|
73
76
|
curBufferIdx = 0;
|
|
74
77
|
curRenderOp: WebGlCoreRenderOp | null = null;
|
|
75
|
-
|
|
78
|
+
override rttNodes: CoreNode[] = [];
|
|
79
|
+
activeRttNode: CoreNode | null = null;
|
|
76
80
|
|
|
77
81
|
//// Default Shader
|
|
78
82
|
defaultShader: WebGlCoreShader;
|
|
@@ -83,6 +87,11 @@ export class WebGlCoreRenderer extends CoreRenderer {
|
|
|
83
87
|
*/
|
|
84
88
|
defaultTexture: Texture;
|
|
85
89
|
|
|
90
|
+
/**
|
|
91
|
+
* Whether the renderer is currently rendering to a texture.
|
|
92
|
+
*/
|
|
93
|
+
public renderToTextureActive = false;
|
|
94
|
+
|
|
86
95
|
constructor(options: WebGlCoreRendererOptions) {
|
|
87
96
|
super(options);
|
|
88
97
|
this.mode = 'webgl';
|
|
@@ -90,6 +99,12 @@ export class WebGlCoreRenderer extends CoreRenderer {
|
|
|
90
99
|
const { canvas, clearColor, bufferMemory } = options;
|
|
91
100
|
|
|
92
101
|
this.defaultTexture = new ColorTexture(this.txManager);
|
|
102
|
+
|
|
103
|
+
// Mark the default texture as ALWAYS renderable
|
|
104
|
+
// This prevents it from ever being garbage collected.
|
|
105
|
+
// Fixes https://github.com/lightning-js/renderer/issues/262
|
|
106
|
+
this.defaultTexture.setRenderableOwner(this, true);
|
|
107
|
+
|
|
93
108
|
// When the default texture is loaded, request a render in case the
|
|
94
109
|
// RAF is paused. Fixes: https://github.com/lightning-js/renderer/issues/123
|
|
95
110
|
this.defaultTexture.once('loaded', () => {
|
|
@@ -177,6 +192,12 @@ export class WebGlCoreRenderer extends CoreRenderer {
|
|
|
177
192
|
this.txMemManager,
|
|
178
193
|
textureSource,
|
|
179
194
|
);
|
|
195
|
+
} else if (textureSource instanceof RenderTexture) {
|
|
196
|
+
return new WebGlCoreCtxRenderTexture(
|
|
197
|
+
this.glw,
|
|
198
|
+
this.txMemManager,
|
|
199
|
+
textureSource,
|
|
200
|
+
);
|
|
180
201
|
}
|
|
181
202
|
return new WebGlCoreCtxTexture(this.glw, this.txMemManager, textureSource);
|
|
182
203
|
}
|
|
@@ -213,6 +234,9 @@ export class WebGlCoreRenderer extends CoreRenderer {
|
|
|
213
234
|
tb,
|
|
214
235
|
tc,
|
|
215
236
|
td,
|
|
237
|
+
rtt: renderToTexture,
|
|
238
|
+
parentHasRenderTexture,
|
|
239
|
+
framebufferDimensions,
|
|
216
240
|
} = params;
|
|
217
241
|
let { texture } = params;
|
|
218
242
|
|
|
@@ -234,39 +258,22 @@ export class WebGlCoreRenderer extends CoreRenderer {
|
|
|
234
258
|
const targetDims = {
|
|
235
259
|
width,
|
|
236
260
|
height,
|
|
237
|
-
// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment
|
|
238
261
|
};
|
|
239
262
|
const targetShader = shader || this.defaultShader;
|
|
240
263
|
assertTruthy(targetShader instanceof WebGlCoreShader);
|
|
241
|
-
if (curRenderOp) {
|
|
242
|
-
// If the current render op is not the same shader, create a new one
|
|
243
|
-
// If the current render op's shader props are not compatible with the
|
|
244
|
-
// the new shader props, create a new one render op.
|
|
245
|
-
if (
|
|
246
|
-
curRenderOp.shader !== targetShader ||
|
|
247
|
-
!compareRect(curRenderOp.clippingRect, clippingRect) ||
|
|
248
|
-
(curRenderOp.shader !== this.defaultShader &&
|
|
249
|
-
(!shaderProps ||
|
|
250
|
-
!curRenderOp.shader.canBatchShaderProps(
|
|
251
|
-
curRenderOp.shaderProps,
|
|
252
|
-
shaderProps,
|
|
253
|
-
)))
|
|
254
|
-
) {
|
|
255
|
-
curRenderOp = null;
|
|
256
|
-
}
|
|
257
|
-
}
|
|
258
|
-
assertTruthy(targetShader instanceof WebGlCoreShader);
|
|
259
264
|
|
|
260
|
-
|
|
261
|
-
if (!curRenderOp) {
|
|
265
|
+
if (!this.reuseRenderOp(params)) {
|
|
262
266
|
// eslint-disable-next-line @typescript-eslint/no-unsafe-argument
|
|
263
267
|
this.newRenderOp(
|
|
264
268
|
targetShader,
|
|
265
|
-
shaderProps as
|
|
269
|
+
shaderProps as Record<string, unknown>,
|
|
266
270
|
alpha,
|
|
267
271
|
targetDims,
|
|
268
272
|
clippingRect,
|
|
269
273
|
bufferIdx,
|
|
274
|
+
renderToTexture,
|
|
275
|
+
parentHasRenderTexture,
|
|
276
|
+
framebufferDimensions,
|
|
270
277
|
);
|
|
271
278
|
curRenderOp = this.curRenderOp;
|
|
272
279
|
assertTruthy(curRenderOp);
|
|
@@ -303,6 +310,7 @@ export class WebGlCoreRenderer extends CoreRenderer {
|
|
|
303
310
|
const ctxTexture = txManager.getCtxTexture(texture);
|
|
304
311
|
assertTruthy(ctxTexture instanceof WebGlCoreCtxTexture);
|
|
305
312
|
const textureIdx = this.addTexture(ctxTexture, bufferIdx);
|
|
313
|
+
|
|
306
314
|
curRenderOp = this.curRenderOp;
|
|
307
315
|
assertTruthy(curRenderOp);
|
|
308
316
|
|
|
@@ -398,6 +406,9 @@ export class WebGlCoreRenderer extends CoreRenderer {
|
|
|
398
406
|
dimensions: Dimensions,
|
|
399
407
|
clippingRect: RectWithValid,
|
|
400
408
|
bufferIdx: number,
|
|
409
|
+
renderToTexture?: boolean,
|
|
410
|
+
parentHasRenderTexture?: boolean,
|
|
411
|
+
framebufferDimensions?: Dimensions,
|
|
401
412
|
) {
|
|
402
413
|
const curRenderOp = new WebGlCoreRenderOp(
|
|
403
414
|
this.glw,
|
|
@@ -410,6 +421,9 @@ export class WebGlCoreRenderer extends CoreRenderer {
|
|
|
410
421
|
dimensions,
|
|
411
422
|
bufferIdx,
|
|
412
423
|
0, // Z-Index is only used for explictly added Render Ops
|
|
424
|
+
renderToTexture,
|
|
425
|
+
parentHasRenderTexture,
|
|
426
|
+
framebufferDimensions,
|
|
413
427
|
);
|
|
414
428
|
this.curRenderOp = curRenderOp;
|
|
415
429
|
this.renderOps.push(curRenderOp);
|
|
@@ -456,6 +470,50 @@ export class WebGlCoreRenderer extends CoreRenderer {
|
|
|
456
470
|
return textureIdx;
|
|
457
471
|
}
|
|
458
472
|
|
|
473
|
+
/**
|
|
474
|
+
* Test if the current Render operation can be reused for the specified parameters.
|
|
475
|
+
* @param params
|
|
476
|
+
* @returns
|
|
477
|
+
*/
|
|
478
|
+
reuseRenderOp(params: QuadOptions) {
|
|
479
|
+
const { shader, shaderProps, parentHasRenderTexture, rtt, clippingRect } =
|
|
480
|
+
params;
|
|
481
|
+
|
|
482
|
+
const targetShader = shader || this.defaultShader;
|
|
483
|
+
|
|
484
|
+
// Switching shader program will require a new render operation
|
|
485
|
+
if (this.curRenderOp?.shader !== targetShader) {
|
|
486
|
+
return false;
|
|
487
|
+
}
|
|
488
|
+
|
|
489
|
+
// Switching clipping rect will require a new render operation
|
|
490
|
+
if (!compareRect(this.curRenderOp.clippingRect, clippingRect)) {
|
|
491
|
+
return false;
|
|
492
|
+
}
|
|
493
|
+
|
|
494
|
+
// Force new render operation if rendering to texture
|
|
495
|
+
// @todo: This needs to be improved, render operations could also be reused
|
|
496
|
+
// for rendering to texture
|
|
497
|
+
if (parentHasRenderTexture || rtt) {
|
|
498
|
+
return false;
|
|
499
|
+
}
|
|
500
|
+
|
|
501
|
+
// Check if the shader can batch the shader properties
|
|
502
|
+
if (
|
|
503
|
+
this.curRenderOp.shader !== this.defaultShader &&
|
|
504
|
+
(!shaderProps ||
|
|
505
|
+
!this.curRenderOp.shader.canBatchShaderProps(
|
|
506
|
+
this.curRenderOp.shaderProps,
|
|
507
|
+
shaderProps,
|
|
508
|
+
))
|
|
509
|
+
) {
|
|
510
|
+
return false;
|
|
511
|
+
}
|
|
512
|
+
|
|
513
|
+
// Render operation can be reused
|
|
514
|
+
return true;
|
|
515
|
+
}
|
|
516
|
+
|
|
459
517
|
/**
|
|
460
518
|
* add RenderOp to the render pipeline
|
|
461
519
|
*/
|
|
@@ -483,16 +541,91 @@ export class WebGlCoreRenderer extends CoreRenderer {
|
|
|
483
541
|
if (doLog) {
|
|
484
542
|
console.log('renderOps', this.renderOps.length);
|
|
485
543
|
}
|
|
544
|
+
|
|
486
545
|
this.renderOps.forEach((renderOp, i) => {
|
|
487
546
|
if (doLog) {
|
|
488
|
-
console.log('
|
|
547
|
+
console.log('Quads per operation', renderOp.numQuads);
|
|
489
548
|
}
|
|
490
549
|
renderOp.draw();
|
|
491
550
|
});
|
|
551
|
+
}
|
|
492
552
|
|
|
493
|
-
|
|
494
|
-
this.
|
|
553
|
+
renderToTexture(node: CoreNode) {
|
|
554
|
+
for (let i = 0; i < this.rttNodes.length; i++) {
|
|
555
|
+
if (this.rttNodes[i] === node) {
|
|
556
|
+
return;
|
|
557
|
+
}
|
|
558
|
+
}
|
|
559
|
+
|
|
560
|
+
// @todo: Better bottom up rendering order
|
|
561
|
+
this.rttNodes.unshift(node);
|
|
495
562
|
}
|
|
496
|
-
}
|
|
497
563
|
|
|
498
|
-
|
|
564
|
+
renderRTTNodes() {
|
|
565
|
+
const { glw } = this;
|
|
566
|
+
const { txManager } = this.stage;
|
|
567
|
+
// Render all associated RTT nodes to their textures
|
|
568
|
+
for (let i = 0; i < this.rttNodes.length; i++) {
|
|
569
|
+
const node = this.rttNodes[i];
|
|
570
|
+
|
|
571
|
+
// Skip nodes that don't have RTT updates
|
|
572
|
+
if (!node || !node.hasRTTupdates) {
|
|
573
|
+
continue;
|
|
574
|
+
}
|
|
575
|
+
|
|
576
|
+
// Set the active RTT node to the current node
|
|
577
|
+
// So we can prevent rendering children of nested RTT nodes
|
|
578
|
+
this.activeRttNode = node;
|
|
579
|
+
|
|
580
|
+
assertTruthy(node.texture, 'RTT node missing texture');
|
|
581
|
+
const ctxTexture = txManager.getCtxTexture(node.texture);
|
|
582
|
+
assertTruthy(ctxTexture instanceof WebGlCoreCtxRenderTexture);
|
|
583
|
+
this.renderToTextureActive = true;
|
|
584
|
+
|
|
585
|
+
// Bind the the texture's framebuffer
|
|
586
|
+
glw.bindFramebuffer(ctxTexture.framebuffer);
|
|
587
|
+
|
|
588
|
+
glw.viewport(0, 0, ctxTexture.w, ctxTexture.h);
|
|
589
|
+
glw.clear();
|
|
590
|
+
|
|
591
|
+
// Render all associated quads to the texture
|
|
592
|
+
for (let i = 0; i < node.children.length; i++) {
|
|
593
|
+
const child = node.children[i];
|
|
594
|
+
if (!child) {
|
|
595
|
+
continue;
|
|
596
|
+
}
|
|
597
|
+
child.update(this.stage.deltaTime, {
|
|
598
|
+
x: 0,
|
|
599
|
+
y: 0,
|
|
600
|
+
width: 0,
|
|
601
|
+
height: 0,
|
|
602
|
+
valid: false,
|
|
603
|
+
});
|
|
604
|
+
|
|
605
|
+
this.stage.addQuads(child);
|
|
606
|
+
child.hasRTTupdates = false;
|
|
607
|
+
}
|
|
608
|
+
|
|
609
|
+
// Render all associated quads to the texture
|
|
610
|
+
this.render();
|
|
611
|
+
|
|
612
|
+
// Reset render operations
|
|
613
|
+
this.renderOps.length = 0;
|
|
614
|
+
node.hasRTTupdates = false;
|
|
615
|
+
}
|
|
616
|
+
|
|
617
|
+
// Bind the default framebuffer
|
|
618
|
+
glw.bindFramebuffer(null);
|
|
619
|
+
|
|
620
|
+
glw.viewport(0, 0, this.glw.canvas.width, this.glw.canvas.height);
|
|
621
|
+
this.renderToTextureActive = false;
|
|
622
|
+
}
|
|
623
|
+
|
|
624
|
+
removeRTTNode(node: CoreNode) {
|
|
625
|
+
const index = this.rttNodes.indexOf(node);
|
|
626
|
+
if (index === -1) {
|
|
627
|
+
return;
|
|
628
|
+
}
|
|
629
|
+
this.rttNodes.splice(index, 1);
|
|
630
|
+
}
|
|
631
|
+
}
|
|
@@ -261,10 +261,35 @@ export abstract class WebGlCoreShader extends CoreShader {
|
|
|
261
261
|
if (renderOp.textures.length > 0) {
|
|
262
262
|
this.bindTextures(renderOp.textures);
|
|
263
263
|
}
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
|
|
264
|
+
|
|
265
|
+
const { glw, parentHasRenderTexture, renderToTexture } = renderOp;
|
|
266
|
+
|
|
267
|
+
// Skip if the parent and current operation both have render textures
|
|
268
|
+
if (renderToTexture && parentHasRenderTexture) {
|
|
269
|
+
return;
|
|
270
|
+
}
|
|
271
|
+
|
|
272
|
+
// Bind render texture framebuffer dimensions as resolution
|
|
273
|
+
// if the parent has a render texture
|
|
274
|
+
if (parentHasRenderTexture) {
|
|
275
|
+
const { width, height } = renderOp.framebufferDimensions || {};
|
|
276
|
+
// Force pixel ratio to 1.0 for render textures since they are always 1:1
|
|
277
|
+
// the final render texture will be rendered to the screen with the correct pixel ratio
|
|
278
|
+
this.setUniform('u_pixelRatio', 1.0);
|
|
279
|
+
|
|
280
|
+
// Set resolution to the framebuffer dimensions
|
|
281
|
+
this.setUniform(
|
|
282
|
+
'u_resolution',
|
|
283
|
+
new Float32Array([width ?? 0, height ?? 0]),
|
|
284
|
+
);
|
|
285
|
+
} else {
|
|
286
|
+
this.setUniform('u_pixelRatio', renderOp.options.pixelRatio);
|
|
287
|
+
this.setUniform(
|
|
288
|
+
'u_resolution',
|
|
289
|
+
new Float32Array([glw.canvas.width, glw.canvas.height]),
|
|
290
|
+
);
|
|
291
|
+
}
|
|
292
|
+
|
|
268
293
|
if (props) {
|
|
269
294
|
// Bind optional automatic uniforms
|
|
270
295
|
// These are only bound if their keys are present in the props.
|
|
@@ -61,16 +61,14 @@ export class DefaultShader extends WebGlCoreShader {
|
|
|
61
61
|
varying vec2 v_textureCoordinate;
|
|
62
62
|
|
|
63
63
|
void main() {
|
|
64
|
-
vec2 normalized = a_position * u_pixelRatio
|
|
65
|
-
vec2
|
|
66
|
-
vec2 clip_space = zero_two - 1.0;
|
|
64
|
+
vec2 normalized = a_position * u_pixelRatio;
|
|
65
|
+
vec2 screenSpace = vec2(2.0 / u_resolution.x, -2.0 / u_resolution.y);
|
|
67
66
|
|
|
68
|
-
// pass to fragment
|
|
69
67
|
v_color = a_color;
|
|
70
68
|
v_textureCoordinate = a_textureCoordinate;
|
|
71
69
|
|
|
72
|
-
|
|
73
|
-
gl_Position =
|
|
70
|
+
gl_Position = vec4(normalized.x * screenSpace.x - 1.0, normalized.y * -abs(screenSpace.y) + 1.0, 0.0, 1.0);
|
|
71
|
+
gl_Position.y = -sign(screenSpace.y) * gl_Position.y;
|
|
74
72
|
}
|
|
75
73
|
`,
|
|
76
74
|
fragment: `
|
|
@@ -136,8 +136,13 @@ export class SdfShader extends WebGlCoreShader {
|
|
|
136
136
|
void main() {
|
|
137
137
|
vec2 scrolledPosition = a_position * u_size - vec2(0, u_scrollY);
|
|
138
138
|
vec2 transformedPosition = (u_transform * vec3(scrolledPosition, 1)).xy;
|
|
139
|
-
|
|
139
|
+
|
|
140
|
+
// Calculate screen space with pixel ratio
|
|
141
|
+
vec2 screenSpace = (transformedPosition * u_pixelRatio / u_resolution * 2.0 - 1.0) * vec2(1, -1);
|
|
142
|
+
|
|
143
|
+
gl_Position = vec4(screenSpace, 0.0, 1.0);
|
|
140
144
|
v_texcoord = a_textureCoordinate;
|
|
145
|
+
|
|
141
146
|
}
|
|
142
147
|
`,
|
|
143
148
|
fragment: `
|
|
@@ -0,0 +1,36 @@
|
|
|
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 2024 Comcast Cable Communications Management, LLC.
|
|
6
|
+
*
|
|
7
|
+
* Licensed under the Apache License, Version 2.0 (the License);
|
|
8
|
+
* you may not use this file except in compliance with the License.
|
|
9
|
+
* You may obtain a copy of the License at
|
|
10
|
+
*
|
|
11
|
+
* http://www.apache.org/licenses/LICENSE-2.0
|
|
12
|
+
*
|
|
13
|
+
* Unless required by applicable law or agreed to in writing, software
|
|
14
|
+
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
15
|
+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
16
|
+
* See the License for the specific language governing permissions and
|
|
17
|
+
* limitations under the License.
|
|
18
|
+
*/
|
|
19
|
+
import type { NormalizedFontMetrics } from './font-face-types/TrFontFace.js';
|
|
20
|
+
|
|
21
|
+
/**
|
|
22
|
+
* Calculate the default line height given normalized font metrics
|
|
23
|
+
*
|
|
24
|
+
* @remarks
|
|
25
|
+
* This method may be used for both the WebTrFontFace and SdfTrFontFace font types.
|
|
26
|
+
*
|
|
27
|
+
* @param metrics
|
|
28
|
+
* @param fontSize
|
|
29
|
+
* @returns
|
|
30
|
+
*/
|
|
31
|
+
export function calcDefaultLineHeight(
|
|
32
|
+
metrics: NormalizedFontMetrics,
|
|
33
|
+
fontSize: number,
|
|
34
|
+
): number {
|
|
35
|
+
return fontSize * (metrics.ascender - metrics.descender + metrics.lineGap);
|
|
36
|
+
}
|
|
@@ -17,6 +17,9 @@
|
|
|
17
17
|
* limitations under the License.
|
|
18
18
|
*/
|
|
19
19
|
|
|
20
|
+
import type { NormalizedFontMetrics } from './font-face-types/TrFontFace.js';
|
|
21
|
+
import type { WebTrFontFace } from './font-face-types/WebTrFontFace.js';
|
|
22
|
+
|
|
20
23
|
/**
|
|
21
24
|
* Returns CSS font setting string for use in canvas context.
|
|
22
25
|
*
|
|
@@ -120,6 +123,77 @@ export function measureText(
|
|
|
120
123
|
}, 0);
|
|
121
124
|
}
|
|
122
125
|
|
|
126
|
+
/**
|
|
127
|
+
* Get the font metrics for a font face.
|
|
128
|
+
*
|
|
129
|
+
* @remarks
|
|
130
|
+
* This function will attempt to grab the explicitly defined metrics from the
|
|
131
|
+
* font face first. If the font face does not have metrics defined, it will
|
|
132
|
+
* attempt to calculate the metrics using the browser's measureText method.
|
|
133
|
+
*
|
|
134
|
+
* If the browser does not support the font metrics API, it will use some
|
|
135
|
+
* default values.
|
|
136
|
+
*
|
|
137
|
+
* @param context
|
|
138
|
+
* @param fontFace
|
|
139
|
+
* @param fontSize
|
|
140
|
+
* @returns
|
|
141
|
+
*/
|
|
142
|
+
export function getWebFontMetrics(
|
|
143
|
+
context: CanvasRenderingContext2D | OffscreenCanvasRenderingContext2D,
|
|
144
|
+
fontFace: WebTrFontFace,
|
|
145
|
+
fontSize: number,
|
|
146
|
+
): NormalizedFontMetrics {
|
|
147
|
+
if (fontFace.metrics) {
|
|
148
|
+
return fontFace.metrics;
|
|
149
|
+
}
|
|
150
|
+
// If the font face doesn't have metrics defined, we fallback to using the
|
|
151
|
+
// browser's measureText method to calculate take a best guess at the font
|
|
152
|
+
// actual font's metrics.
|
|
153
|
+
// - fontBoundingBox[Ascent|Descent] is the best estimate but only supported
|
|
154
|
+
// in Chrome 87+ (2020), Firefox 116+ (2023), and Safari 11.1+ (2018).
|
|
155
|
+
// - It is an estimate as it can vary between browsers.
|
|
156
|
+
// - actualBoundingBox[Ascent|Descent] is less accurate and supported in
|
|
157
|
+
// Chrome 77+ (2019), Firefox 74+ (2020), and Safari 11.1+ (2018).
|
|
158
|
+
// - If neither are supported, we'll use some default values which will
|
|
159
|
+
// get text on the screen but likely not be great.
|
|
160
|
+
// NOTE: It's been decided not to rely on fontBoundingBox[Ascent|Descent]
|
|
161
|
+
// as it's browser support is limited and it also tends to produce higher than
|
|
162
|
+
// expected values. It is instead HIGHLY RECOMMENDED that developers provide
|
|
163
|
+
// explicit metrics in the font face definition.
|
|
164
|
+
const browserMetrics = context.measureText(
|
|
165
|
+
'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz',
|
|
166
|
+
);
|
|
167
|
+
console.warn(
|
|
168
|
+
`Font metrics not provided for Canvas Web font ${fontFace.fontFamily}. ` +
|
|
169
|
+
'Using fallback values. It is HIGHLY recommended you use the latest ' +
|
|
170
|
+
'version of the Lightning 3 `msdf-generator` tool to extract the default ' +
|
|
171
|
+
'metrics for the font and provide them in the Canvas Web font definition.',
|
|
172
|
+
);
|
|
173
|
+
let metrics: NormalizedFontMetrics;
|
|
174
|
+
if (
|
|
175
|
+
browserMetrics.actualBoundingBoxDescent &&
|
|
176
|
+
browserMetrics.actualBoundingBoxAscent
|
|
177
|
+
) {
|
|
178
|
+
metrics = {
|
|
179
|
+
ascender: browserMetrics.actualBoundingBoxAscent / fontSize,
|
|
180
|
+
descender: -browserMetrics.actualBoundingBoxDescent / fontSize,
|
|
181
|
+
lineGap: 0.2,
|
|
182
|
+
};
|
|
183
|
+
} else {
|
|
184
|
+
// If the browser doesn't support the font metrics API, we'll use some
|
|
185
|
+
// default values.
|
|
186
|
+
metrics = {
|
|
187
|
+
ascender: 0.8,
|
|
188
|
+
descender: -0.2,
|
|
189
|
+
lineGap: 0.2,
|
|
190
|
+
};
|
|
191
|
+
}
|
|
192
|
+
// Save the calculated metrics to the font face for future use.
|
|
193
|
+
(fontFace.metrics as NormalizedFontMetrics | null) = metrics;
|
|
194
|
+
return metrics;
|
|
195
|
+
}
|
|
196
|
+
|
|
123
197
|
export interface WrapTextResult {
|
|
124
198
|
l: string[];
|
|
125
199
|
n: number[];
|
|
@@ -22,7 +22,12 @@ import { assertTruthy } from '../../../../utils.js';
|
|
|
22
22
|
import type { Stage } from '../../../Stage.js';
|
|
23
23
|
import { WebGlCoreRenderer } from '../../../renderers/webgl/WebGlCoreRenderer.js';
|
|
24
24
|
import { ImageTexture } from '../../../textures/ImageTexture.js';
|
|
25
|
-
import {
|
|
25
|
+
import {
|
|
26
|
+
TrFontFace,
|
|
27
|
+
type NormalizedFontMetrics,
|
|
28
|
+
type TrFontFaceDescriptors,
|
|
29
|
+
type TrFontFaceOptions,
|
|
30
|
+
} from '../TrFontFace.js';
|
|
26
31
|
import type { FontShaper } from './internal/FontShaper.js';
|
|
27
32
|
import { SdfFontShaper, type SdfFontData } from './internal/SdfFontShaper.js';
|
|
28
33
|
|
|
@@ -42,6 +47,12 @@ interface GlyphAtlasEntry {
|
|
|
42
47
|
height: number;
|
|
43
48
|
}
|
|
44
49
|
|
|
50
|
+
export interface SdfTrFontFaceOptions extends TrFontFaceOptions {
|
|
51
|
+
atlasUrl: string;
|
|
52
|
+
atlasDataUrl: string;
|
|
53
|
+
stage: Stage;
|
|
54
|
+
}
|
|
55
|
+
|
|
45
56
|
export class SdfTrFontFace<
|
|
46
57
|
FontTypeT extends SdfFontType = SdfFontType,
|
|
47
58
|
> extends TrFontFace {
|
|
@@ -49,21 +60,16 @@ export class SdfTrFontFace<
|
|
|
49
60
|
public readonly texture: ImageTexture;
|
|
50
61
|
/**
|
|
51
62
|
* Height of the tallest character in the font including the whitespace above it
|
|
63
|
+
* in SDF/vertex units.
|
|
52
64
|
*/
|
|
53
65
|
public readonly maxCharHeight: number = 0;
|
|
54
66
|
public readonly data: SdfFontData | undefined;
|
|
55
67
|
public readonly shaper: FontShaper | undefined;
|
|
56
68
|
public readonly glyphMap: Map<number, SdfFontData['chars'][0]> = new Map();
|
|
57
69
|
|
|
58
|
-
constructor(
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
type: FontTypeT,
|
|
62
|
-
stage: Stage,
|
|
63
|
-
atlasUrl: string,
|
|
64
|
-
atlasDataUrl: string,
|
|
65
|
-
) {
|
|
66
|
-
super(fontFamily, descriptors);
|
|
70
|
+
constructor(type: FontTypeT, options: SdfTrFontFaceOptions) {
|
|
71
|
+
super(options);
|
|
72
|
+
const { atlasUrl, atlasDataUrl, stage } = options;
|
|
67
73
|
this.type = type;
|
|
68
74
|
const renderer = stage.renderer;
|
|
69
75
|
assertTruthy(
|
|
@@ -95,10 +101,11 @@ export class SdfTrFontFace<
|
|
|
95
101
|
.then(async (response) => {
|
|
96
102
|
// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment
|
|
97
103
|
(this.data as SdfFontData) = await response.json();
|
|
104
|
+
assertTruthy(this.data);
|
|
98
105
|
// Add all the glyphs to the glyph map
|
|
99
106
|
// eslint-disable-next-line @typescript-eslint/no-non-null-assertion
|
|
100
107
|
let maxCharHeight = 0;
|
|
101
|
-
this.data
|
|
108
|
+
this.data.chars.forEach((glyph) => {
|
|
102
109
|
this.glyphMap.set(glyph.id, glyph);
|
|
103
110
|
const charHeight = glyph.yoffset + glyph.height;
|
|
104
111
|
if (charHeight > maxCharHeight) {
|
|
@@ -110,9 +117,31 @@ export class SdfTrFontFace<
|
|
|
110
117
|
// We know `data` is defined here, because we just set it
|
|
111
118
|
// eslint-disable-next-line @typescript-eslint/no-non-null-assertion
|
|
112
119
|
(this.shaper as FontShaper) = new SdfFontShaper(
|
|
113
|
-
this.data
|
|
120
|
+
this.data,
|
|
114
121
|
this.glyphMap,
|
|
115
122
|
);
|
|
123
|
+
|
|
124
|
+
// If the metrics aren't provided explicitly in the font face options,
|
|
125
|
+
// Gather them from the metrics added by the msdf-generator tool ()
|
|
126
|
+
// If they are missing then we throw an error.
|
|
127
|
+
if (!this.metrics) {
|
|
128
|
+
if (this.data?.lightningMetrics) {
|
|
129
|
+
const { ascender, descender, lineGap, unitsPerEm } =
|
|
130
|
+
this.data.lightningMetrics;
|
|
131
|
+
(this.metrics as NormalizedFontMetrics | null) = {
|
|
132
|
+
ascender: ascender / unitsPerEm,
|
|
133
|
+
descender: descender / unitsPerEm,
|
|
134
|
+
lineGap: lineGap / unitsPerEm,
|
|
135
|
+
};
|
|
136
|
+
} else {
|
|
137
|
+
throw new Error(
|
|
138
|
+
`Font metrics not found in ${this.type} font ${this.fontFamily}. ` +
|
|
139
|
+
'Make sure you are using the latest version of the Lightning ' +
|
|
140
|
+
'3 `msdf-generator` tool to generate your SDF fonts.',
|
|
141
|
+
);
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
|
|
116
145
|
this.checkLoaded();
|
|
117
146
|
})
|
|
118
147
|
.catch(console.error);
|
|
@@ -19,6 +19,7 @@
|
|
|
19
19
|
|
|
20
20
|
import type { PeekableIterator } from '../../../renderers/SdfTextRenderer/internal/PeekableGenerator.js';
|
|
21
21
|
import { SpecialCodepoints } from '../../../renderers/SdfTextRenderer/internal/SpecialCodepoints.js';
|
|
22
|
+
import type { FontMetrics } from '../../TrFontFace.js';
|
|
22
23
|
import {
|
|
23
24
|
FontShaper,
|
|
24
25
|
type FontShaperProps,
|
|
@@ -166,4 +167,5 @@ export interface SdfFontData {
|
|
|
166
167
|
fieldType: 'sdf' | 'msdf';
|
|
167
168
|
distanceRange: number;
|
|
168
169
|
};
|
|
170
|
+
lightningMetrics?: FontMetrics;
|
|
169
171
|
}
|