@lightningjs/renderer 2.6.2 → 2.7.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (215) hide show
  1. package/dist/src/core/CoreNode.d.ts +6 -1
  2. package/dist/src/core/CoreNode.js +109 -64
  3. package/dist/src/core/CoreNode.js.map +1 -1
  4. package/dist/src/core/lib/WebGlContextWrapper.d.ts +1 -1
  5. package/dist/src/core/renderers/canvas/CanvasCoreRenderer.js +40 -3
  6. package/dist/src/core/renderers/canvas/CanvasCoreRenderer.js.map +1 -1
  7. package/dist/src/core/renderers/canvas/internal/C2DShaderUtils.d.ts +9 -1
  8. package/dist/src/core/renderers/canvas/internal/C2DShaderUtils.js +68 -0
  9. package/dist/src/core/renderers/canvas/internal/C2DShaderUtils.js.map +1 -1
  10. package/dist/src/core/renderers/canvas/internal/ColorUtils.d.ts +4 -0
  11. package/dist/src/core/renderers/canvas/internal/ColorUtils.js +13 -0
  12. package/dist/src/core/renderers/canvas/internal/ColorUtils.js.map +1 -1
  13. package/dist/src/core/renderers/canvas/shaders/UnsupportedShader.js +3 -3
  14. package/dist/src/core/renderers/canvas/shaders/UnsupportedShader.js.map +1 -1
  15. package/dist/src/core/renderers/webgl/WebGlCoreCtxSubTexture.js +4 -0
  16. package/dist/src/core/renderers/webgl/WebGlCoreCtxSubTexture.js.map +1 -1
  17. package/dist/src/core/renderers/webgl/WebGlCoreCtxTexture.js +9 -0
  18. package/dist/src/core/renderers/webgl/WebGlCoreCtxTexture.js.map +1 -1
  19. package/dist/src/core/renderers/webgl/WebGlCoreRenderer.d.ts +23 -0
  20. package/dist/src/core/renderers/webgl/WebGlCoreRenderer.js +65 -9
  21. package/dist/src/core/renderers/webgl/WebGlCoreRenderer.js.map +1 -1
  22. package/dist/src/core/renderers/webgl/WebGlCoreShader.js +2 -2
  23. package/dist/src/core/renderers/webgl/WebGlCoreShader.js.map +1 -1
  24. package/dist/src/core/renderers/webgl/internal/ShaderUtils.js +4 -4
  25. package/dist/src/core/renderers/webgl/internal/ShaderUtils.js.map +1 -1
  26. package/dist/src/core/renderers/webgl/shaders/effects/RadiusEffect.js +18 -0
  27. package/dist/src/core/renderers/webgl/shaders/effects/RadiusEffect.js.map +1 -1
  28. package/dist/src/core/renderers/webgl/shaders/effects/ShaderEffect.js.map +1 -1
  29. package/dist/src/core/textures/ColorTexture.js +14 -3
  30. package/dist/src/core/textures/ColorTexture.js.map +1 -1
  31. package/dist/src/core/textures/Texture.d.ts +1 -1
  32. package/dist/src/core/textures/Texture.js.map +1 -1
  33. package/dist/src/main-api/Inspector.d.ts +1 -1
  34. package/dist/src/main-api/Inspector.js +23 -8
  35. package/dist/src/main-api/Inspector.js.map +1 -1
  36. package/dist/tsconfig.dist.tsbuildinfo +1 -1
  37. package/package.json +1 -2
  38. package/src/core/CoreNode.ts +125 -73
  39. package/src/core/lib/WebGlContextWrapper.ts +1 -1
  40. package/src/core/renderers/canvas/CanvasCoreRenderer.ts +91 -2
  41. package/src/core/renderers/canvas/internal/C2DShaderUtils.ts +102 -1
  42. package/src/core/renderers/canvas/internal/ColorUtils.ts +14 -0
  43. package/src/core/renderers/canvas/shaders/UnsupportedShader.ts +3 -3
  44. package/src/core/renderers/webgl/WebGlCoreCtxSubTexture.ts +6 -0
  45. package/src/core/renderers/webgl/WebGlCoreCtxTexture.ts +27 -1
  46. package/src/core/renderers/webgl/WebGlCoreRenderer.ts +78 -9
  47. package/src/core/renderers/webgl/WebGlCoreShader.ts +4 -2
  48. package/src/core/renderers/webgl/internal/ShaderUtils.ts +5 -4
  49. package/src/core/renderers/webgl/shaders/effects/RadiusEffect.ts +0 -2
  50. package/src/core/renderers/webgl/shaders/effects/ShaderEffect.ts +0 -1
  51. package/src/core/textures/ColorTexture.ts +15 -3
  52. package/src/core/textures/Texture.ts +1 -0
  53. package/src/main-api/Inspector.ts +29 -11
  54. package/dist/exports/core-api.d.ts +0 -74
  55. package/dist/exports/core-api.js +0 -96
  56. package/dist/exports/core-api.js.map +0 -1
  57. package/dist/exports/main-api.d.ts +0 -30
  58. package/dist/exports/main-api.js +0 -45
  59. package/dist/exports/main-api.js.map +0 -1
  60. package/dist/src/core/CoreExtension.d.ts +0 -12
  61. package/dist/src/core/CoreExtension.js +0 -29
  62. package/dist/src/core/CoreExtension.js.map +0 -1
  63. package/dist/src/core/CoreStuff.d.ts +0 -1
  64. package/dist/src/core/CoreStuff.js +0 -138
  65. package/dist/src/core/CoreStuff.js.map +0 -1
  66. package/dist/src/core/LngNode.d.ts +0 -736
  67. package/dist/src/core/LngNode.js +0 -1174
  68. package/dist/src/core/LngNode.js.map +0 -1
  69. package/dist/src/core/Matrix2DContext.d.ts +0 -15
  70. package/dist/src/core/Matrix2DContext.js +0 -45
  71. package/dist/src/core/Matrix2DContext.js.map +0 -1
  72. package/dist/src/core/ShaderNode.d.ts +0 -10
  73. package/dist/src/core/ShaderNode.js +0 -30
  74. package/dist/src/core/ShaderNode.js.map +0 -1
  75. package/dist/src/core/TextNode.d.ts +0 -103
  76. package/dist/src/core/TextNode.js +0 -331
  77. package/dist/src/core/TextNode.js.map +0 -1
  78. package/dist/src/core/lib/Coords.d.ts +0 -14
  79. package/dist/src/core/lib/Coords.js +0 -55
  80. package/dist/src/core/lib/Coords.js.map +0 -1
  81. package/dist/src/core/lib/glm/common.d.ts +0 -162
  82. package/dist/src/core/lib/glm/common.js +0 -81
  83. package/dist/src/core/lib/glm/common.js.map +0 -1
  84. package/dist/src/core/lib/glm/index.d.ts +0 -11
  85. package/dist/src/core/lib/glm/index.js +0 -30
  86. package/dist/src/core/lib/glm/index.js.map +0 -1
  87. package/dist/src/core/lib/glm/mat2.d.ts +0 -219
  88. package/dist/src/core/lib/glm/mat2.js +0 -396
  89. package/dist/src/core/lib/glm/mat2.js.map +0 -1
  90. package/dist/src/core/lib/glm/mat2d.d.ts +0 -237
  91. package/dist/src/core/lib/glm/mat2d.js +0 -442
  92. package/dist/src/core/lib/glm/mat2d.js.map +0 -1
  93. package/dist/src/core/lib/glm/mat3.d.ts +0 -283
  94. package/dist/src/core/lib/glm/mat3.js +0 -680
  95. package/dist/src/core/lib/glm/mat3.js.map +0 -1
  96. package/dist/src/core/lib/glm/mat4.d.ts +0 -550
  97. package/dist/src/core/lib/glm/mat4.js +0 -1802
  98. package/dist/src/core/lib/glm/mat4.js.map +0 -1
  99. package/dist/src/core/lib/glm/quat.d.ts +0 -363
  100. package/dist/src/core/lib/glm/quat.js +0 -693
  101. package/dist/src/core/lib/glm/quat.js.map +0 -1
  102. package/dist/src/core/lib/glm/quat2.d.ts +0 -356
  103. package/dist/src/core/lib/glm/quat2.js +0 -754
  104. package/dist/src/core/lib/glm/quat2.js.map +0 -1
  105. package/dist/src/core/lib/glm/vec2.d.ts +0 -365
  106. package/dist/src/core/lib/glm/vec2.js +0 -569
  107. package/dist/src/core/lib/glm/vec2.js.map +0 -1
  108. package/dist/src/core/lib/glm/vec3.d.ts +0 -406
  109. package/dist/src/core/lib/glm/vec3.js +0 -720
  110. package/dist/src/core/lib/glm/vec3.js.map +0 -1
  111. package/dist/src/core/lib/glm/vec4.d.ts +0 -330
  112. package/dist/src/core/lib/glm/vec4.js +0 -608
  113. package/dist/src/core/lib/glm/vec4.js.map +0 -1
  114. package/dist/src/core/renderers/CoreShaderManager.d.ts +0 -19
  115. package/dist/src/core/renderers/CoreShaderManager.js +0 -33
  116. package/dist/src/core/renderers/CoreShaderManager.js.map +0 -1
  117. package/dist/src/core/renderers/webgl/WebGlCoreShaderManager.d.ts +0 -27
  118. package/dist/src/core/renderers/webgl/WebGlCoreShaderManager.js +0 -82
  119. package/dist/src/core/renderers/webgl/WebGlCoreShaderManager.js.map +0 -1
  120. package/dist/src/core/renderers/webgl/WebGlCoreShaderProgram.d.ts +0 -11
  121. package/dist/src/core/renderers/webgl/WebGlCoreShaderProgram.js +0 -34
  122. package/dist/src/core/renderers/webgl/WebGlCoreShaderProgram.js.map +0 -1
  123. package/dist/src/core/scene/Scene.d.ts +0 -59
  124. package/dist/src/core/scene/Scene.js +0 -106
  125. package/dist/src/core/scene/Scene.js.map +0 -1
  126. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/makeRenderWindow.d.ts +0 -20
  127. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/makeRenderWindow.js +0 -55
  128. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/makeRenderWindow.js.map +0 -1
  129. package/dist/src/main-api/ICoreDriver.d.ts +0 -27
  130. package/dist/src/main-api/ICoreDriver.js +0 -20
  131. package/dist/src/main-api/ICoreDriver.js.map +0 -1
  132. package/dist/src/main-api/IRenderDriver.d.ts +0 -20
  133. package/dist/src/main-api/IRenderDriver.js +0 -20
  134. package/dist/src/main-api/IRenderDriver.js.map +0 -1
  135. package/dist/src/main-api/IShaderController.d.ts +0 -14
  136. package/dist/src/main-api/IShaderController.js +0 -30
  137. package/dist/src/main-api/IShaderController.js.map +0 -1
  138. package/dist/src/main-api/IShaderNode.d.ts +0 -17
  139. package/dist/src/main-api/IShaderNode.js +0 -19
  140. package/dist/src/main-api/IShaderNode.js.map +0 -1
  141. package/dist/src/main-api/RendererMain.d.ts +0 -375
  142. package/dist/src/main-api/RendererMain.js +0 -365
  143. package/dist/src/main-api/RendererMain.js.map +0 -1
  144. package/dist/src/main-api/texture-usage-trackers/FinalizationRegistryTextureUsageTracker.d.ts +0 -9
  145. package/dist/src/main-api/texture-usage-trackers/FinalizationRegistryTextureUsageTracker.js +0 -38
  146. package/dist/src/main-api/texture-usage-trackers/FinalizationRegistryTextureUsageTracker.js.map +0 -1
  147. package/dist/src/main-api/texture-usage-trackers/ManualCountTextureUsageTracker.d.ts +0 -56
  148. package/dist/src/main-api/texture-usage-trackers/ManualCountTextureUsageTracker.js +0 -101
  149. package/dist/src/main-api/texture-usage-trackers/ManualCountTextureUsageTracker.js.map +0 -1
  150. package/dist/src/main-api/texture-usage-trackers/TextureUsageTracker.d.ts +0 -32
  151. package/dist/src/main-api/texture-usage-trackers/TextureUsageTracker.js +0 -28
  152. package/dist/src/main-api/texture-usage-trackers/TextureUsageTracker.js.map +0 -1
  153. package/dist/src/render-drivers/main/MainCoreDriver.d.ts +0 -24
  154. package/dist/src/render-drivers/main/MainCoreDriver.js +0 -118
  155. package/dist/src/render-drivers/main/MainCoreDriver.js.map +0 -1
  156. package/dist/src/render-drivers/main/MainOnlyNode.d.ts +0 -99
  157. package/dist/src/render-drivers/main/MainOnlyNode.js +0 -396
  158. package/dist/src/render-drivers/main/MainOnlyNode.js.map +0 -1
  159. package/dist/src/render-drivers/main/MainOnlyShaderController.d.ts +0 -6
  160. package/dist/src/render-drivers/main/MainOnlyShaderController.js +0 -15
  161. package/dist/src/render-drivers/main/MainOnlyShaderController.js.map +0 -1
  162. package/dist/src/render-drivers/main/MainOnlyShaderNode.d.ts +0 -7
  163. package/dist/src/render-drivers/main/MainOnlyShaderNode.js +0 -34
  164. package/dist/src/render-drivers/main/MainOnlyShaderNode.js.map +0 -1
  165. package/dist/src/render-drivers/main/MainOnlyTextNode.d.ts +0 -47
  166. package/dist/src/render-drivers/main/MainOnlyTextNode.js +0 -205
  167. package/dist/src/render-drivers/main/MainOnlyTextNode.js.map +0 -1
  168. package/dist/src/render-drivers/main/MainRenderDriver.d.ts +0 -17
  169. package/dist/src/render-drivers/main/MainRenderDriver.js +0 -88
  170. package/dist/src/render-drivers/main/MainRenderDriver.js.map +0 -1
  171. package/dist/src/render-drivers/threadx/NodeStruct.d.ts +0 -90
  172. package/dist/src/render-drivers/threadx/NodeStruct.js +0 -281
  173. package/dist/src/render-drivers/threadx/NodeStruct.js.map +0 -1
  174. package/dist/src/render-drivers/threadx/SharedNode.d.ts +0 -39
  175. package/dist/src/render-drivers/threadx/SharedNode.js +0 -60
  176. package/dist/src/render-drivers/threadx/SharedNode.js.map +0 -1
  177. package/dist/src/render-drivers/threadx/TextNodeStruct.d.ts +0 -44
  178. package/dist/src/render-drivers/threadx/TextNodeStruct.js +0 -201
  179. package/dist/src/render-drivers/threadx/TextNodeStruct.js.map +0 -1
  180. package/dist/src/render-drivers/threadx/ThreadXCoreDriver.d.ts +0 -28
  181. package/dist/src/render-drivers/threadx/ThreadXCoreDriver.js +0 -234
  182. package/dist/src/render-drivers/threadx/ThreadXCoreDriver.js.map +0 -1
  183. package/dist/src/render-drivers/threadx/ThreadXMainAnimationController.d.ts +0 -20
  184. package/dist/src/render-drivers/threadx/ThreadXMainAnimationController.js +0 -84
  185. package/dist/src/render-drivers/threadx/ThreadXMainAnimationController.js.map +0 -1
  186. package/dist/src/render-drivers/threadx/ThreadXMainNode.d.ts +0 -44
  187. package/dist/src/render-drivers/threadx/ThreadXMainNode.js +0 -154
  188. package/dist/src/render-drivers/threadx/ThreadXMainNode.js.map +0 -1
  189. package/dist/src/render-drivers/threadx/ThreadXMainShaderController.d.ts +0 -6
  190. package/dist/src/render-drivers/threadx/ThreadXMainShaderController.js +0 -16
  191. package/dist/src/render-drivers/threadx/ThreadXMainShaderController.js.map +0 -1
  192. package/dist/src/render-drivers/threadx/ThreadXMainShaderNode.d.ts +0 -7
  193. package/dist/src/render-drivers/threadx/ThreadXMainShaderNode.js +0 -15
  194. package/dist/src/render-drivers/threadx/ThreadXMainShaderNode.js.map +0 -1
  195. package/dist/src/render-drivers/threadx/ThreadXMainTextNode.d.ts +0 -28
  196. package/dist/src/render-drivers/threadx/ThreadXMainTextNode.js +0 -55
  197. package/dist/src/render-drivers/threadx/ThreadXMainTextNode.js.map +0 -1
  198. package/dist/src/render-drivers/threadx/ThreadXRenderDriver.d.ts +0 -21
  199. package/dist/src/render-drivers/threadx/ThreadXRenderDriver.js +0 -198
  200. package/dist/src/render-drivers/threadx/ThreadXRenderDriver.js.map +0 -1
  201. package/dist/src/render-drivers/threadx/ThreadXRendererMessage.d.ts +0 -70
  202. package/dist/src/render-drivers/threadx/ThreadXRendererMessage.js +0 -32
  203. package/dist/src/render-drivers/threadx/ThreadXRendererMessage.js.map +0 -1
  204. package/dist/src/render-drivers/threadx/worker/ThreadXRendererNode.d.ts +0 -19
  205. package/dist/src/render-drivers/threadx/worker/ThreadXRendererNode.js +0 -177
  206. package/dist/src/render-drivers/threadx/worker/ThreadXRendererNode.js.map +0 -1
  207. package/dist/src/render-drivers/threadx/worker/ThreadXRendererTextNode.d.ts +0 -27
  208. package/dist/src/render-drivers/threadx/worker/ThreadXRendererTextNode.js +0 -108
  209. package/dist/src/render-drivers/threadx/worker/ThreadXRendererTextNode.js.map +0 -1
  210. package/dist/src/render-drivers/threadx/worker/renderer.d.ts +0 -1
  211. package/dist/src/render-drivers/threadx/worker/renderer.js +0 -145
  212. package/dist/src/render-drivers/threadx/worker/renderer.js.map +0 -1
  213. package/dist/src/render-drivers/utils.d.ts +0 -12
  214. package/dist/src/render-drivers/utils.js +0 -69
  215. package/dist/src/render-drivers/utils.js.map +0 -1
@@ -626,13 +626,88 @@ export class WebGlCoreRenderer extends CoreRenderer {
626
626
  }
627
627
  }
628
628
 
629
- // @todo: Better bottom up rendering order
630
- this.rttNodes.unshift(node);
629
+ this.insertRTTNodeInOrder(node);
630
+ }
631
+
632
+ /**
633
+ * Inserts an RTT node into `this.rttNodes` while maintaining the correct rendering order based on hierarchy.
634
+ *
635
+ * Rendering order for RTT nodes is critical when nested RTT nodes exist in a parent-child relationship.
636
+ * Specifically:
637
+ * - Child RTT nodes must be rendered before their RTT-enabled parents to ensure proper texture composition.
638
+ * - If an RTT node is added and it has existing RTT children, it should be rendered after those children.
639
+ *
640
+ * This function addresses both cases by:
641
+ * 1. **Checking Upwards**: It traverses the node's hierarchy upwards to identify any RTT parent
642
+ * already in `rttNodes`. If an RTT parent is found, the new node is placed before this parent.
643
+ * 2. **Checking Downwards**: It traverses the node’s children recursively to find any RTT-enabled
644
+ * children that are already in `rttNodes`. If such children are found, the new node is inserted
645
+ * after the last (highest index) RTT child node.
646
+ *
647
+ * The final calculated insertion index ensures the new node is positioned in `rttNodes` to respect
648
+ * both parent-before-child and child-before-parent rendering rules, preserving the correct order
649
+ * for the WebGL renderer.
650
+ *
651
+ * @param node - The RTT-enabled CoreNode to be added to `rttNodes` in the appropriate hierarchical position.
652
+ */
653
+ private insertRTTNodeInOrder(node: CoreNode) {
654
+ let insertIndex = this.rttNodes.length; // Default to the end of the array
655
+
656
+ // 1. Traverse upwards to ensure the node is placed before its RTT parent (if any).
657
+ let currentNode: CoreNode = node;
658
+ while (currentNode) {
659
+ if (!currentNode.parent) {
660
+ break;
661
+ }
662
+
663
+ const parentIndex = this.rttNodes.indexOf(currentNode.parent);
664
+ if (parentIndex !== -1) {
665
+ // Found an RTT parent in the list; set insertIndex to place node before the parent
666
+ insertIndex = parentIndex;
667
+ break;
668
+ }
669
+
670
+ currentNode = currentNode.parent;
671
+ }
672
+
673
+ // 2. Traverse downwards to ensure the node is placed after any RTT children.
674
+ // Look through each child recursively to see if any are already in rttNodes.
675
+ const maxChildIndex = this.findMaxChildRTTIndex(node);
676
+ if (maxChildIndex !== -1) {
677
+ // Adjust insertIndex to be after the last child RTT node
678
+ insertIndex = Math.max(insertIndex, maxChildIndex + 1);
679
+ }
680
+
681
+ // 3. Insert the node at the calculated position
682
+ this.rttNodes.splice(insertIndex, 0, node);
683
+ }
684
+
685
+ // Helper function to find the highest index of any RTT children of a node within rttNodes
686
+ private findMaxChildRTTIndex(node: CoreNode): number {
687
+ let maxIndex = -1;
688
+
689
+ const traverseChildren = (currentNode: CoreNode) => {
690
+ const currentIndex = this.rttNodes.indexOf(currentNode);
691
+ if (currentIndex !== -1) {
692
+ maxIndex = Math.max(maxIndex, currentIndex);
693
+ }
694
+
695
+ // Recursively check all children of the current node
696
+ for (const child of currentNode.children) {
697
+ traverseChildren(child);
698
+ }
699
+ };
700
+
701
+ // Start traversal directly with the provided node
702
+ traverseChildren(node);
703
+
704
+ return maxIndex;
631
705
  }
632
706
 
633
707
  renderRTTNodes() {
634
708
  const { glw } = this;
635
709
  const { txManager } = this.stage;
710
+
636
711
  // Render all associated RTT nodes to their textures
637
712
  for (let i = 0; i < this.rttNodes.length; i++) {
638
713
  const node = this.rttNodes[i];
@@ -662,16 +737,10 @@ export class WebGlCoreRenderer extends CoreRenderer {
662
737
  // Render all associated quads to the texture
663
738
  for (let i = 0; i < node.children.length; i++) {
664
739
  const child = node.children[i];
740
+
665
741
  if (!child) {
666
742
  continue;
667
743
  }
668
- child.update(this.stage.deltaTime, {
669
- x: 0,
670
- y: 0,
671
- width: 0,
672
- height: 0,
673
- valid: false,
674
- });
675
744
 
676
745
  this.stage.addQuads(child);
677
746
  child.hasRTTupdates = false;
@@ -143,12 +143,14 @@ export abstract class WebGlCoreShader extends CoreShader {
143
143
  fragmentSource,
144
144
  );
145
145
  if (!vertexShader || !fragmentShader) {
146
- throw new Error();
146
+ throw new Error(
147
+ `Unable to create shader type: ${glw.FRAGMENT_SHADER}. Source: ${fragmentSource}`,
148
+ );
147
149
  }
148
150
 
149
151
  const program = createProgram(glw, vertexShader, fragmentShader);
150
152
  if (!program) {
151
- throw new Error();
153
+ throw new Error('Unable to create program');
152
154
  }
153
155
  this.program = program;
154
156
 
@@ -100,11 +100,11 @@ export function createShader(
100
100
  ) {
101
101
  const shader = glw.createShader(type);
102
102
  if (!shader) {
103
- throw new Error();
103
+ throw new Error(`Unable to create shader type: ${type}. Source: ${source}`);
104
104
  }
105
105
  glw.shaderSource(shader, source);
106
106
  glw.compileShader(shader);
107
- const success = glw.getShaderParameter(shader, glw.COMPILE_STATUS);
107
+ const success = !!glw.getShaderParameter(shader, glw.COMPILE_STATUS);
108
108
  if (success) {
109
109
  return shader;
110
110
  }
@@ -120,12 +120,13 @@ export function createProgram(
120
120
  ) {
121
121
  const program = glw.createProgram();
122
122
  if (!program) {
123
- throw new Error();
123
+ throw new Error('Unable to create program');
124
124
  }
125
+
125
126
  glw.attachShader(program, vertexShader);
126
127
  glw.attachShader(program, fragmentShader);
127
128
  glw.linkProgram(program);
128
- const success = glw.getProgramParameter(program, glw.LINK_STATUS);
129
+ const success = !!glw.getProgramParameter(program, glw.LINK_STATUS);
129
130
  if (success) {
130
131
  return program;
131
132
  }
@@ -16,13 +16,11 @@
16
16
  * See the License for the specific language governing permissions and
17
17
  * limitations under the License.
18
18
  */
19
- import type { DynamicShaderProps } from '../DynamicShader.js';
20
19
  import { updateWebSafeRadius, validateArrayLength4 } from './EffectUtils.js';
21
20
  import {
22
21
  ShaderEffect,
23
22
  type DefaultEffectProps,
24
23
  type ShaderEffectUniforms,
25
- type ShaderEffectValueMap,
26
24
  } from './ShaderEffect.js';
27
25
 
28
26
  /**
@@ -1,6 +1,5 @@
1
1
  import type { EffectMap } from '../../../../CoreShaderManager.js';
2
2
  import type { ExtractProps } from '../../../../CoreTextureManager.js';
3
- import type { WebGlContextWrapper } from '../../../../lib/WebGlContextWrapper.js';
4
3
  import type {
5
4
  AlphaShaderProp,
6
5
  DimensionsShaderProp,
@@ -63,10 +63,22 @@ export class ColorTexture extends Texture {
63
63
  }
64
64
 
65
65
  override async getTextureData(): Promise<TextureData> {
66
- const pixelData32 = new Uint32Array([this.color]);
67
- const pixelData8 = new Uint8ClampedArray(pixelData32.buffer);
66
+ const pixelData = new Uint8Array(4);
67
+
68
+ if (this.color === 0xffffffff) {
69
+ pixelData[0] = 255;
70
+ pixelData[1] = 255;
71
+ pixelData[2] = 255;
72
+ pixelData[3] = 255;
73
+ } else {
74
+ pixelData[0] = (this.color >> 16) & 0xff; // Red
75
+ pixelData[1] = (this.color >> 8) & 0xff; // Green
76
+ pixelData[2] = this.color & 0xff; // Blue
77
+ pixelData[3] = (this.color >>> 24) & 0xff; // Alpha
78
+ }
79
+
68
80
  return {
69
- data: new ImageData(pixelData8, 1, 1),
81
+ data: pixelData,
70
82
  premultiplyAlpha: true,
71
83
  };
72
84
  }
@@ -91,6 +91,7 @@ export interface TextureData {
91
91
  | SubTextureProps
92
92
  | CompressedData
93
93
  | HTMLImageElement
94
+ | Uint8Array
94
95
  | null;
95
96
  /**
96
97
  * Premultiply alpha when uploading texture data to the GPU
@@ -62,7 +62,7 @@ const stylePropertyMap: {
62
62
 
63
63
  return { prop: 'height', value: `${h}px` };
64
64
  },
65
- zIndex: () => 'zIndex',
65
+ zIndex: () => 'z-index',
66
66
  fontFamily: () => 'font-family',
67
67
  fontSize: () => 'font-size',
68
68
  fontStyle: () => 'font-style',
@@ -239,6 +239,7 @@ export class Inspector {
239
239
  // really typescript? really?
240
240
  key as keyof CoreNodeProps,
241
241
  properties[key as keyof CoreNodeProps],
242
+ properties,
242
243
  );
243
244
  }
244
245
 
@@ -247,8 +248,8 @@ export class Inspector {
247
248
 
248
249
  createNode(node: CoreNode): CoreNode {
249
250
  const div = this.createDiv(node.id, node.props);
250
- (div as any).node = node;
251
- (node as any).div = div;
251
+ (div as HTMLElement & { node: CoreNode }).node = node;
252
+ (node as CoreNode & { div: HTMLElement }).div = div;
252
253
 
253
254
  node.on('inViewport', () => div.setAttribute('state', 'inViewport'));
254
255
  node.on('inBounds', () => div.setAttribute('state', 'inBounds'));
@@ -260,8 +261,8 @@ export class Inspector {
260
261
 
261
262
  createTextNode(node: CoreNode): CoreTextNode {
262
263
  const div = this.createDiv(node.id, node.props);
263
- (div as any).node = node;
264
- (node as any).div = div;
264
+ (div as HTMLElement & { node: CoreNode }).node = node;
265
+ (node as CoreNode & { div: HTMLElement }).div = div;
265
266
 
266
267
  return this.createProxy(node, div) as CoreTextNode;
267
268
  }
@@ -295,6 +296,7 @@ export class Inspector {
295
296
  div,
296
297
  property as keyof CoreNodeProps | keyof CoreTextNodeProps,
297
298
  value,
299
+ node.props,
298
300
  );
299
301
  },
300
302
  configurable: true,
@@ -344,6 +346,7 @@ export class Inspector {
344
346
  property: keyof CoreNodeProps | keyof CoreTextNodeProps,
345
347
  // eslint-disable-next-line @typescript-eslint/no-explicit-any
346
348
  value: any,
349
+ props: CoreNodeProps | CoreTextNodeProps,
347
350
  ) {
348
351
  if (this.root === null || value === undefined || value === null) {
349
352
  return;
@@ -407,10 +410,23 @@ export class Inspector {
407
410
  }
408
411
 
409
412
  if (typeof mappedStyleResponse === 'object') {
410
- div.style.setProperty(
411
- mappedStyleResponse.prop,
412
- mappedStyleResponse.value,
413
- );
413
+ let value = mappedStyleResponse.value;
414
+ if (property === 'x') {
415
+ const mount = props.mountX;
416
+ const width = props.width;
417
+
418
+ if (mount) {
419
+ value = `${parseInt(value) - width * mount}px`;
420
+ }
421
+ } else if (property === 'y') {
422
+ const mount = props.mountY;
423
+ const height = props.height;
424
+
425
+ if (mount) {
426
+ value = `${parseInt(value) - height * mount}px`;
427
+ }
428
+ }
429
+ div.style.setProperty(mappedStyleResponse.prop, value);
414
430
  }
415
431
 
416
432
  return;
@@ -466,13 +482,15 @@ export class Inspector {
466
482
  rotation = 0,
467
483
  scale = 1,
468
484
  color,
485
+ mountX,
486
+ mountY,
469
487
  } = props;
470
488
 
471
489
  // ignoring loops and repeats for now, as that might be a bit too much for the inspector
472
490
  function animate() {
473
491
  setTimeout(() => {
474
- div.style.top = `${y}px`;
475
- div.style.left = `${x}px`;
492
+ div.style.top = `${y - height * mountY}px`;
493
+ div.style.left = `${x - width * mountX}px`;
476
494
  div.style.width = `${width}px`;
477
495
  div.style.height = `${height}px`;
478
496
  div.style.opacity = `${alpha}`;
@@ -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';
@@ -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';
@@ -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 +0,0 @@
1
- export {};