@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.
Files changed (133) hide show
  1. package/dist/src/core/CoreNode.d.ts +27 -1
  2. package/dist/src/core/CoreNode.js +130 -5
  3. package/dist/src/core/CoreNode.js.map +1 -1
  4. package/dist/src/core/CoreShaderManager.js +3 -2
  5. package/dist/src/core/CoreShaderManager.js.map +1 -1
  6. package/dist/src/core/CoreTextNode.js +20 -1
  7. package/dist/src/core/CoreTextNode.js.map +1 -1
  8. package/dist/src/core/CoreTextureManager.d.ts +2 -0
  9. package/dist/src/core/CoreTextureManager.js +2 -0
  10. package/dist/src/core/CoreTextureManager.js.map +1 -1
  11. package/dist/src/core/Stage.js +25 -9
  12. package/dist/src/core/Stage.js.map +1 -1
  13. package/dist/src/core/TextureMemoryManager.d.ts +1 -0
  14. package/dist/src/core/TextureMemoryManager.js +3 -1
  15. package/dist/src/core/TextureMemoryManager.js.map +1 -1
  16. package/dist/src/core/lib/ImageWorker.d.ts +2 -1
  17. package/dist/src/core/lib/ImageWorker.js +10 -6
  18. package/dist/src/core/lib/ImageWorker.js.map +1 -1
  19. package/dist/src/core/lib/WebGlContextWrapper.d.ts +26 -1
  20. package/dist/src/core/lib/WebGlContextWrapper.js +37 -1
  21. package/dist/src/core/lib/WebGlContextWrapper.js.map +1 -1
  22. package/dist/src/core/renderers/CoreRenderer.d.ts +11 -0
  23. package/dist/src/core/renderers/CoreRenderer.js +1 -0
  24. package/dist/src/core/renderers/CoreRenderer.js.map +1 -1
  25. package/dist/src/core/renderers/canvas/CanvasCoreRenderer.d.ts +10 -4
  26. package/dist/src/core/renderers/canvas/CanvasCoreRenderer.js +18 -7
  27. package/dist/src/core/renderers/canvas/CanvasCoreRenderer.js.map +1 -1
  28. package/dist/src/core/renderers/canvas/CanvasCoreTexture.d.ts +2 -2
  29. package/dist/src/core/renderers/canvas/CanvasCoreTexture.js +8 -6
  30. package/dist/src/core/renderers/canvas/CanvasCoreTexture.js.map +1 -1
  31. package/dist/src/core/renderers/canvas/internal/C2DShaderUtils.d.ts +1 -1
  32. package/dist/src/core/renderers/canvas/internal/C2DShaderUtils.js +1 -1
  33. package/dist/src/core/renderers/canvas/internal/C2DShaderUtils.js.map +1 -1
  34. package/dist/src/core/renderers/canvas/internal/ColorUtils.js +4 -4
  35. package/dist/src/core/renderers/canvas/internal/ColorUtils.js.map +1 -1
  36. package/dist/src/core/renderers/canvas/shaders/UnsupportedShader.d.ts +1 -1
  37. package/dist/src/core/renderers/canvas/shaders/UnsupportedShader.js +2 -2
  38. package/dist/src/core/renderers/canvas/shaders/UnsupportedShader.js.map +1 -1
  39. package/dist/src/core/renderers/webgl/WebGlCoreCtxRenderTexture.d.ts +11 -0
  40. package/dist/src/core/renderers/webgl/WebGlCoreCtxRenderTexture.js +51 -0
  41. package/dist/src/core/renderers/webgl/WebGlCoreCtxRenderTexture.js.map +1 -0
  42. package/dist/src/core/renderers/webgl/WebGlCoreCtxTexture.d.ts +11 -1
  43. package/dist/src/core/renderers/webgl/WebGlCoreCtxTexture.js +22 -11
  44. package/dist/src/core/renderers/webgl/WebGlCoreCtxTexture.js.map +1 -1
  45. package/dist/src/core/renderers/webgl/WebGlCoreRenderOp.d.ts +4 -1
  46. package/dist/src/core/renderers/webgl/WebGlCoreRenderOp.js +7 -2
  47. package/dist/src/core/renderers/webgl/WebGlCoreRenderOp.js.map +1 -1
  48. package/dist/src/core/renderers/webgl/WebGlCoreRenderer.d.ts +16 -1
  49. package/dist/src/core/renderers/webgl/WebGlCoreRenderer.js +119 -27
  50. package/dist/src/core/renderers/webgl/WebGlCoreRenderer.js.map +1 -1
  51. package/dist/src/core/renderers/webgl/WebGlCoreShader.js +19 -4
  52. package/dist/src/core/renderers/webgl/WebGlCoreShader.js.map +1 -1
  53. package/dist/src/core/renderers/webgl/shaders/DefaultShader.js +4 -6
  54. package/dist/src/core/renderers/webgl/shaders/DefaultShader.js.map +1 -1
  55. package/dist/src/core/renderers/webgl/shaders/SdfShader.js +6 -1
  56. package/dist/src/core/renderers/webgl/shaders/SdfShader.js.map +1 -1
  57. package/dist/src/core/text-rendering/TextRenderingUtils.d.ts +12 -0
  58. package/dist/src/core/text-rendering/TextRenderingUtils.js +14 -0
  59. package/dist/src/core/text-rendering/TextRenderingUtils.js.map +1 -0
  60. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.d.ts +2 -1
  61. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.js +4 -3
  62. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.js.map +1 -1
  63. package/dist/src/core/text-rendering/renderers/TextRenderer.d.ts +2 -1
  64. package/dist/src/core/text-rendering/renderers/TextRenderer.js.map +1 -1
  65. package/dist/src/core/textures/RenderTexture.d.ts +28 -0
  66. package/dist/src/core/textures/RenderTexture.js +52 -0
  67. package/dist/src/core/textures/RenderTexture.js.map +1 -0
  68. package/dist/src/core/utils.d.ts +6 -1
  69. package/dist/src/core/utils.js +74 -82
  70. package/dist/src/core/utils.js.map +1 -1
  71. package/dist/src/main-api/INode.d.ts +9 -0
  72. package/dist/src/main-api/RendererMain.js +2 -1
  73. package/dist/src/main-api/RendererMain.js.map +1 -1
  74. package/dist/src/render-drivers/main/MainOnlyNode.d.ts +3 -0
  75. package/dist/src/render-drivers/main/MainOnlyNode.js +29 -0
  76. package/dist/src/render-drivers/main/MainOnlyNode.js.map +1 -1
  77. package/dist/src/render-drivers/main/MainOnlyTextNode.js +1 -0
  78. package/dist/src/render-drivers/main/MainOnlyTextNode.js.map +1 -1
  79. package/dist/src/render-drivers/threadx/NodeStruct.d.ts +3 -0
  80. package/dist/src/render-drivers/threadx/NodeStruct.js +9 -0
  81. package/dist/src/render-drivers/threadx/NodeStruct.js.map +1 -1
  82. package/dist/src/render-drivers/threadx/SharedNode.d.ts +1 -0
  83. package/dist/src/render-drivers/threadx/SharedNode.js +1 -0
  84. package/dist/src/render-drivers/threadx/SharedNode.js.map +1 -1
  85. package/dist/src/render-drivers/threadx/ThreadXCoreDriver.js +2 -0
  86. package/dist/src/render-drivers/threadx/ThreadXCoreDriver.js.map +1 -1
  87. package/dist/src/render-drivers/threadx/ThreadXMainNode.d.ts +3 -0
  88. package/dist/src/render-drivers/threadx/ThreadXMainNode.js +7 -0
  89. package/dist/src/render-drivers/threadx/ThreadXMainNode.js.map +1 -1
  90. package/dist/src/render-drivers/threadx/worker/ThreadXRendererNode.js +1 -0
  91. package/dist/src/render-drivers/threadx/worker/ThreadXRendererNode.js.map +1 -1
  92. package/dist/src/render-drivers/threadx/worker/ThreadXRendererTextNode.js +1 -0
  93. package/dist/src/render-drivers/threadx/worker/ThreadXRendererTextNode.js.map +1 -1
  94. package/dist/src/render-drivers/threadx/worker/renderer.js +1 -0
  95. package/dist/src/render-drivers/threadx/worker/renderer.js.map +1 -1
  96. package/dist/tsconfig.dist.tsbuildinfo +1 -1
  97. package/package.json +1 -1
  98. package/src/core/CoreNode.ts +164 -8
  99. package/src/core/CoreShaderManager.ts +6 -3
  100. package/src/core/CoreTextNode.ts +25 -0
  101. package/src/core/CoreTextureManager.ts +3 -0
  102. package/src/core/Stage.ts +32 -11
  103. package/src/core/TextureMemoryManager.ts +3 -1
  104. package/src/core/lib/ImageWorker.ts +12 -7
  105. package/src/core/lib/WebGlContextWrapper.ts +51 -1
  106. package/src/core/renderers/CoreRenderer.ts +15 -1
  107. package/src/core/renderers/canvas/CanvasCoreRenderer.ts +59 -14
  108. package/src/core/renderers/canvas/CanvasCoreTexture.ts +24 -18
  109. package/src/core/renderers/canvas/internal/C2DShaderUtils.ts +6 -3
  110. package/src/core/renderers/canvas/internal/ColorUtils.ts +6 -6
  111. package/src/core/renderers/canvas/shaders/UnsupportedShader.ts +2 -3
  112. package/src/core/renderers/webgl/WebGlCoreCtxRenderTexture.ts +79 -0
  113. package/src/core/renderers/webgl/WebGlCoreCtxTexture.ts +26 -24
  114. package/src/core/renderers/webgl/WebGlCoreRenderOp.ts +4 -2
  115. package/src/core/renderers/webgl/WebGlCoreRenderer.ts +166 -33
  116. package/src/core/renderers/webgl/WebGlCoreShader.ts +29 -4
  117. package/src/core/renderers/webgl/shaders/DefaultShader.ts +4 -6
  118. package/src/core/renderers/webgl/shaders/SdfShader.ts +6 -1
  119. package/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.ts +8 -1
  120. package/src/core/text-rendering/renderers/TextRenderer.ts +3 -0
  121. package/src/core/textures/RenderTexture.ts +81 -0
  122. package/src/core/utils.ts +101 -93
  123. package/src/main-api/INode.ts +11 -0
  124. package/src/main-api/RendererMain.ts +2 -1
  125. package/src/render-drivers/main/MainOnlyNode.ts +44 -0
  126. package/src/render-drivers/main/MainOnlyTextNode.ts +1 -0
  127. package/src/render-drivers/threadx/NodeStruct.ts +10 -0
  128. package/src/render-drivers/threadx/SharedNode.ts +2 -0
  129. package/src/render-drivers/threadx/ThreadXCoreDriver.ts +2 -0
  130. package/src/render-drivers/threadx/ThreadXMainNode.ts +9 -0
  131. package/src/render-drivers/threadx/worker/ThreadXRendererNode.ts +1 -0
  132. package/src/render-drivers/threadx/worker/ThreadXRendererTextNode.ts +1 -0
  133. 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
- export const getTimingFunction = memo(
125
- (str: string): ((time: number) => number | undefined) => {
126
- switch (str) {
127
- case 'linear':
128
- return function (time: number) {
129
- return time;
130
- };
131
- case 'ease':
132
- return getTimingBezier(0.25, 0.1, 0.25, 1.0);
133
-
134
- case 'ease-in':
135
- return getTimingBezier(0.42, 0, 1.0, 1.0);
136
- case 'ease-out':
137
- return getTimingBezier(0, 0, 0.58, 1.0);
138
- case 'ease-in-out':
139
- return getTimingBezier(0.42, 0, 0.58, 1.0);
140
-
141
- case 'ease-in-sine':
142
- return getTimingBezier(0.12, 0, 0.39, 0);
143
- case 'ease-out-sine':
144
- return getTimingBezier(0.12, 0, 0.39, 0);
145
- case 'ease-in-out-sine':
146
- return getTimingBezier(0.37, 0, 0.63, 1);
147
-
148
- case 'ease-in-cubic':
149
- return getTimingBezier(0.32, 0, 0.67, 0);
150
- case 'ease-out-cubic':
151
- return getTimingBezier(0.33, 1, 0.68, 1);
152
- case 'ease-in-out-cubic':
153
- return getTimingBezier(0.65, 0, 0.35, 1);
154
-
155
- case 'ease-in-circ':
156
- return getTimingBezier(0.55, 0, 1, 0.45);
157
- case 'ease-out-circ':
158
- return getTimingBezier(0, 0.55, 0.45, 1);
159
- case 'ease-in-out-circ':
160
- return getTimingBezier(0.85, 0, 0.15, 1);
161
-
162
- case 'ease-in-back':
163
- return getTimingBezier(0.36, 0, 0.66, -0.56);
164
- case 'ease-out-back':
165
- return getTimingBezier(0.34, 1.56, 0.64, 1);
166
- case 'ease-in-out-back':
167
- return getTimingBezier(0.68, -0.6, 0.32, 1.6);
168
-
169
- case 'step-start':
170
- return function () {
171
- return 1;
172
- };
173
- case 'step-end':
174
- return function (time: number) {
175
- return time === 1 ? 1 : 0;
176
- };
177
- default:
178
- // eslint-disable-next-line no-case-declarations
179
- const s = 'cubic-bezier(';
180
- if (str && str.indexOf(s) === 0) {
181
- const parts = str
182
- .substr(s.length, str.length - s.length - 1)
183
- .split(',');
184
- if (parts.length !== 4) {
185
- console.warn('Unknown timing function: ' + str);
186
- // Fallback: use linear.
187
- return function (time) {
188
- return time;
189
- };
190
- }
191
- const a = parseFloat(parts[0] || '0.42');
192
- const b = parseFloat(parts[1] || '0');
193
- const c = parseFloat(parts[2] || '1');
194
- const d = parseFloat(parts[3] || '1');
195
-
196
- if (isNaN(a) || isNaN(b) || isNaN(c) || isNaN(d)) {
197
- console.warn(' Unknown timing function: ' + str);
198
- // Fallback: use linear.
199
- return function (time) {
200
- return time;
201
- };
202
- }
203
-
204
- return getTimingBezier(a, b, c, d);
205
- } else {
206
- console.warn('Unknown timing function: ' + str);
207
- // Fallback: use linear.
208
- return function (time) {
209
- return time;
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[]) => {
@@ -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
  };
@@ -94,6 +94,7 @@ export class MainOnlyTextNode extends MainOnlyNode implements ITextNode {
94
94
  textureOptions: null,
95
95
  shader: null,
96
96
  shaderProps: null,
97
+ rtt: false,
97
98
  }),
98
99
  );
99
100
  }
@@ -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.