@lightningjs/renderer 2.5.1 → 2.6.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.
- package/dist/exports/index.d.ts +1 -0
- package/dist/exports/index.js.map +1 -1
- package/dist/src/core/CoreNode.d.ts +1 -2
- package/dist/src/core/CoreNode.js +42 -31
- package/dist/src/core/CoreNode.js.map +1 -1
- package/dist/src/core/CoreTextNode.d.ts +1 -1
- package/dist/src/core/CoreTextNode.js +2 -2
- package/dist/src/core/CoreTextNode.js.map +1 -1
- package/dist/src/core/Stage.d.ts +5 -0
- package/dist/src/core/Stage.js +10 -2
- package/dist/src/core/Stage.js.map +1 -1
- package/dist/src/core/lib/utils.d.ts +8 -0
- package/dist/src/core/lib/utils.js +10 -0
- package/dist/src/core/lib/utils.js.map +1 -1
- package/dist/src/core/renderers/canvas/CanvasCoreRenderer.js +1 -1
- package/dist/src/core/renderers/canvas/CanvasCoreRenderer.js.map +1 -1
- package/dist/src/core/text-rendering/renderers/CanvasTextRenderer.js +2 -0
- package/dist/src/core/text-rendering/renderers/CanvasTextRenderer.js.map +1 -1
- package/dist/src/core/utils.d.ts +1 -1
- package/dist/src/main-api/Inspector.js +51 -36
- package/dist/src/main-api/Inspector.js.map +1 -1
- package/dist/src/main-api/Renderer.d.ts +10 -0
- package/dist/src/main-api/Renderer.js +2 -1
- package/dist/src/main-api/Renderer.js.map +1 -1
- package/dist/tsconfig.dist.tsbuildinfo +1 -1
- package/exports/index.ts +1 -0
- package/package.json +1 -2
- package/src/core/CoreNode.ts +54 -45
- package/src/core/CoreTextNode.ts +2 -2
- package/src/core/Stage.ts +12 -2
- package/src/core/lib/utils.ts +19 -0
- package/src/core/renderers/canvas/CanvasCoreRenderer.ts +1 -1
- package/src/core/text-rendering/renderers/CanvasTextRenderer.ts +2 -0
- package/src/main-api/Inspector.ts +62 -43
- package/src/main-api/Renderer.ts +13 -2
- package/dist/exports/core-api.d.ts +0 -74
- package/dist/exports/core-api.js +0 -96
- package/dist/exports/core-api.js.map +0 -1
- package/dist/exports/main-api.d.ts +0 -30
- package/dist/exports/main-api.js +0 -45
- package/dist/exports/main-api.js.map +0 -1
- package/dist/src/core/CoreExtension.d.ts +0 -12
- package/dist/src/core/CoreExtension.js +0 -29
- package/dist/src/core/CoreExtension.js.map +0 -1
- package/dist/src/main-api/ICoreDriver.d.ts +0 -24
- package/dist/src/main-api/ICoreDriver.js +0 -20
- package/dist/src/main-api/ICoreDriver.js.map +0 -1
- package/dist/src/main-api/RendererMain.d.ts +0 -378
- package/dist/src/main-api/RendererMain.js +0 -367
- package/dist/src/main-api/RendererMain.js.map +0 -1
- package/dist/src/main-api/texture-usage-trackers/FinalizationRegistryTextureUsageTracker.d.ts +0 -9
- package/dist/src/main-api/texture-usage-trackers/FinalizationRegistryTextureUsageTracker.js +0 -38
- package/dist/src/main-api/texture-usage-trackers/FinalizationRegistryTextureUsageTracker.js.map +0 -1
- package/dist/src/main-api/texture-usage-trackers/ManualCountTextureUsageTracker.d.ts +0 -56
- package/dist/src/main-api/texture-usage-trackers/ManualCountTextureUsageTracker.js +0 -101
- package/dist/src/main-api/texture-usage-trackers/ManualCountTextureUsageTracker.js.map +0 -1
- package/dist/src/main-api/texture-usage-trackers/TextureUsageTracker.d.ts +0 -32
- package/dist/src/main-api/texture-usage-trackers/TextureUsageTracker.js +0 -28
- package/dist/src/main-api/texture-usage-trackers/TextureUsageTracker.js.map +0 -1
- package/dist/src/render-drivers/main/MainCoreDriver.d.ts +0 -21
- package/dist/src/render-drivers/main/MainCoreDriver.js +0 -115
- package/dist/src/render-drivers/main/MainCoreDriver.js.map +0 -1
- package/dist/src/render-drivers/main/MainOnlyNode.d.ts +0 -101
- package/dist/src/render-drivers/main/MainOnlyNode.js +0 -425
- package/dist/src/render-drivers/main/MainOnlyNode.js.map +0 -1
- package/dist/src/render-drivers/main/MainOnlyTextNode.d.ts +0 -47
- package/dist/src/render-drivers/main/MainOnlyTextNode.js +0 -204
- package/dist/src/render-drivers/main/MainOnlyTextNode.js.map +0 -1
- package/dist/src/render-drivers/threadx/NodeStruct.d.ts +0 -93
- package/dist/src/render-drivers/threadx/NodeStruct.js +0 -290
- package/dist/src/render-drivers/threadx/NodeStruct.js.map +0 -1
- package/dist/src/render-drivers/threadx/SharedNode.d.ts +0 -40
- package/dist/src/render-drivers/threadx/SharedNode.js +0 -61
- package/dist/src/render-drivers/threadx/SharedNode.js.map +0 -1
- package/dist/src/render-drivers/threadx/TextNodeStruct.d.ts +0 -44
- package/dist/src/render-drivers/threadx/TextNodeStruct.js +0 -203
- package/dist/src/render-drivers/threadx/TextNodeStruct.js.map +0 -1
- package/dist/src/render-drivers/threadx/ThreadXCoreDriver.d.ts +0 -25
- package/dist/src/render-drivers/threadx/ThreadXCoreDriver.js +0 -232
- package/dist/src/render-drivers/threadx/ThreadXCoreDriver.js.map +0 -1
- package/dist/src/render-drivers/threadx/ThreadXMainAnimationController.d.ts +0 -24
- package/dist/src/render-drivers/threadx/ThreadXMainAnimationController.js +0 -113
- package/dist/src/render-drivers/threadx/ThreadXMainAnimationController.js.map +0 -1
- package/dist/src/render-drivers/threadx/ThreadXMainNode.d.ts +0 -46
- package/dist/src/render-drivers/threadx/ThreadXMainNode.js +0 -160
- package/dist/src/render-drivers/threadx/ThreadXMainNode.js.map +0 -1
- package/dist/src/render-drivers/threadx/ThreadXMainTextNode.d.ts +0 -28
- package/dist/src/render-drivers/threadx/ThreadXMainTextNode.js +0 -55
- package/dist/src/render-drivers/threadx/ThreadXMainTextNode.js.map +0 -1
- package/dist/src/render-drivers/threadx/ThreadXRendererMessage.d.ts +0 -70
- package/dist/src/render-drivers/threadx/ThreadXRendererMessage.js +0 -32
- package/dist/src/render-drivers/threadx/ThreadXRendererMessage.js.map +0 -1
- package/dist/src/render-drivers/threadx/worker/ThreadXRendererNode.d.ts +0 -19
- package/dist/src/render-drivers/threadx/worker/ThreadXRendererNode.js +0 -184
- package/dist/src/render-drivers/threadx/worker/ThreadXRendererNode.js.map +0 -1
- package/dist/src/render-drivers/threadx/worker/ThreadXRendererTextNode.d.ts +0 -27
- package/dist/src/render-drivers/threadx/worker/ThreadXRendererTextNode.js +0 -109
- package/dist/src/render-drivers/threadx/worker/ThreadXRendererTextNode.js.map +0 -1
- package/dist/src/render-drivers/threadx/worker/renderer.d.ts +0 -1
- package/dist/src/render-drivers/threadx/worker/renderer.js +0 -147
- package/dist/src/render-drivers/threadx/worker/renderer.js.map +0 -1
- package/dist/src/render-drivers/utils.d.ts +0 -12
- package/dist/src/render-drivers/utils.js +0 -74
- package/dist/src/render-drivers/utils.js.map +0 -1
- package/dist/tsconfig.tsbuildinfo +0 -1
|
@@ -142,6 +142,14 @@ const gradientColorPropertyMap = [
|
|
|
142
142
|
'colorBr',
|
|
143
143
|
];
|
|
144
144
|
|
|
145
|
+
const knownProperties = new Set<string>([
|
|
146
|
+
...Object.keys(stylePropertyMap),
|
|
147
|
+
...Object.keys(domPropertyMap),
|
|
148
|
+
// ...gradientColorPropertyMap,
|
|
149
|
+
'src',
|
|
150
|
+
'parent',
|
|
151
|
+
]);
|
|
152
|
+
|
|
145
153
|
export class Inspector {
|
|
146
154
|
private root: HTMLElement | null = null;
|
|
147
155
|
private canvas: HTMLCanvasElement | null = null;
|
|
@@ -239,35 +247,22 @@ export class Inspector {
|
|
|
239
247
|
|
|
240
248
|
createNode(node: CoreNode): CoreNode {
|
|
241
249
|
const div = this.createDiv(node.id, node.props);
|
|
242
|
-
|
|
243
|
-
// eslint-disable-next-line @typescript-eslint/no-unsafe-member-access, @typescript-eslint/no-explicit-any
|
|
244
250
|
(div as any).node = node;
|
|
245
|
-
|
|
246
|
-
// eslint-disable-next-line @typescript-eslint/no-unsafe-member-access, @typescript-eslint/no-explicit-any
|
|
247
251
|
(node as any).div = div;
|
|
248
252
|
|
|
249
|
-
node.on('inViewport', () =>
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
node.on('inBounds', () => {
|
|
254
|
-
div.setAttribute('state', 'inBounds');
|
|
255
|
-
});
|
|
256
|
-
|
|
257
|
-
node.on('outOfBounds', () => {
|
|
258
|
-
div.setAttribute('state', 'outOfBounds');
|
|
259
|
-
});
|
|
253
|
+
node.on('inViewport', () => div.setAttribute('state', 'inViewport'));
|
|
254
|
+
node.on('inBounds', () => div.setAttribute('state', 'inBounds'));
|
|
255
|
+
node.on('outOfBounds', () => div.setAttribute('state', 'outOfBounds'));
|
|
260
256
|
|
|
257
|
+
// Monitor only relevant properties by trapping with selective assignment
|
|
261
258
|
return this.createProxy(node, div);
|
|
262
259
|
}
|
|
263
260
|
|
|
264
261
|
createTextNode(node: CoreNode): CoreTextNode {
|
|
265
262
|
const div = this.createDiv(node.id, node.props);
|
|
266
|
-
// eslint-disable-next-line @typescript-eslint/no-unsafe-member-access, @typescript-eslint/no-explicit-any
|
|
267
263
|
(div as any).node = node;
|
|
268
|
-
|
|
269
|
-
// eslint-disable-next-line @typescript-eslint/no-unsafe-member-access, @typescript-eslint/no-explicit-any
|
|
270
264
|
(node as any).div = div;
|
|
265
|
+
|
|
271
266
|
return this.createProxy(node, div) as CoreTextNode;
|
|
272
267
|
}
|
|
273
268
|
|
|
@@ -275,36 +270,60 @@ export class Inspector {
|
|
|
275
270
|
node: CoreNode | CoreTextNode,
|
|
276
271
|
div: HTMLElement,
|
|
277
272
|
): CoreNode | CoreTextNode {
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
273
|
+
// Define traps for each property in knownProperties
|
|
274
|
+
knownProperties.forEach((property) => {
|
|
275
|
+
const originalProp = Object.getOwnPropertyDescriptor(node, property);
|
|
276
|
+
if (!originalProp) {
|
|
277
|
+
return;
|
|
278
|
+
}
|
|
279
|
+
|
|
280
|
+
Object.defineProperties(node, {
|
|
281
|
+
[property]: {
|
|
282
|
+
get() {
|
|
283
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-return
|
|
284
|
+
return originalProp.get?.call(node);
|
|
285
|
+
},
|
|
286
|
+
set(value) {
|
|
287
|
+
originalProp.set?.call(node, value);
|
|
288
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-member-access, @typescript-eslint/no-unsafe-call
|
|
289
|
+
this.updateNodeProperty(div, property, value);
|
|
290
|
+
},
|
|
291
|
+
configurable: true,
|
|
292
|
+
enumerable: true,
|
|
293
|
+
},
|
|
294
|
+
});
|
|
295
|
+
});
|
|
296
|
+
|
|
297
|
+
const originalDestroy = node.destroy;
|
|
298
|
+
Object.defineProperty(node, 'destroy', {
|
|
299
|
+
value: () => {
|
|
300
|
+
this.destroyNode(node.id);
|
|
301
|
+
originalDestroy.call(node);
|
|
282
302
|
},
|
|
283
|
-
|
|
284
|
-
if (property === 'destroy') {
|
|
285
|
-
this.destroyNode(target.id);
|
|
286
|
-
}
|
|
303
|
+
});
|
|
287
304
|
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
|
|
295
|
-
|
|
296
|
-
|
|
297
|
-
|
|
298
|
-
|
|
299
|
-
|
|
300
|
-
|
|
301
|
-
});
|
|
302
|
-
};
|
|
303
|
-
}
|
|
305
|
+
// eslint-disable-next-line @typescript-eslint/unbound-method
|
|
306
|
+
const originalAnimate = node.animate;
|
|
307
|
+
Object.defineProperty(node, 'animate', {
|
|
308
|
+
value: (
|
|
309
|
+
props: CoreNodeAnimateProps,
|
|
310
|
+
settings: AnimationSettings,
|
|
311
|
+
): IAnimationController => {
|
|
312
|
+
const animationController = originalAnimate.call(node, props, settings);
|
|
313
|
+
|
|
314
|
+
const originalStart =
|
|
315
|
+
animationController.start.bind(animationController);
|
|
316
|
+
animationController.start = () => {
|
|
317
|
+
this.animateNode(div, props, settings);
|
|
304
318
|
|
|
305
|
-
|
|
319
|
+
return originalStart();
|
|
320
|
+
};
|
|
321
|
+
|
|
322
|
+
return animationController;
|
|
306
323
|
},
|
|
307
324
|
});
|
|
325
|
+
|
|
326
|
+
return node;
|
|
308
327
|
}
|
|
309
328
|
|
|
310
329
|
destroyNode(id: number) {
|
package/src/main-api/Renderer.ts
CHANGED
|
@@ -256,6 +256,17 @@ export interface RendererMainSettings {
|
|
|
256
256
|
* @defaultValue `false`
|
|
257
257
|
*/
|
|
258
258
|
forceWebGL2?: boolean;
|
|
259
|
+
|
|
260
|
+
/**
|
|
261
|
+
* Enable strictBounds
|
|
262
|
+
*
|
|
263
|
+
* @remarks
|
|
264
|
+
* Enable strict bounds for the renderer. This will ensure that the renderer
|
|
265
|
+
* will not render outside the bounds of the canvas.
|
|
266
|
+
*
|
|
267
|
+
* @defaultValue `true`
|
|
268
|
+
*/
|
|
269
|
+
strictBounds?: boolean;
|
|
259
270
|
}
|
|
260
271
|
|
|
261
272
|
/**
|
|
@@ -346,6 +357,7 @@ export class RendererMain extends EventEmitter {
|
|
|
346
357
|
renderEngine: settings.renderEngine,
|
|
347
358
|
quadBufferSize: settings.quadBufferSize ?? 4 * 1024 * 1024,
|
|
348
359
|
fontEngines: settings.fontEngines,
|
|
360
|
+
strictBounds: settings.strictBounds ?? true,
|
|
349
361
|
};
|
|
350
362
|
this.settings = resolvedSettings;
|
|
351
363
|
|
|
@@ -387,6 +399,7 @@ export class RendererMain extends EventEmitter {
|
|
|
387
399
|
quadBufferSize: this.settings.quadBufferSize,
|
|
388
400
|
fontEngines: this.settings.fontEngines,
|
|
389
401
|
inspector: this.settings.inspector !== null,
|
|
402
|
+
strictBounds: this.settings.strictBounds,
|
|
390
403
|
});
|
|
391
404
|
|
|
392
405
|
// Extract the root node
|
|
@@ -432,8 +445,6 @@ export class RendererMain extends EventEmitter {
|
|
|
432
445
|
createNode<
|
|
433
446
|
ShCtr extends BaseShaderController = ShaderController<'DefaultShader'>,
|
|
434
447
|
>(props: Partial<INodeProps<ShCtr>>): INode<ShCtr> {
|
|
435
|
-
assertTruthy(this.stage, 'Stage is not initialized');
|
|
436
|
-
|
|
437
448
|
const node = this.stage.createNode(props as Partial<CoreNodeProps>);
|
|
438
449
|
|
|
439
450
|
if (this.inspector) {
|
|
@@ -1,74 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Lightning 3 Renderer Core API
|
|
3
|
-
*
|
|
4
|
-
* @remarks
|
|
5
|
-
* ```
|
|
6
|
-
* import * from '@lightning/renderer/core';
|
|
7
|
-
* ```
|
|
8
|
-
*
|
|
9
|
-
* The Core API is used by developers to extend the capabilities of the Renderer
|
|
10
|
-
* by writing custom Shaders, Dynamic Shader Effects, Textures, Text Renderers,
|
|
11
|
-
* etc.
|
|
12
|
-
*
|
|
13
|
-
* Custom capabilities as well as fonts can be loaded via Core Extensions.
|
|
14
|
-
*
|
|
15
|
-
* A core extension module is structured like so:
|
|
16
|
-
* ```ts
|
|
17
|
-
* import {
|
|
18
|
-
* CoreExtension,
|
|
19
|
-
* WebTrFontFace,
|
|
20
|
-
* SdfTrFontFace,
|
|
21
|
-
* type Stage
|
|
22
|
-
* } from '@lightning/renderer/core';
|
|
23
|
-
*
|
|
24
|
-
* export default class MyCoreExtension extends CoreExtension {
|
|
25
|
-
* async run(stage: Stage) {
|
|
26
|
-
* stage.fontManager.addFontFace(
|
|
27
|
-
* new WebTrFontFace('Ubuntu', {}, '/fonts/Ubuntu-Regular.ttf'),
|
|
28
|
-
* );
|
|
29
|
-
*
|
|
30
|
-
* stage.fontManager.addFontFace(
|
|
31
|
-
* new SdfTrFontFace(
|
|
32
|
-
* 'Ubuntu',
|
|
33
|
-
* {},
|
|
34
|
-
* 'msdf',
|
|
35
|
-
* stage,
|
|
36
|
-
* '/fonts/Ubuntu-Regular.msdf.png',
|
|
37
|
-
* '/fonts/Ubuntu-Regular.msdf.json',
|
|
38
|
-
* ),
|
|
39
|
-
* );
|
|
40
|
-
* }
|
|
41
|
-
* }
|
|
42
|
-
* ```
|
|
43
|
-
*
|
|
44
|
-
* And then imported and registered in the application's entry point
|
|
45
|
-
* using the `@lightningjs/vite-plugin-import-chunk-url` plugin:
|
|
46
|
-
* ```ts
|
|
47
|
-
* import coreExtensionModuleUrl from './MyCoreExtension.js?importChunkUrl';
|
|
48
|
-
*
|
|
49
|
-
* // Set up driver, etc.
|
|
50
|
-
*
|
|
51
|
-
* // Initialize the Renderer
|
|
52
|
-
* const renderer = new RendererMain(
|
|
53
|
-
* {
|
|
54
|
-
* // Other Renderer Config...
|
|
55
|
-
* coreExtensionModule: coreExtensionModuleUrl,
|
|
56
|
-
* },
|
|
57
|
-
* 'app',
|
|
58
|
-
* driver,
|
|
59
|
-
* );
|
|
60
|
-
* ```
|
|
61
|
-
*
|
|
62
|
-
* @module
|
|
63
|
-
*/
|
|
64
|
-
export * from '../src/core/renderers/webgl/WebGlCoreShader.js';
|
|
65
|
-
export * from '../src/core/renderers/webgl/shaders/effects/ShaderEffect.js';
|
|
66
|
-
export * from '../src/core/textures/Texture.js';
|
|
67
|
-
export * from '../src/core/text-rendering/renderers/TextRenderer.js';
|
|
68
|
-
export * from '../src/core/text-rendering/renderers/CanvasTextRenderer.js';
|
|
69
|
-
export * from '../src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.js';
|
|
70
|
-
export * from '../src/core/text-rendering/font-face-types/TrFontFace.js';
|
|
71
|
-
export * from '../src/core/text-rendering/font-face-types/WebTrFontFace.js';
|
|
72
|
-
export * from '../src/core/text-rendering/font-face-types/SdfTrFontFace/SdfTrFontFace.js';
|
|
73
|
-
export * from '../src/core/CoreExtension.js';
|
|
74
|
-
export type * from '../src/core/Stage.js';
|
package/dist/exports/core-api.js
DELETED
|
@@ -1,96 +0,0 @@
|
|
|
1
|
-
/*
|
|
2
|
-
* If not stated otherwise in this file or this component's LICENSE file the
|
|
3
|
-
* following copyright and licenses apply:
|
|
4
|
-
*
|
|
5
|
-
* Copyright 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
|
-
* Lightning 3 Renderer Core API
|
|
21
|
-
*
|
|
22
|
-
* @remarks
|
|
23
|
-
* ```
|
|
24
|
-
* import * from '@lightning/renderer/core';
|
|
25
|
-
* ```
|
|
26
|
-
*
|
|
27
|
-
* The Core API is used by developers to extend the capabilities of the Renderer
|
|
28
|
-
* by writing custom Shaders, Dynamic Shader Effects, Textures, Text Renderers,
|
|
29
|
-
* etc.
|
|
30
|
-
*
|
|
31
|
-
* Custom capabilities as well as fonts can be loaded via Core Extensions.
|
|
32
|
-
*
|
|
33
|
-
* A core extension module is structured like so:
|
|
34
|
-
* ```ts
|
|
35
|
-
* import {
|
|
36
|
-
* CoreExtension,
|
|
37
|
-
* WebTrFontFace,
|
|
38
|
-
* SdfTrFontFace,
|
|
39
|
-
* type Stage
|
|
40
|
-
* } from '@lightning/renderer/core';
|
|
41
|
-
*
|
|
42
|
-
* export default class MyCoreExtension extends CoreExtension {
|
|
43
|
-
* async run(stage: Stage) {
|
|
44
|
-
* stage.fontManager.addFontFace(
|
|
45
|
-
* new WebTrFontFace('Ubuntu', {}, '/fonts/Ubuntu-Regular.ttf'),
|
|
46
|
-
* );
|
|
47
|
-
*
|
|
48
|
-
* stage.fontManager.addFontFace(
|
|
49
|
-
* new SdfTrFontFace(
|
|
50
|
-
* 'Ubuntu',
|
|
51
|
-
* {},
|
|
52
|
-
* 'msdf',
|
|
53
|
-
* stage,
|
|
54
|
-
* '/fonts/Ubuntu-Regular.msdf.png',
|
|
55
|
-
* '/fonts/Ubuntu-Regular.msdf.json',
|
|
56
|
-
* ),
|
|
57
|
-
* );
|
|
58
|
-
* }
|
|
59
|
-
* }
|
|
60
|
-
* ```
|
|
61
|
-
*
|
|
62
|
-
* And then imported and registered in the application's entry point
|
|
63
|
-
* using the `@lightningjs/vite-plugin-import-chunk-url` plugin:
|
|
64
|
-
* ```ts
|
|
65
|
-
* import coreExtensionModuleUrl from './MyCoreExtension.js?importChunkUrl';
|
|
66
|
-
*
|
|
67
|
-
* // Set up driver, etc.
|
|
68
|
-
*
|
|
69
|
-
* // Initialize the Renderer
|
|
70
|
-
* const renderer = new RendererMain(
|
|
71
|
-
* {
|
|
72
|
-
* // Other Renderer Config...
|
|
73
|
-
* coreExtensionModule: coreExtensionModuleUrl,
|
|
74
|
-
* },
|
|
75
|
-
* 'app',
|
|
76
|
-
* driver,
|
|
77
|
-
* );
|
|
78
|
-
* ```
|
|
79
|
-
*
|
|
80
|
-
* @module
|
|
81
|
-
*/
|
|
82
|
-
// Shaders
|
|
83
|
-
export * from '../src/core/renderers/webgl/WebGlCoreShader.js';
|
|
84
|
-
export * from '../src/core/renderers/webgl/shaders/effects/ShaderEffect.js';
|
|
85
|
-
// Textures
|
|
86
|
-
export * from '../src/core/textures/Texture.js';
|
|
87
|
-
// Text Rendering & Fonts
|
|
88
|
-
export * from '../src/core/text-rendering/renderers/TextRenderer.js';
|
|
89
|
-
export * from '../src/core/text-rendering/renderers/CanvasTextRenderer.js';
|
|
90
|
-
export * from '../src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.js';
|
|
91
|
-
export * from '../src/core/text-rendering/font-face-types/TrFontFace.js';
|
|
92
|
-
export * from '../src/core/text-rendering/font-face-types/WebTrFontFace.js';
|
|
93
|
-
export * from '../src/core/text-rendering/font-face-types/SdfTrFontFace/SdfTrFontFace.js';
|
|
94
|
-
// Core Extensions
|
|
95
|
-
export * from '../src/core/CoreExtension.js';
|
|
96
|
-
//# sourceMappingURL=core-api.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"core-api.js","sourceRoot":"","sources":["../../exports/core-api.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;GAiBG;AACH;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA8DG;AAEH,UAAU;AACV,cAAc,gDAAgD,CAAC;AAC/D,cAAc,6DAA6D,CAAC;AAE5E,WAAW;AACX,cAAc,iCAAiC,CAAC;AAEhD,yBAAyB;AACzB,cAAc,sDAAsD,CAAC;AACrE,cAAc,4DAA4D,CAAC;AAC3E,cAAc,yEAAyE,CAAC;AACxF,cAAc,0DAA0D,CAAC;AACzE,cAAc,6DAA6D,CAAC;AAC5E,cAAc,2EAA2E,CAAC;AAE1F,kBAAkB;AAClB,cAAc,8BAA8B,CAAC"}
|
|
@@ -1,30 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Lightning 3 Renderer Main API
|
|
3
|
-
*
|
|
4
|
-
* @remarks
|
|
5
|
-
* This module exports the Main API for the Lightning 3 Renderer. You
|
|
6
|
-
* can import the exports from this module like so:
|
|
7
|
-
* ```ts
|
|
8
|
-
* import { RendererMain } from '@lightning/renderer';
|
|
9
|
-
* ```
|
|
10
|
-
*
|
|
11
|
-
* Generally developers/frameworks using the Renderer will use the Main API to
|
|
12
|
-
* render applications.
|
|
13
|
-
*
|
|
14
|
-
* Do not confuse the Main API with the Core API which is used to extend
|
|
15
|
-
* capabilities of the Renderer. The Main API code always runs from the main
|
|
16
|
-
* thread.
|
|
17
|
-
*
|
|
18
|
-
* @module
|
|
19
|
-
*/
|
|
20
|
-
export * from '../src/main-api/INode.js';
|
|
21
|
-
export * from '../src/main-api/ICoreDriver.js';
|
|
22
|
-
export * from '../src/main-api/RendererMain.js';
|
|
23
|
-
export * from '../src/render-drivers/main/MainCoreDriver.js';
|
|
24
|
-
export * from '../src/render-drivers/threadx/ThreadXCoreDriver.js';
|
|
25
|
-
export * from '../src/common/IAnimationController.js';
|
|
26
|
-
export * from '../src/common/CommonTypes.js';
|
|
27
|
-
export type { TextRendererMap } from '../src/core/text-rendering/renderers/TextRenderer.js';
|
|
28
|
-
export type { TrFontFaceMap } from '../src/core/text-rendering/font-face-types/TrFontFace.js';
|
|
29
|
-
export type { AnimationSettings } from '../src/core/animations/CoreAnimation.js';
|
|
30
|
-
export type { EffectProps, FadeOutEffectProps, LinearGradientEffectProps, RadialGradientEffectProps, GrayscaleEffectProps, GlitchEffectProps, RadialProgressEffectProps, } from '../src/core/CoreShaderManager.js';
|
package/dist/exports/main-api.js
DELETED
|
@@ -1,45 +0,0 @@
|
|
|
1
|
-
/*
|
|
2
|
-
* If not stated otherwise in this file or this component's LICENSE file the
|
|
3
|
-
* following copyright and licenses apply:
|
|
4
|
-
*
|
|
5
|
-
* Copyright 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
|
-
* Lightning 3 Renderer Main API
|
|
21
|
-
*
|
|
22
|
-
* @remarks
|
|
23
|
-
* This module exports the Main API for the Lightning 3 Renderer. You
|
|
24
|
-
* can import the exports from this module like so:
|
|
25
|
-
* ```ts
|
|
26
|
-
* import { RendererMain } from '@lightning/renderer';
|
|
27
|
-
* ```
|
|
28
|
-
*
|
|
29
|
-
* Generally developers/frameworks using the Renderer will use the Main API to
|
|
30
|
-
* render applications.
|
|
31
|
-
*
|
|
32
|
-
* Do not confuse the Main API with the Core API which is used to extend
|
|
33
|
-
* capabilities of the Renderer. The Main API code always runs from the main
|
|
34
|
-
* thread.
|
|
35
|
-
*
|
|
36
|
-
* @module
|
|
37
|
-
*/
|
|
38
|
-
export * from '../src/main-api/INode.js';
|
|
39
|
-
export * from '../src/main-api/ICoreDriver.js';
|
|
40
|
-
export * from '../src/main-api/RendererMain.js';
|
|
41
|
-
export * from '../src/render-drivers/main/MainCoreDriver.js';
|
|
42
|
-
export * from '../src/render-drivers/threadx/ThreadXCoreDriver.js';
|
|
43
|
-
export * from '../src/common/IAnimationController.js';
|
|
44
|
-
export * from '../src/common/CommonTypes.js';
|
|
45
|
-
//# sourceMappingURL=main-api.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"main-api.js","sourceRoot":"","sources":["../../exports/main-api.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;GAiBG;AAEH;;;;;;;;;;;;;;;;;;GAkBG;AACH,cAAc,0BAA0B,CAAC;AACzC,cAAc,gCAAgC,CAAC;AAC/C,cAAc,iCAAiC,CAAC;AAChD,cAAc,8CAA8C,CAAC;AAC7D,cAAc,oDAAoD,CAAC;AACnE,cAAc,uCAAuC,CAAC;AACtD,cAAc,8BAA8B,CAAC"}
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
import type { Stage } from './Stage.js';
|
|
2
|
-
/**
|
|
3
|
-
* Base class for Core extensions.
|
|
4
|
-
*
|
|
5
|
-
* @remarks
|
|
6
|
-
* Core extensions are used to extend the Core Renderer with custom code such as
|
|
7
|
-
* custom fonts, custom shaders, custom textures, custom animation functions,
|
|
8
|
-
* and more.
|
|
9
|
-
*/
|
|
10
|
-
export declare abstract class CoreExtension {
|
|
11
|
-
abstract run(stage: Stage): Promise<void>;
|
|
12
|
-
}
|
|
@@ -1,29 +0,0 @@
|
|
|
1
|
-
/*
|
|
2
|
-
* If not stated otherwise in this file or this component's LICENSE file the
|
|
3
|
-
* following copyright and licenses apply:
|
|
4
|
-
*
|
|
5
|
-
* Copyright 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
|
-
* Base class for Core extensions.
|
|
21
|
-
*
|
|
22
|
-
* @remarks
|
|
23
|
-
* Core extensions are used to extend the Core Renderer with custom code such as
|
|
24
|
-
* custom fonts, custom shaders, custom textures, custom animation functions,
|
|
25
|
-
* and more.
|
|
26
|
-
*/
|
|
27
|
-
export class CoreExtension {
|
|
28
|
-
}
|
|
29
|
-
//# sourceMappingURL=CoreExtension.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"CoreExtension.js","sourceRoot":"","sources":["../../../src/core/CoreExtension.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;GAiBG;AAIH;;;;;;;GAOG;AACH,MAAM,OAAgB,aAAa;CAElC"}
|
|
@@ -1,24 +0,0 @@
|
|
|
1
|
-
import type { FpsUpdatePayload, FrameTickPayload } from '../common/CommonTypes.js';
|
|
2
|
-
import type { INode, INodeWritableProps, ITextNode, ITextNodeWritableProps } from './INode.js';
|
|
3
|
-
import type { RendererMain, RendererMainSettings } from './RendererMain.js';
|
|
4
|
-
/**
|
|
5
|
-
* This interface is to be implemented by Core Drivers
|
|
6
|
-
*
|
|
7
|
-
* @remarks
|
|
8
|
-
* Both the {@link MainCoreDriver} and the {@link ThreadXCoreDriver} exist
|
|
9
|
-
* that implement this interface to support both the single-threaded and
|
|
10
|
-
* multi-threaded Core modes.
|
|
11
|
-
*/
|
|
12
|
-
export interface ICoreDriver {
|
|
13
|
-
init(rendererMain: RendererMain, rendererSettings: Required<RendererMainSettings>, canvas: HTMLCanvasElement): Promise<void>;
|
|
14
|
-
createNode(props: INodeWritableProps): INode;
|
|
15
|
-
createTextNode(props: ITextNodeWritableProps): ITextNode;
|
|
16
|
-
destroyNode(node: INode): void;
|
|
17
|
-
getRootNode(): INode;
|
|
18
|
-
releaseTexture(textureDescId: number): void;
|
|
19
|
-
onCreateNode(node: INode): void;
|
|
20
|
-
onBeforeDestroyNode(node: INode): void;
|
|
21
|
-
onFpsUpdate(fpsData: FpsUpdatePayload): void;
|
|
22
|
-
onFrameTick(frameTickData: FrameTickPayload): void;
|
|
23
|
-
onIdle?(): void;
|
|
24
|
-
}
|
|
@@ -1,20 +0,0 @@
|
|
|
1
|
-
/*
|
|
2
|
-
* If not stated otherwise in this file or this component's LICENSE file the
|
|
3
|
-
* following copyright and licenses apply:
|
|
4
|
-
*
|
|
5
|
-
* Copyright 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=ICoreDriver.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"ICoreDriver.js","sourceRoot":"","sources":["../../../src/main-api/ICoreDriver.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;GAiBG"}
|