@lightningjs/renderer 0.7.4 → 0.7.6

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 (228) hide show
  1. package/LICENSE +202 -202
  2. package/NOTICE +3 -3
  3. package/README.md +229 -221
  4. package/dist/src/common/CommonTypes.d.ts +6 -0
  5. package/dist/src/core/CoreNode.d.ts +25 -4
  6. package/dist/src/core/CoreNode.js +158 -25
  7. package/dist/src/core/CoreNode.js.map +1 -1
  8. package/dist/src/core/CoreTextNode.d.ts +1 -1
  9. package/dist/src/core/CoreTextNode.js +18 -10
  10. package/dist/src/core/CoreTextNode.js.map +1 -1
  11. package/dist/src/core/CoreTextureManager.d.ts +3 -1
  12. package/dist/src/core/CoreTextureManager.js +9 -2
  13. package/dist/src/core/CoreTextureManager.js.map +1 -1
  14. package/dist/src/core/Stage.d.ts +2 -0
  15. package/dist/src/core/Stage.js +9 -1
  16. package/dist/src/core/Stage.js.map +1 -1
  17. package/dist/src/core/lib/ImageWorker.d.ts +0 -1
  18. package/dist/src/core/lib/ImageWorker.js +55 -40
  19. package/dist/src/core/lib/ImageWorker.js.map +1 -1
  20. package/dist/src/core/lib/RenderCoords.d.ts +13 -0
  21. package/dist/src/core/lib/RenderCoords.js +63 -0
  22. package/dist/src/core/lib/RenderCoords.js.map +1 -0
  23. package/dist/src/core/lib/WebGlContext.d.ts +414 -0
  24. package/dist/src/core/lib/WebGlContext.js +640 -0
  25. package/dist/src/core/lib/WebGlContext.js.map +1 -0
  26. package/dist/src/core/lib/utils.d.ts +1 -0
  27. package/dist/src/core/lib/utils.js +6 -0
  28. package/dist/src/core/lib/utils.js.map +1 -1
  29. package/dist/src/core/renderers/webgl/WebGlCoreCtxTexture.js +4 -1
  30. package/dist/src/core/renderers/webgl/WebGlCoreCtxTexture.js.map +1 -1
  31. package/dist/src/core/renderers/webgl/internal/RendererUtils.d.ts +9 -0
  32. package/dist/src/core/renderers/webgl/internal/RendererUtils.js +14 -0
  33. package/dist/src/core/renderers/webgl/internal/RendererUtils.js.map +1 -1
  34. package/dist/src/core/renderers/webgl/shaders/DefaultShader.js +47 -47
  35. package/dist/src/core/renderers/webgl/shaders/DefaultShaderBatched.js +61 -61
  36. package/dist/src/core/renderers/webgl/shaders/DynamicShader.js +93 -93
  37. package/dist/src/core/renderers/webgl/shaders/RoundedRectangle.js +63 -63
  38. package/dist/src/core/renderers/webgl/shaders/SdfShader.js +49 -49
  39. package/dist/src/core/renderers/webgl/shaders/effects/BorderBottomEffect.js +15 -15
  40. package/dist/src/core/renderers/webgl/shaders/effects/BorderEffect.js +5 -5
  41. package/dist/src/core/renderers/webgl/shaders/effects/BorderLeftEffect.js +15 -15
  42. package/dist/src/core/renderers/webgl/shaders/effects/BorderRightEffect.js +15 -15
  43. package/dist/src/core/renderers/webgl/shaders/effects/BorderTopEffect.js +15 -15
  44. package/dist/src/core/renderers/webgl/shaders/effects/FadeOutEffect.js +42 -42
  45. package/dist/src/core/renderers/webgl/shaders/effects/GlitchEffect.js +44 -44
  46. package/dist/src/core/renderers/webgl/shaders/effects/GrayscaleEffect.js +3 -3
  47. package/dist/src/core/renderers/webgl/shaders/effects/LinearGradientEffect.js +31 -31
  48. package/dist/src/core/renderers/webgl/shaders/effects/RadialGradientEffect.js +13 -13
  49. package/dist/src/core/renderers/webgl/shaders/effects/RadialProgressEffect.js +37 -37
  50. package/dist/src/core/renderers/webgl/shaders/effects/RadiusEffect.js +19 -19
  51. package/dist/src/core/scene/Scene.d.ts +59 -0
  52. package/dist/src/core/scene/Scene.js +106 -0
  53. package/dist/src/core/scene/Scene.js.map +1 -0
  54. package/dist/src/core/text-rendering/TrFontManager.js +76 -27
  55. package/dist/src/core/text-rendering/TrFontManager.js.map +1 -1
  56. package/dist/src/core/text-rendering/renderers/CanvasTextRenderer.js +8 -2
  57. package/dist/src/core/text-rendering/renderers/CanvasTextRenderer.js.map +1 -1
  58. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.d.ts +1 -0
  59. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.js +13 -3
  60. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.js.map +1 -1
  61. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/findNearestMultiple.d.ts +8 -0
  62. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/findNearestMultiple.js +29 -0
  63. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/findNearestMultiple.js.map +1 -0
  64. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText2/SdfBufferHelper.d.ts +19 -0
  65. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText2/SdfBufferHelper.js +84 -0
  66. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText2/SdfBufferHelper.js.map +1 -0
  67. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText2/layoutLine.d.ts +8 -0
  68. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText2/layoutLine.js +40 -0
  69. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText2/layoutLine.js.map +1 -0
  70. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText2/layoutText2.d.ts +2 -0
  71. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText2/layoutText2.js +41 -0
  72. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText2/layoutText2.js.map +1 -0
  73. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText2/utils.d.ts +1 -0
  74. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText2/utils.js +4 -0
  75. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText2/utils.js.map +1 -0
  76. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText2.d.ts +1 -0
  77. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText2.js +2 -0
  78. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText2.js.map +1 -0
  79. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/makeRenderWindow.d.ts +20 -0
  80. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/makeRenderWindow.js +55 -0
  81. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/makeRenderWindow.js.map +1 -0
  82. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/roundUpToMultiple.d.ts +9 -0
  83. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/roundUpToMultiple.js +32 -0
  84. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/roundUpToMultiple.js.map +1 -0
  85. package/dist/src/core/text-rendering/renderers/TextRenderer.d.ts +12 -0
  86. package/dist/src/core/text-rendering/renderers/TextRenderer.js.map +1 -1
  87. package/dist/src/core/textures/ImageTexture.js +16 -2
  88. package/dist/src/core/textures/ImageTexture.js.map +1 -1
  89. package/dist/src/core/textures/Texture.d.ts +1 -1
  90. package/dist/src/core/textures/Texture.js.map +1 -1
  91. package/dist/src/core/utils.d.ts +1 -1
  92. package/dist/src/main-api/INode.d.ts +27 -0
  93. package/dist/src/main-api/Inspector.js +20 -15
  94. package/dist/src/main-api/Inspector.js.map +1 -1
  95. package/dist/src/main-api/RendererMain.d.ts +6 -0
  96. package/dist/src/main-api/RendererMain.js +4 -0
  97. package/dist/src/main-api/RendererMain.js.map +1 -1
  98. package/dist/src/render-drivers/main/MainCoreDriver.js +1 -0
  99. package/dist/src/render-drivers/main/MainCoreDriver.js.map +1 -1
  100. package/dist/src/render-drivers/main/MainOnlyNode.d.ts +8 -1
  101. package/dist/src/render-drivers/main/MainOnlyNode.js +32 -0
  102. package/dist/src/render-drivers/main/MainOnlyNode.js.map +1 -1
  103. package/dist/src/render-drivers/threadx/ThreadXCoreDriver.js +1 -0
  104. package/dist/src/render-drivers/threadx/ThreadXCoreDriver.js.map +1 -1
  105. package/dist/src/render-drivers/threadx/ThreadXMainNode.d.ts +4 -1
  106. package/dist/src/render-drivers/threadx/ThreadXMainNode.js +8 -0
  107. package/dist/src/render-drivers/threadx/ThreadXMainNode.js.map +1 -1
  108. package/dist/src/render-drivers/threadx/ThreadXRendererMessage.d.ts +1 -0
  109. package/dist/src/render-drivers/threadx/ThreadXRendererMessage.js.map +1 -1
  110. package/dist/src/render-drivers/threadx/worker/renderer.js +1 -0
  111. package/dist/src/render-drivers/threadx/worker/renderer.js.map +1 -1
  112. package/dist/src/render-drivers/utils.d.ts +2 -0
  113. package/dist/src/render-drivers/utils.js +28 -0
  114. package/dist/src/render-drivers/utils.js.map +1 -1
  115. package/dist/tsconfig.dist.tsbuildinfo +1 -1
  116. package/exports/core-api.ts +102 -102
  117. package/exports/main-api.ts +60 -60
  118. package/exports/utils.ts +41 -41
  119. package/package.json +1 -1
  120. package/scripts/please-use-pnpm.js +13 -13
  121. package/src/common/CommonTypes.ts +125 -113
  122. package/src/common/EventEmitter.ts +77 -77
  123. package/src/common/IAnimationController.ts +29 -29
  124. package/src/core/CoreExtension.ts +32 -32
  125. package/src/core/CoreNode.ts +1114 -926
  126. package/src/core/CoreShaderManager.ts +243 -243
  127. package/src/core/CoreTextNode.ts +399 -391
  128. package/src/core/CoreTextureManager.ts +337 -326
  129. package/src/core/Stage.ts +365 -354
  130. package/src/core/animations/AnimationManager.ts +38 -38
  131. package/src/core/animations/CoreAnimation.ts +181 -181
  132. package/src/core/animations/CoreAnimationController.ts +148 -148
  133. package/src/core/lib/ContextSpy.ts +41 -41
  134. package/src/core/lib/ImageWorker.ts +149 -135
  135. package/src/core/lib/Matrix3d.ts +290 -290
  136. package/src/core/lib/RenderCoords.ts +86 -0
  137. package/src/core/lib/WebGlContextWrapper.ts +992 -992
  138. package/src/core/lib/textureCompression.ts +152 -152
  139. package/src/core/lib/utils.ts +250 -241
  140. package/src/core/platform.ts +46 -46
  141. package/src/core/renderers/CoreContextTexture.ts +30 -30
  142. package/src/core/renderers/CoreRenderOp.ts +22 -22
  143. package/src/core/renderers/CoreRenderer.ts +63 -63
  144. package/src/core/renderers/CoreShader.ts +41 -41
  145. package/src/core/renderers/webgl/WebGlCoreCtxSubTexture.ts +37 -37
  146. package/src/core/renderers/webgl/WebGlCoreCtxTexture.ts +233 -230
  147. package/src/core/renderers/webgl/WebGlCoreRenderOp.ts +107 -107
  148. package/src/core/renderers/webgl/WebGlCoreRenderer.ts +520 -520
  149. package/src/core/renderers/webgl/WebGlCoreShader.ts +337 -337
  150. package/src/core/renderers/webgl/internal/BufferCollection.ts +54 -54
  151. package/src/core/renderers/webgl/internal/RendererUtils.ts +148 -131
  152. package/src/core/renderers/webgl/internal/ShaderUtils.ts +136 -136
  153. package/src/core/renderers/webgl/internal/WebGlUtils.ts +35 -35
  154. package/src/core/renderers/webgl/shaders/DefaultShader.ts +95 -95
  155. package/src/core/renderers/webgl/shaders/DefaultShaderBatched.ts +132 -132
  156. package/src/core/renderers/webgl/shaders/DynamicShader.ts +474 -474
  157. package/src/core/renderers/webgl/shaders/RoundedRectangle.ts +161 -161
  158. package/src/core/renderers/webgl/shaders/SdfShader.ts +174 -174
  159. package/src/core/renderers/webgl/shaders/effects/BorderBottomEffect.ts +101 -101
  160. package/src/core/renderers/webgl/shaders/effects/BorderEffect.ts +86 -86
  161. package/src/core/renderers/webgl/shaders/effects/BorderLeftEffect.ts +101 -101
  162. package/src/core/renderers/webgl/shaders/effects/BorderRightEffect.ts +101 -101
  163. package/src/core/renderers/webgl/shaders/effects/BorderTopEffect.ts +101 -101
  164. package/src/core/renderers/webgl/shaders/effects/EffectUtils.ts +33 -33
  165. package/src/core/renderers/webgl/shaders/effects/FadeOutEffect.ts +135 -135
  166. package/src/core/renderers/webgl/shaders/effects/GlitchEffect.ts +145 -145
  167. package/src/core/renderers/webgl/shaders/effects/GrayscaleEffect.ts +67 -67
  168. package/src/core/renderers/webgl/shaders/effects/LinearGradientEffect.ts +176 -176
  169. package/src/core/renderers/webgl/shaders/effects/RadialGradientEffect.ts +159 -159
  170. package/src/core/renderers/webgl/shaders/effects/RadialProgressEffect.ts +186 -186
  171. package/src/core/renderers/webgl/shaders/effects/RadiusEffect.ts +121 -121
  172. package/src/core/renderers/webgl/shaders/effects/ShaderEffect.ts +114 -114
  173. package/src/core/text-rendering/TextTextureRendererUtils.ts +189 -189
  174. package/src/core/text-rendering/TrFontManager.ts +170 -96
  175. package/src/core/text-rendering/font-face-types/SdfTrFontFace/SdfTrFontFace.ts +141 -141
  176. package/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/FontShaper.ts +139 -139
  177. package/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/SdfFontShaper.test.ts +173 -173
  178. package/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/SdfFontShaper.ts +169 -169
  179. package/src/core/text-rendering/font-face-types/TrFontFace.ts +105 -105
  180. package/src/core/text-rendering/font-face-types/WebTrFontFace.ts +77 -77
  181. package/src/core/text-rendering/renderers/CanvasTextRenderer.ts +757 -751
  182. package/src/core/text-rendering/renderers/LightningTextTextureRenderer.ts +741 -741
  183. package/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.ts +784 -775
  184. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/PeekableGenerator.test.ts +48 -48
  185. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/PeekableGenerator.ts +66 -66
  186. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/SpecialCodepoints.ts +52 -52
  187. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/constants.ts +32 -32
  188. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/getStartConditions.ts +84 -84
  189. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/getUnicodeCodepoints.test.ts +133 -133
  190. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/getUnicodeCodepoints.ts +38 -38
  191. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText.ts +393 -393
  192. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/measureText.test.ts +49 -49
  193. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/measureText.ts +51 -51
  194. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/setRenderWindow.test.ts +205 -205
  195. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/setRenderWindow.ts +93 -93
  196. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/util.ts +40 -40
  197. package/src/core/text-rendering/renderers/TextRenderer.ts +516 -504
  198. package/src/core/textures/ColorTexture.ts +86 -86
  199. package/src/core/textures/ImageTexture.ts +154 -140
  200. package/src/core/textures/NoiseTexture.ts +96 -96
  201. package/src/core/textures/SubTexture.ts +143 -143
  202. package/src/core/textures/Texture.ts +224 -218
  203. package/src/core/utils.ts +224 -224
  204. package/src/env.d.ts +7 -7
  205. package/src/main-api/ICoreDriver.ts +66 -66
  206. package/src/main-api/INode.ts +499 -470
  207. package/src/main-api/Inspector.ts +439 -432
  208. package/src/main-api/RendererMain.ts +659 -649
  209. package/src/main-api/texture-usage-trackers/FinalizationRegistryTextureUsageTracker.ts +45 -45
  210. package/src/main-api/texture-usage-trackers/ManualCountTextureUsageTracker.ts +154 -154
  211. package/src/main-api/texture-usage-trackers/TextureUsageTracker.ts +54 -54
  212. package/src/render-drivers/main/MainCoreDriver.ts +149 -148
  213. package/src/render-drivers/main/MainOnlyNode.ts +494 -453
  214. package/src/render-drivers/main/MainOnlyTextNode.ts +261 -261
  215. package/src/render-drivers/threadx/NodeStruct.ts +300 -300
  216. package/src/render-drivers/threadx/SharedNode.ts +97 -97
  217. package/src/render-drivers/threadx/TextNodeStruct.ts +211 -211
  218. package/src/render-drivers/threadx/ThreadXCoreDriver.ts +286 -285
  219. package/src/render-drivers/threadx/ThreadXMainAnimationController.ts +99 -99
  220. package/src/render-drivers/threadx/ThreadXMainNode.ts +192 -178
  221. package/src/render-drivers/threadx/ThreadXMainTextNode.ts +85 -85
  222. package/src/render-drivers/threadx/ThreadXRendererMessage.ts +111 -110
  223. package/src/render-drivers/threadx/worker/ThreadXRendererNode.ts +238 -238
  224. package/src/render-drivers/threadx/worker/ThreadXRendererTextNode.ts +149 -149
  225. package/src/render-drivers/threadx/worker/renderer.ts +152 -151
  226. package/src/render-drivers/utils.ts +97 -57
  227. package/src/utils.ts +207 -207
  228. package/COPYING +0 -1
@@ -1,54 +1,54 @@
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
- import type { AttributeInfo } from './ShaderUtils.js';
21
-
22
- export interface BufferItem {
23
- buffer: WebGLBuffer;
24
- attributes: Record<string, AttributeInfo>;
25
- }
26
-
27
- /**
28
- * Represents a collection of WebGL Buffers along with their associated
29
- * vertex attribute formats.
30
- */
31
- export class BufferCollection {
32
- constructor(readonly config: BufferItem[]) {}
33
-
34
- /**
35
- * Get the WebGLBuffer associated with the given attribute name if it exists.
36
- *
37
- * @param attributeName
38
- * @returns
39
- */
40
- getBuffer(attributeName: string): WebGLBuffer | undefined {
41
- return this.config.find((item) => item.attributes[attributeName])?.buffer;
42
- }
43
-
44
- /**
45
- * Get the AttributeInfo associated with the given attribute name if it exists.
46
- *
47
- * @param attributeName
48
- * @returns
49
- */
50
- getAttributeInfo(attributeName: string): AttributeInfo | undefined {
51
- return this.config.find((item) => item.attributes[attributeName])
52
- ?.attributes[attributeName];
53
- }
54
- }
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
+ import type { AttributeInfo } from './ShaderUtils.js';
21
+
22
+ export interface BufferItem {
23
+ buffer: WebGLBuffer;
24
+ attributes: Record<string, AttributeInfo>;
25
+ }
26
+
27
+ /**
28
+ * Represents a collection of WebGL Buffers along with their associated
29
+ * vertex attribute formats.
30
+ */
31
+ export class BufferCollection {
32
+ constructor(readonly config: BufferItem[]) {}
33
+
34
+ /**
35
+ * Get the WebGLBuffer associated with the given attribute name if it exists.
36
+ *
37
+ * @param attributeName
38
+ * @returns
39
+ */
40
+ getBuffer(attributeName: string): WebGLBuffer | undefined {
41
+ return this.config.find((item) => item.attributes[attributeName])?.buffer;
42
+ }
43
+
44
+ /**
45
+ * Get the AttributeInfo associated with the given attribute name if it exists.
46
+ *
47
+ * @param attributeName
48
+ * @returns
49
+ */
50
+ getAttributeInfo(attributeName: string): AttributeInfo | undefined {
51
+ return this.config.find((item) => item.attributes[attributeName])
52
+ ?.attributes[attributeName];
53
+ }
54
+ }
@@ -1,131 +1,148 @@
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
- import type { WebGlContextWrapper } from '../../../lib/WebGlContextWrapper.js';
21
-
22
- export interface CoreWebGlParameters {
23
- MAX_RENDERBUFFER_SIZE: number;
24
- MAX_TEXTURE_SIZE: number;
25
- MAX_VIEWPORT_DIMS: Int32Array;
26
- MAX_VERTEX_TEXTURE_IMAGE_UNITS: number;
27
- MAX_TEXTURE_IMAGE_UNITS: number;
28
- MAX_COMBINED_TEXTURE_IMAGE_UNITS: number;
29
- MAX_VERTEX_ATTRIBS: number;
30
- MAX_VARYING_VECTORS: number;
31
- MAX_VERTEX_UNIFORM_VECTORS: number;
32
- MAX_FRAGMENT_UNIFORM_VECTORS: number;
33
- }
34
-
35
- /**
36
- * Get device specific webgl parameters
37
- * @param glw
38
- */
39
- export function getWebGlParameters(
40
- glw: WebGlContextWrapper,
41
- ): CoreWebGlParameters {
42
- const params: CoreWebGlParameters = {
43
- MAX_RENDERBUFFER_SIZE: 0,
44
- MAX_TEXTURE_SIZE: 0,
45
- // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment, @typescript-eslint/no-explicit-any
46
- MAX_VIEWPORT_DIMS: 0 as any, // Code below will replace this with an Int32Array
47
- MAX_VERTEX_TEXTURE_IMAGE_UNITS: 0,
48
- MAX_TEXTURE_IMAGE_UNITS: 0,
49
- MAX_COMBINED_TEXTURE_IMAGE_UNITS: 0,
50
- MAX_VERTEX_ATTRIBS: 0,
51
- MAX_VARYING_VECTORS: 0,
52
- MAX_VERTEX_UNIFORM_VECTORS: 0,
53
- MAX_FRAGMENT_UNIFORM_VECTORS: 0,
54
- };
55
-
56
- // Map over all parameters and get them
57
- const keys = Object.keys(params) as Array<keyof CoreWebGlParameters>;
58
- keys.forEach((key) => {
59
- // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment
60
- params[key] = glw.getParameter(glw[key]);
61
- });
62
-
63
- return params;
64
- }
65
-
66
- export interface CoreWebGlExtensions {
67
- ANGLE_instanced_arrays: ANGLE_instanced_arrays | null;
68
- WEBGL_compressed_texture_s3tc: WEBGL_compressed_texture_s3tc | null;
69
- WEBGL_compressed_texture_astc: WEBGL_compressed_texture_astc | null;
70
- WEBGL_compressed_texture_etc: WEBGL_compressed_texture_etc | null;
71
- WEBGL_compressed_texture_etc1: WEBGL_compressed_texture_etc1 | null;
72
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
73
- WEBGL_compressed_texture_pvrtc: any | null;
74
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
75
- WEBKIT_WEBGL_compressed_texture_pvrtc: any | null;
76
- WEBGL_compressed_texture_s3tc_srgb: WEBGL_compressed_texture_s3tc_srgb | null;
77
- OES_vertex_array_object: OES_vertex_array_object | null;
78
- }
79
-
80
- /**
81
- * Get device webgl extensions
82
- * @param glw
83
- */
84
- export function getWebGlExtensions(
85
- glw: WebGlContextWrapper,
86
- ): CoreWebGlExtensions {
87
- const extensions: CoreWebGlExtensions = {
88
- ANGLE_instanced_arrays: null,
89
- WEBGL_compressed_texture_s3tc: null,
90
- WEBGL_compressed_texture_astc: null,
91
- WEBGL_compressed_texture_etc: null,
92
- WEBGL_compressed_texture_etc1: null,
93
- WEBGL_compressed_texture_pvrtc: null,
94
- WEBKIT_WEBGL_compressed_texture_pvrtc: null,
95
- WEBGL_compressed_texture_s3tc_srgb: null,
96
- OES_vertex_array_object: null,
97
- };
98
-
99
- // Map over all extensions and get them
100
- const keys = Object.keys(extensions) as Array<keyof CoreWebGlExtensions>;
101
- keys.forEach((key) => {
102
- // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment
103
- extensions[key] = glw.getExtension(key);
104
- });
105
-
106
- return extensions;
107
- }
108
-
109
- /**
110
- * Allocate big memory chunk that we
111
- * can re-use to draw quads
112
- *
113
- * @param glw
114
- * @param size
115
- */
116
- export function createIndexBuffer(glw: WebGlContextWrapper, size: number) {
117
- const maxQuads = ~~(size / 80);
118
- const indices = new Uint16Array(maxQuads * 6);
119
-
120
- for (let i = 0, j = 0; i < maxQuads; i += 6, j += 4) {
121
- indices[i] = j;
122
- indices[i + 1] = j + 1;
123
- indices[i + 2] = j + 2;
124
- indices[i + 3] = j + 2;
125
- indices[i + 4] = j + 1;
126
- indices[i + 5] = j + 3;
127
- }
128
-
129
- const buffer = glw.createBuffer();
130
- glw.elementArrayBufferData(buffer, indices, glw.STATIC_DRAW);
131
- }
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
+ import type { WebGlContextWrapper } from '../../../lib/WebGlContextWrapper.js';
21
+
22
+ export interface CoreWebGlParameters {
23
+ MAX_RENDERBUFFER_SIZE: number;
24
+ MAX_TEXTURE_SIZE: number;
25
+ MAX_VIEWPORT_DIMS: Int32Array;
26
+ MAX_VERTEX_TEXTURE_IMAGE_UNITS: number;
27
+ MAX_TEXTURE_IMAGE_UNITS: number;
28
+ MAX_COMBINED_TEXTURE_IMAGE_UNITS: number;
29
+ MAX_VERTEX_ATTRIBS: number;
30
+ MAX_VARYING_VECTORS: number;
31
+ MAX_VERTEX_UNIFORM_VECTORS: number;
32
+ MAX_FRAGMENT_UNIFORM_VECTORS: number;
33
+ }
34
+
35
+ /**
36
+ * Get device specific webgl parameters
37
+ * @param glw
38
+ */
39
+ export function getWebGlParameters(
40
+ glw: WebGlContextWrapper,
41
+ ): CoreWebGlParameters {
42
+ const params: CoreWebGlParameters = {
43
+ MAX_RENDERBUFFER_SIZE: 0,
44
+ MAX_TEXTURE_SIZE: 0,
45
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment, @typescript-eslint/no-explicit-any
46
+ MAX_VIEWPORT_DIMS: 0 as any, // Code below will replace this with an Int32Array
47
+ MAX_VERTEX_TEXTURE_IMAGE_UNITS: 0,
48
+ MAX_TEXTURE_IMAGE_UNITS: 0,
49
+ MAX_COMBINED_TEXTURE_IMAGE_UNITS: 0,
50
+ MAX_VERTEX_ATTRIBS: 0,
51
+ MAX_VARYING_VECTORS: 0,
52
+ MAX_VERTEX_UNIFORM_VECTORS: 0,
53
+ MAX_FRAGMENT_UNIFORM_VECTORS: 0,
54
+ };
55
+
56
+ // Map over all parameters and get them
57
+ const keys = Object.keys(params) as Array<keyof CoreWebGlParameters>;
58
+ keys.forEach((key) => {
59
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment
60
+ params[key] = glw.getParameter(glw[key]);
61
+ });
62
+
63
+ return params;
64
+ }
65
+
66
+ export interface CoreWebGlExtensions {
67
+ ANGLE_instanced_arrays: ANGLE_instanced_arrays | null;
68
+ WEBGL_compressed_texture_s3tc: WEBGL_compressed_texture_s3tc | null;
69
+ WEBGL_compressed_texture_astc: WEBGL_compressed_texture_astc | null;
70
+ WEBGL_compressed_texture_etc: WEBGL_compressed_texture_etc | null;
71
+ WEBGL_compressed_texture_etc1: WEBGL_compressed_texture_etc1 | null;
72
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
73
+ WEBGL_compressed_texture_pvrtc: any | null;
74
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
75
+ WEBKIT_WEBGL_compressed_texture_pvrtc: any | null;
76
+ WEBGL_compressed_texture_s3tc_srgb: WEBGL_compressed_texture_s3tc_srgb | null;
77
+ OES_vertex_array_object: OES_vertex_array_object | null;
78
+ }
79
+
80
+ /**
81
+ * Get device webgl extensions
82
+ * @param glw
83
+ */
84
+ export function getWebGlExtensions(
85
+ glw: WebGlContextWrapper,
86
+ ): CoreWebGlExtensions {
87
+ const extensions: CoreWebGlExtensions = {
88
+ ANGLE_instanced_arrays: null,
89
+ WEBGL_compressed_texture_s3tc: null,
90
+ WEBGL_compressed_texture_astc: null,
91
+ WEBGL_compressed_texture_etc: null,
92
+ WEBGL_compressed_texture_etc1: null,
93
+ WEBGL_compressed_texture_pvrtc: null,
94
+ WEBKIT_WEBGL_compressed_texture_pvrtc: null,
95
+ WEBGL_compressed_texture_s3tc_srgb: null,
96
+ OES_vertex_array_object: null,
97
+ };
98
+
99
+ // Map over all extensions and get them
100
+ const keys = Object.keys(extensions) as Array<keyof CoreWebGlExtensions>;
101
+ keys.forEach((key) => {
102
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment
103
+ extensions[key] = glw.getExtension(key);
104
+ });
105
+
106
+ return extensions;
107
+ }
108
+
109
+ /**
110
+ * Allocate big memory chunk that we
111
+ * can re-use to draw quads
112
+ *
113
+ * @param glw
114
+ * @param size
115
+ */
116
+ export function createIndexBuffer(glw: WebGlContextWrapper, size: number) {
117
+ const maxQuads = ~~(size / 80);
118
+ const indices = new Uint16Array(maxQuads * 6);
119
+
120
+ for (let i = 0, j = 0; i < maxQuads; i += 6, j += 4) {
121
+ indices[i] = j;
122
+ indices[i + 1] = j + 1;
123
+ indices[i + 2] = j + 2;
124
+ indices[i + 3] = j + 2;
125
+ indices[i + 4] = j + 1;
126
+ indices[i + 5] = j + 3;
127
+ }
128
+
129
+ const buffer = glw.createBuffer();
130
+ glw.elementArrayBufferData(buffer, indices, glw.STATIC_DRAW);
131
+ }
132
+
133
+ /**
134
+ * Checks if an object is of type HTMLImageElement.
135
+ * This is used because we cant check for HTMLImageElement directly when the
136
+ * renderer is running in a seperate web worker context.
137
+ *
138
+ * @param obj
139
+ * @returns
140
+ */
141
+ export function isHTMLImageElement(obj: unknown): obj is HTMLImageElement {
142
+ return (
143
+ obj !== null &&
144
+ typeof obj === 'object' &&
145
+ obj.constructor &&
146
+ obj.constructor.name === 'HTMLImageElement'
147
+ );
148
+ }
@@ -1,136 +1,136 @@
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
- import type { WebGlContextWrapper } from '../../../lib/WebGlContextWrapper.js';
21
- import type { WebGlCoreRenderer } from '../WebGlCoreRenderer.js';
22
-
23
- //#region Types
24
- export interface AttributeInfo {
25
- name: string;
26
- size: number;
27
- type: number;
28
- normalized: boolean;
29
- stride: number;
30
- offset: number;
31
- }
32
-
33
- export interface UniformInfo {
34
- name: string;
35
- uniform: keyof UniformMethodMap;
36
- }
37
-
38
- export interface ShaderOptions {
39
- renderer: WebGlCoreRenderer;
40
- attributes: string[];
41
- uniforms: UniformInfo[];
42
- shaderSources?: ShaderProgramSources;
43
- supportsIndexedTextures?: boolean;
44
- webgl1Extensions?: string[];
45
- webgl2Extensions?: string[];
46
- }
47
-
48
- // prettier-ignore
49
- type IsUniformMethod<MethodName, MethodType> = MethodName extends `uniform${string}`
50
- ? // eslint-disable-next-line @typescript-eslint/no-explicit-any
51
- MethodType extends (location: WebGLUniformLocation | null, ...args: any[]) => void
52
- ? true
53
- : false
54
- : false;
55
-
56
- // prettier-ignore
57
- export type UniformMethodMap = {
58
- [Key in keyof WebGLRenderingContext as IsUniformMethod<Key, WebGLRenderingContext[Key]> extends true ? Key : never]: WebGLRenderingContext[Key] extends (
59
- location: WebGLUniformLocation | null,
60
- ...args: infer T
61
- ) => void
62
- ? T
63
- : never;
64
- };
65
-
66
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
67
- type TupleToObject<T extends any[]> = Omit<T, keyof any[]>;
68
-
69
- // Why the below has to be so insane is beyond me
70
- // prettier-ignore
71
- export type UniformTupleToMap<Uniforms extends [...UniformInfo[]]> = {
72
- [Key in keyof TupleToObject<Uniforms> as TupleToObject<Uniforms>[Key] extends {
73
- name: infer K extends string;
74
- }
75
- ? K
76
- : never]: TupleToObject<Uniforms>[Key] extends {
77
- uniform: infer T extends keyof UniformMethodMap;
78
- }
79
- ? UniformMethodMap[T]
80
- : never;
81
- };
82
-
83
- type ShaderSource = string | ((textureUnits: number) => string);
84
-
85
- export interface ShaderProgramSources {
86
- vertex: ShaderSource;
87
- fragment: ShaderSource;
88
- webGl2?: {
89
- vertex: ShaderSource;
90
- fragment: ShaderSource;
91
- };
92
- }
93
-
94
- //#endregion Types
95
-
96
- export function createShader(
97
- glw: WebGlContextWrapper,
98
- type: number,
99
- source: string,
100
- ) {
101
- const shader = glw.createShader(type);
102
- if (!shader) {
103
- throw new Error();
104
- }
105
- glw.shaderSource(shader, source);
106
- glw.compileShader(shader);
107
- const success = glw.getShaderParameter(shader, glw.COMPILE_STATUS);
108
- if (success) {
109
- return shader;
110
- }
111
-
112
- console.log(glw.getShaderInfoLog(shader));
113
- glw.deleteShader(shader);
114
- }
115
-
116
- export function createProgram(
117
- glw: WebGlContextWrapper,
118
- vertexShader: WebGLShader,
119
- fragmentShader: WebGLShader,
120
- ) {
121
- const program = glw.createProgram();
122
- if (!program) {
123
- throw new Error();
124
- }
125
- glw.attachShader(program, vertexShader);
126
- glw.attachShader(program, fragmentShader);
127
- glw.linkProgram(program);
128
- const success = glw.getProgramParameter(program, glw.LINK_STATUS);
129
- if (success) {
130
- return program;
131
- }
132
-
133
- console.log(glw.getProgramInfoLog(program));
134
- glw.deleteProgram(program);
135
- return undefined;
136
- }
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
+ import type { WebGlContextWrapper } from '../../../lib/WebGlContextWrapper.js';
21
+ import type { WebGlCoreRenderer } from '../WebGlCoreRenderer.js';
22
+
23
+ //#region Types
24
+ export interface AttributeInfo {
25
+ name: string;
26
+ size: number;
27
+ type: number;
28
+ normalized: boolean;
29
+ stride: number;
30
+ offset: number;
31
+ }
32
+
33
+ export interface UniformInfo {
34
+ name: string;
35
+ uniform: keyof UniformMethodMap;
36
+ }
37
+
38
+ export interface ShaderOptions {
39
+ renderer: WebGlCoreRenderer;
40
+ attributes: string[];
41
+ uniforms: UniformInfo[];
42
+ shaderSources?: ShaderProgramSources;
43
+ supportsIndexedTextures?: boolean;
44
+ webgl1Extensions?: string[];
45
+ webgl2Extensions?: string[];
46
+ }
47
+
48
+ // prettier-ignore
49
+ type IsUniformMethod<MethodName, MethodType> = MethodName extends `uniform${string}`
50
+ ? // eslint-disable-next-line @typescript-eslint/no-explicit-any
51
+ MethodType extends (location: WebGLUniformLocation | null, ...args: any[]) => void
52
+ ? true
53
+ : false
54
+ : false;
55
+
56
+ // prettier-ignore
57
+ export type UniformMethodMap = {
58
+ [Key in keyof WebGLRenderingContext as IsUniformMethod<Key, WebGLRenderingContext[Key]> extends true ? Key : never]: WebGLRenderingContext[Key] extends (
59
+ location: WebGLUniformLocation | null,
60
+ ...args: infer T
61
+ ) => void
62
+ ? T
63
+ : never;
64
+ };
65
+
66
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
67
+ type TupleToObject<T extends any[]> = Omit<T, keyof any[]>;
68
+
69
+ // Why the below has to be so insane is beyond me
70
+ // prettier-ignore
71
+ export type UniformTupleToMap<Uniforms extends [...UniformInfo[]]> = {
72
+ [Key in keyof TupleToObject<Uniforms> as TupleToObject<Uniforms>[Key] extends {
73
+ name: infer K extends string;
74
+ }
75
+ ? K
76
+ : never]: TupleToObject<Uniforms>[Key] extends {
77
+ uniform: infer T extends keyof UniformMethodMap;
78
+ }
79
+ ? UniformMethodMap[T]
80
+ : never;
81
+ };
82
+
83
+ type ShaderSource = string | ((textureUnits: number) => string);
84
+
85
+ export interface ShaderProgramSources {
86
+ vertex: ShaderSource;
87
+ fragment: ShaderSource;
88
+ webGl2?: {
89
+ vertex: ShaderSource;
90
+ fragment: ShaderSource;
91
+ };
92
+ }
93
+
94
+ //#endregion Types
95
+
96
+ export function createShader(
97
+ glw: WebGlContextWrapper,
98
+ type: number,
99
+ source: string,
100
+ ) {
101
+ const shader = glw.createShader(type);
102
+ if (!shader) {
103
+ throw new Error();
104
+ }
105
+ glw.shaderSource(shader, source);
106
+ glw.compileShader(shader);
107
+ const success = glw.getShaderParameter(shader, glw.COMPILE_STATUS);
108
+ if (success) {
109
+ return shader;
110
+ }
111
+
112
+ console.log(glw.getShaderInfoLog(shader));
113
+ glw.deleteShader(shader);
114
+ }
115
+
116
+ export function createProgram(
117
+ glw: WebGlContextWrapper,
118
+ vertexShader: WebGLShader,
119
+ fragmentShader: WebGLShader,
120
+ ) {
121
+ const program = glw.createProgram();
122
+ if (!program) {
123
+ throw new Error();
124
+ }
125
+ glw.attachShader(program, vertexShader);
126
+ glw.attachShader(program, fragmentShader);
127
+ glw.linkProgram(program);
128
+ const success = glw.getProgramParameter(program, glw.LINK_STATUS);
129
+ if (success) {
130
+ return program;
131
+ }
132
+
133
+ console.log(glw.getProgramInfoLog(program));
134
+ glw.deleteProgram(program);
135
+ return undefined;
136
+ }