@lightningjs/renderer 0.8.3 → 0.8.4
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/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/renderers/SdfTextRenderer/SdfTextRenderer.d.ts +2 -1
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.js +4 -3
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.js.map +1 -1
- package/dist/src/core/text-rendering/renderers/TextRenderer.d.ts +2 -1
- 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 +2 -1
- 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 +1 -0
- 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/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 +1 -1
- 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/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/renderers/SdfTextRenderer/SdfTextRenderer.ts +8 -1
- package/src/core/text-rendering/renderers/TextRenderer.ts +3 -0
- 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 +2 -1
- package/src/render-drivers/main/MainOnlyNode.ts +44 -0
- package/src/render-drivers/main/MainOnlyTextNode.ts +1 -0
- package/src/render-drivers/threadx/NodeStruct.ts +10 -0
- package/src/render-drivers/threadx/SharedNode.ts +2 -0
- 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
package/src/core/utils.ts
CHANGED
|
@@ -23,8 +23,6 @@
|
|
|
23
23
|
* @module
|
|
24
24
|
*/
|
|
25
25
|
|
|
26
|
-
import memo from 'memize';
|
|
27
|
-
|
|
28
26
|
export const EPSILON = 0.000001;
|
|
29
27
|
export let ARRAY_TYPE =
|
|
30
28
|
typeof Float32Array !== 'undefined' ? Float32Array : Array;
|
|
@@ -121,97 +119,107 @@ const getTimingBezier = (
|
|
|
121
119
|
};
|
|
122
120
|
};
|
|
123
121
|
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
122
|
+
interface TimingFunctionMap {
|
|
123
|
+
[key: string]: (time: number) => number | undefined;
|
|
124
|
+
}
|
|
125
|
+
|
|
126
|
+
type TimingLookupArray = number[];
|
|
127
|
+
interface TimingLookup {
|
|
128
|
+
[key: string]: TimingLookupArray;
|
|
129
|
+
}
|
|
130
|
+
|
|
131
|
+
const timingMapping: TimingFunctionMap = {};
|
|
132
|
+
|
|
133
|
+
const timingLookup: TimingLookup = {
|
|
134
|
+
ease: [0.25, 0.1, 0.25, 1.0],
|
|
135
|
+
'ease-in': [0.42, 0, 1.0, 1.0],
|
|
136
|
+
'ease-out': [0, 0, 0.58, 1.0],
|
|
137
|
+
'ease-in-out': [0.42, 0, 0.58, 1.0],
|
|
138
|
+
'ease-in-sine': [0.12, 0, 0.39, 0],
|
|
139
|
+
'ease-out-sine': [0.12, 0, 0.39, 0],
|
|
140
|
+
'ease-in-out-sine': [0.37, 0, 0.63, 1],
|
|
141
|
+
'ease-in-cubic': [0.32, 0, 0.67, 0],
|
|
142
|
+
'ease-out-cubic': [0.33, 1, 0.68, 1],
|
|
143
|
+
'ease-in-out-cubic': [0.65, 0, 0.35, 1],
|
|
144
|
+
'ease-in-circ': [0.55, 0, 1, 0.45],
|
|
145
|
+
'ease-out-circ': [0, 0.55, 0.45, 1],
|
|
146
|
+
'ease-in-out-circ': [0.85, 0, 0.15, 1],
|
|
147
|
+
'ease-in-back': [0.36, 0, 0.66, -0.56],
|
|
148
|
+
'ease-out-back': [0.34, 1.56, 0.64, 1],
|
|
149
|
+
'ease-in-out-back': [0.68, -0.6, 0.32, 1.6],
|
|
150
|
+
};
|
|
151
|
+
|
|
152
|
+
const defaultTiming = (t: number): number => t;
|
|
153
|
+
|
|
154
|
+
const parseCubicBezier = (str: string) => {
|
|
155
|
+
//cubic-bezier(0.84, 0.52, 0.56, 0.6)
|
|
156
|
+
const regex = /-?\d*\.?\d+/g;
|
|
157
|
+
const match = str.match(regex);
|
|
158
|
+
|
|
159
|
+
if (match) {
|
|
160
|
+
const [num1, num2, num3, num4] = match;
|
|
161
|
+
const a = parseFloat(num1 || '0.42');
|
|
162
|
+
const b = parseFloat(num2 || '0');
|
|
163
|
+
const c = parseFloat(num3 || '1');
|
|
164
|
+
const d = parseFloat(num4 || '1');
|
|
165
|
+
|
|
166
|
+
const timing = getTimingBezier(a, b, c, d);
|
|
167
|
+
timingMapping[str] = timing;
|
|
168
|
+
|
|
169
|
+
return timing;
|
|
170
|
+
}
|
|
171
|
+
|
|
172
|
+
// parse failed, return linear
|
|
173
|
+
console.warn('Unknown cubic-bezier timing: ' + str);
|
|
174
|
+
return defaultTiming;
|
|
175
|
+
};
|
|
176
|
+
|
|
177
|
+
export const getTimingFunction = (
|
|
178
|
+
str: string,
|
|
179
|
+
): ((time: number) => number | undefined) => {
|
|
180
|
+
if (str === '') {
|
|
181
|
+
return defaultTiming;
|
|
182
|
+
}
|
|
183
|
+
|
|
184
|
+
if (timingMapping[str] !== undefined) {
|
|
185
|
+
return timingMapping[str] || defaultTiming;
|
|
186
|
+
}
|
|
187
|
+
|
|
188
|
+
if (str === 'linear') {
|
|
189
|
+
return (time: number) => {
|
|
190
|
+
return time;
|
|
191
|
+
};
|
|
192
|
+
}
|
|
193
|
+
|
|
194
|
+
if (str === 'step-start') {
|
|
195
|
+
return () => {
|
|
196
|
+
return 1;
|
|
197
|
+
};
|
|
198
|
+
}
|
|
199
|
+
|
|
200
|
+
if (str === 'step-end') {
|
|
201
|
+
return (time: number) => {
|
|
202
|
+
return time === 1 ? 1 : 0;
|
|
203
|
+
};
|
|
204
|
+
}
|
|
205
|
+
|
|
206
|
+
if (timingLookup[str] !== undefined) {
|
|
207
|
+
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
|
|
208
|
+
// @ts-ignore - TS doesn't understand that we've checked for undefined
|
|
209
|
+
const [a, b, c, d] = timingLookup[str];
|
|
210
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-argument
|
|
211
|
+
const timing = getTimingBezier(a, b, c, d);
|
|
212
|
+
timingMapping[str] = timing;
|
|
213
|
+
return timing;
|
|
214
|
+
}
|
|
215
|
+
|
|
216
|
+
if (str.startsWith('cubic-bezier')) {
|
|
217
|
+
return parseCubicBezier(str);
|
|
218
|
+
}
|
|
219
|
+
|
|
220
|
+
console.warn('Unknown timing function: ' + str);
|
|
221
|
+
return defaultTiming;
|
|
222
|
+
};
|
|
215
223
|
|
|
216
224
|
if (!Math.hypot)
|
|
217
225
|
Math.hypot = (...args: number[]) => {
|
package/src/main-api/INode.ts
CHANGED
|
@@ -405,6 +405,17 @@ export interface INodeWritableProps {
|
|
|
405
405
|
* - `2 * Math.PI`: 360 rotation clockwise
|
|
406
406
|
*/
|
|
407
407
|
rotation: number;
|
|
408
|
+
|
|
409
|
+
/**
|
|
410
|
+
* Whether the Node is rendered to a texture
|
|
411
|
+
*
|
|
412
|
+
* @remarks
|
|
413
|
+
* TBD
|
|
414
|
+
*
|
|
415
|
+
* @default false
|
|
416
|
+
*/
|
|
417
|
+
rtt: boolean;
|
|
418
|
+
|
|
408
419
|
/**
|
|
409
420
|
* Node data element for custom data storage (optional)
|
|
410
421
|
*
|
|
@@ -350,7 +350,7 @@ export class RendererMain extends EventEmitter {
|
|
|
350
350
|
settings.numImageWorkers !== undefined ? settings.numImageWorkers : 2,
|
|
351
351
|
enableContextSpy: settings.enableContextSpy ?? false,
|
|
352
352
|
enableInspector: settings.enableInspector ?? false,
|
|
353
|
-
renderMode: settings.renderMode ?? 'webgl'
|
|
353
|
+
renderMode: settings.renderMode ?? 'webgl',
|
|
354
354
|
};
|
|
355
355
|
this.settings = resolvedSettings;
|
|
356
356
|
|
|
@@ -570,6 +570,7 @@ export class RendererMain extends EventEmitter {
|
|
|
570
570
|
pivotX: props.pivotX ?? props.pivot ?? 0.5,
|
|
571
571
|
pivotY: props.pivotY ?? props.pivot ?? 0.5,
|
|
572
572
|
rotation: props.rotation ?? 0,
|
|
573
|
+
rtt: props.rtt ?? false,
|
|
573
574
|
data: data,
|
|
574
575
|
};
|
|
575
576
|
}
|
|
@@ -105,6 +105,7 @@ export class MainOnlyNode extends EventEmitter implements INode {
|
|
|
105
105
|
shaderProps: null,
|
|
106
106
|
texture: null,
|
|
107
107
|
textureOptions: null,
|
|
108
|
+
rtt: props.rtt,
|
|
108
109
|
});
|
|
109
110
|
// Forward loaded/failed events
|
|
110
111
|
this.coreNode.on('loaded', this.onTextureLoaded);
|
|
@@ -121,6 +122,7 @@ export class MainOnlyNode extends EventEmitter implements INode {
|
|
|
121
122
|
this.shader = props.shader;
|
|
122
123
|
this.texture = props.texture;
|
|
123
124
|
this.src = props.src;
|
|
125
|
+
this.rtt = props.rtt;
|
|
124
126
|
this._data = props.data;
|
|
125
127
|
}
|
|
126
128
|
|
|
@@ -145,6 +147,16 @@ export class MainOnlyNode extends EventEmitter implements INode {
|
|
|
145
147
|
}
|
|
146
148
|
|
|
147
149
|
set width(value: number) {
|
|
150
|
+
if (value !== this.coreNode.width && this.coreNode.rtt) {
|
|
151
|
+
this.texture = this.rendererMain.createTexture(
|
|
152
|
+
'RenderTexture',
|
|
153
|
+
{
|
|
154
|
+
width: this.width,
|
|
155
|
+
height: this.height,
|
|
156
|
+
},
|
|
157
|
+
{ preload: true, flipY: true },
|
|
158
|
+
);
|
|
159
|
+
}
|
|
148
160
|
this.coreNode.width = value;
|
|
149
161
|
}
|
|
150
162
|
|
|
@@ -153,6 +165,16 @@ export class MainOnlyNode extends EventEmitter implements INode {
|
|
|
153
165
|
}
|
|
154
166
|
|
|
155
167
|
set height(value: number) {
|
|
168
|
+
if (value !== this.coreNode.height && this.coreNode.rtt) {
|
|
169
|
+
this.texture = this.rendererMain.createTexture(
|
|
170
|
+
'RenderTexture',
|
|
171
|
+
{
|
|
172
|
+
width: this.width,
|
|
173
|
+
height: this.height,
|
|
174
|
+
},
|
|
175
|
+
{ preload: true, flipY: true },
|
|
176
|
+
);
|
|
177
|
+
}
|
|
156
178
|
this.coreNode.height = value;
|
|
157
179
|
}
|
|
158
180
|
|
|
@@ -422,6 +444,28 @@ export class MainOnlyNode extends EventEmitter implements INode {
|
|
|
422
444
|
}
|
|
423
445
|
}
|
|
424
446
|
|
|
447
|
+
get rtt(): boolean {
|
|
448
|
+
return this.coreNode.rtt;
|
|
449
|
+
}
|
|
450
|
+
|
|
451
|
+
set rtt(value: boolean) {
|
|
452
|
+
if (value) {
|
|
453
|
+
this.texture = this.rendererMain.createTexture(
|
|
454
|
+
'RenderTexture',
|
|
455
|
+
{
|
|
456
|
+
width: this.width,
|
|
457
|
+
height: this.height,
|
|
458
|
+
},
|
|
459
|
+
{ preload: true, flipY: true },
|
|
460
|
+
);
|
|
461
|
+
}
|
|
462
|
+
this.coreNode.rtt = value;
|
|
463
|
+
}
|
|
464
|
+
|
|
465
|
+
get parentHasRenderTexture(): boolean {
|
|
466
|
+
return this.coreNode.parentHasRenderTexture;
|
|
467
|
+
}
|
|
468
|
+
|
|
425
469
|
private onTextureLoaded: NodeLoadedEventHandler = (target, payload) => {
|
|
426
470
|
this.emit('loaded', payload);
|
|
427
471
|
};
|
|
@@ -48,6 +48,7 @@ export interface NodeStructWritableProps {
|
|
|
48
48
|
pivotX: number;
|
|
49
49
|
pivotY: number;
|
|
50
50
|
rotation: number;
|
|
51
|
+
rtt: boolean;
|
|
51
52
|
}
|
|
52
53
|
|
|
53
54
|
export class NodeStruct
|
|
@@ -307,4 +308,13 @@ export class NodeStruct
|
|
|
307
308
|
set zIndexLocked(value: number) {
|
|
308
309
|
// Decorator will handle this
|
|
309
310
|
}
|
|
311
|
+
|
|
312
|
+
@structProp('boolean')
|
|
313
|
+
get rtt(): boolean {
|
|
314
|
+
return false;
|
|
315
|
+
}
|
|
316
|
+
|
|
317
|
+
set rtt(value: boolean) {
|
|
318
|
+
// Decorator will handle this
|
|
319
|
+
}
|
|
310
320
|
}
|
|
@@ -63,6 +63,7 @@ export class SharedNode extends SharedObject {
|
|
|
63
63
|
pivotX: sharedNodeStruct.pivotX,
|
|
64
64
|
pivotY: sharedNodeStruct.pivotY,
|
|
65
65
|
rotation: sharedNodeStruct.rotation,
|
|
66
|
+
rtt: sharedNodeStruct.rtt,
|
|
66
67
|
} satisfies NodeStructWritableProps);
|
|
67
68
|
}
|
|
68
69
|
|
|
@@ -96,4 +97,5 @@ export class SharedNode extends SharedObject {
|
|
|
96
97
|
protected declare parentId: number;
|
|
97
98
|
declare zIndex: number;
|
|
98
99
|
declare zIndexLocked: number;
|
|
100
|
+
declare rtt: boolean;
|
|
99
101
|
}
|
|
@@ -174,6 +174,7 @@ export class ThreadXCoreDriver implements ICoreDriver {
|
|
|
174
174
|
pivotX: props.pivotX,
|
|
175
175
|
pivotY: props.pivotY,
|
|
176
176
|
rotation: props.rotation,
|
|
177
|
+
rtt: props.rtt,
|
|
177
178
|
} satisfies NodeStructWritableProps);
|
|
178
179
|
|
|
179
180
|
const node = new ThreadXMainNode(rendererMain, bufferStruct);
|
|
@@ -221,6 +222,7 @@ export class ThreadXCoreDriver implements ICoreDriver {
|
|
|
221
222
|
pivotX: props.pivotX,
|
|
222
223
|
pivotY: props.pivotY,
|
|
223
224
|
rotation: props.rotation,
|
|
225
|
+
rtt: props.rtt,
|
|
224
226
|
|
|
225
227
|
// Text specific properties
|
|
226
228
|
text: props.text,
|
|
@@ -43,6 +43,7 @@ export class ThreadXMainNode extends SharedNode implements INode {
|
|
|
43
43
|
protected _shader: ShaderRef | null = null;
|
|
44
44
|
protected _data: CustomDataMap | undefined = {};
|
|
45
45
|
private _src = '';
|
|
46
|
+
private _parentHasRenderTexture = false;
|
|
46
47
|
|
|
47
48
|
/**
|
|
48
49
|
* FinalizationRegistry for animation controllers. When an animation
|
|
@@ -168,6 +169,14 @@ export class ThreadXMainNode extends SharedNode implements INode {
|
|
|
168
169
|
}
|
|
169
170
|
}
|
|
170
171
|
|
|
172
|
+
set parentHasRenderTexture(hasRenderTexture: boolean) {
|
|
173
|
+
this._parentHasRenderTexture = hasRenderTexture;
|
|
174
|
+
}
|
|
175
|
+
|
|
176
|
+
get parentHasRenderTexture(): boolean {
|
|
177
|
+
return this._parentHasRenderTexture;
|
|
178
|
+
}
|
|
179
|
+
|
|
171
180
|
get children(): ThreadXMainNode[] {
|
|
172
181
|
return this._children;
|
|
173
182
|
}
|
|
@@ -231,6 +231,7 @@ export class ThreadXRendererNode extends SharedNode {
|
|
|
231
231
|
pivotX: sharedNodeStruct.pivotX,
|
|
232
232
|
pivotY: sharedNodeStruct.pivotY,
|
|
233
233
|
rotation: sharedNodeStruct.rotation,
|
|
234
|
+
rtt: sharedNodeStruct.rtt,
|
|
234
235
|
|
|
235
236
|
// These are passed in via message handlers
|
|
236
237
|
shader: null,
|
|
@@ -68,6 +68,7 @@ export class ThreadXRendererTextNode extends ThreadXRendererNode {
|
|
|
68
68
|
scaleX: sharedNodeStruct.scaleX,
|
|
69
69
|
scaleY: sharedNodeStruct.scaleY,
|
|
70
70
|
rotation: sharedNodeStruct.rotation,
|
|
71
|
+
rtt: sharedNodeStruct.rtt,
|
|
71
72
|
|
|
72
73
|
// These are passed in via message handlers
|
|
73
74
|
shader: null,
|
|
@@ -114,6 +114,7 @@ const threadx = ThreadX.init({
|
|
|
114
114
|
pivotX: coreRootNode.pivotX,
|
|
115
115
|
pivotY: coreRootNode.pivotY,
|
|
116
116
|
rotation: coreRootNode.rotation,
|
|
117
|
+
rtt: coreRootNode.rtt,
|
|
117
118
|
} satisfies NodeStructWritableProps);
|
|
118
119
|
|
|
119
120
|
// Share the root node that was created by the Stage with the main worker.
|