@lightningjs/renderer 0.7.5 → 0.8.0

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 (252) hide show
  1. package/LICENSE +202 -202
  2. package/NOTICE +3 -3
  3. package/README.md +233 -221
  4. package/dist/src/common/CommonTypes.d.ts +12 -0
  5. package/dist/src/core/CoreNode.d.ts +83 -9
  6. package/dist/src/core/CoreNode.js +232 -44
  7. package/dist/src/core/CoreNode.js.map +1 -1
  8. package/dist/src/core/CoreTextNode.d.ts +6 -1
  9. package/dist/src/core/CoreTextNode.js +33 -20
  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 +11 -2
  13. package/dist/src/core/CoreTextureManager.js.map +1 -1
  14. package/dist/src/core/Stage.d.ts +6 -0
  15. package/dist/src/core/Stage.js +16 -1
  16. package/dist/src/core/Stage.js.map +1 -1
  17. package/dist/src/core/TextureMemoryManager.d.ts +12 -0
  18. package/dist/src/core/TextureMemoryManager.js +42 -0
  19. package/dist/src/core/TextureMemoryManager.js.map +1 -0
  20. package/dist/src/core/lib/ImageWorker.d.ts +0 -1
  21. package/dist/src/core/lib/ImageWorker.js +55 -40
  22. package/dist/src/core/lib/ImageWorker.js.map +1 -1
  23. package/dist/src/core/lib/RenderCoords.d.ts +13 -0
  24. package/dist/src/core/lib/RenderCoords.js +63 -0
  25. package/dist/src/core/lib/RenderCoords.js.map +1 -0
  26. package/dist/src/core/lib/WebGlContext.d.ts +414 -0
  27. package/dist/src/core/lib/WebGlContext.js +640 -0
  28. package/dist/src/core/lib/WebGlContext.js.map +1 -0
  29. package/dist/src/core/lib/utils.d.ts +1 -0
  30. package/dist/src/core/lib/utils.js +6 -0
  31. package/dist/src/core/lib/utils.js.map +1 -1
  32. package/dist/src/core/platform.js +8 -0
  33. package/dist/src/core/platform.js.map +1 -1
  34. package/dist/src/core/renderers/CoreContextTexture.d.ts +5 -1
  35. package/dist/src/core/renderers/CoreContextTexture.js +3 -1
  36. package/dist/src/core/renderers/CoreContextTexture.js.map +1 -1
  37. package/dist/src/core/renderers/webgl/WebGlCoreCtxSubTexture.d.ts +2 -1
  38. package/dist/src/core/renderers/webgl/WebGlCoreCtxSubTexture.js +2 -2
  39. package/dist/src/core/renderers/webgl/WebGlCoreCtxSubTexture.js.map +1 -1
  40. package/dist/src/core/renderers/webgl/WebGlCoreCtxTexture.d.ts +3 -1
  41. package/dist/src/core/renderers/webgl/WebGlCoreCtxTexture.js +26 -6
  42. package/dist/src/core/renderers/webgl/WebGlCoreCtxTexture.js.map +1 -1
  43. package/dist/src/core/renderers/webgl/WebGlCoreRenderer.d.ts +3 -0
  44. package/dist/src/core/renderers/webgl/WebGlCoreRenderer.js +4 -2
  45. package/dist/src/core/renderers/webgl/WebGlCoreRenderer.js.map +1 -1
  46. package/dist/src/core/renderers/webgl/internal/RendererUtils.d.ts +9 -0
  47. package/dist/src/core/renderers/webgl/internal/RendererUtils.js +14 -0
  48. package/dist/src/core/renderers/webgl/internal/RendererUtils.js.map +1 -1
  49. package/dist/src/core/renderers/webgl/shaders/DefaultShader.js +47 -47
  50. package/dist/src/core/renderers/webgl/shaders/DefaultShaderBatched.js +61 -61
  51. package/dist/src/core/renderers/webgl/shaders/DynamicShader.js +93 -93
  52. package/dist/src/core/renderers/webgl/shaders/RoundedRectangle.js +63 -63
  53. package/dist/src/core/renderers/webgl/shaders/SdfShader.js +49 -49
  54. package/dist/src/core/renderers/webgl/shaders/effects/BorderBottomEffect.js +15 -15
  55. package/dist/src/core/renderers/webgl/shaders/effects/BorderEffect.js +5 -5
  56. package/dist/src/core/renderers/webgl/shaders/effects/BorderLeftEffect.js +15 -15
  57. package/dist/src/core/renderers/webgl/shaders/effects/BorderRightEffect.js +15 -15
  58. package/dist/src/core/renderers/webgl/shaders/effects/BorderTopEffect.js +15 -15
  59. package/dist/src/core/renderers/webgl/shaders/effects/FadeOutEffect.js +42 -42
  60. package/dist/src/core/renderers/webgl/shaders/effects/GlitchEffect.js +44 -44
  61. package/dist/src/core/renderers/webgl/shaders/effects/GrayscaleEffect.js +3 -3
  62. package/dist/src/core/renderers/webgl/shaders/effects/LinearGradientEffect.js +44 -57
  63. package/dist/src/core/renderers/webgl/shaders/effects/LinearGradientEffect.js.map +1 -1
  64. package/dist/src/core/renderers/webgl/shaders/effects/RadialGradientEffect.d.ts +1 -0
  65. package/dist/src/core/renderers/webgl/shaders/effects/RadialGradientEffect.js +33 -39
  66. package/dist/src/core/renderers/webgl/shaders/effects/RadialGradientEffect.js.map +1 -1
  67. package/dist/src/core/renderers/webgl/shaders/effects/RadialProgressEffect.js +37 -37
  68. package/dist/src/core/renderers/webgl/shaders/effects/RadiusEffect.js +19 -19
  69. package/dist/src/core/scene/Scene.d.ts +59 -0
  70. package/dist/src/core/scene/Scene.js +106 -0
  71. package/dist/src/core/scene/Scene.js.map +1 -0
  72. package/dist/src/core/text-rendering/TrFontManager.js +30 -25
  73. package/dist/src/core/text-rendering/TrFontManager.js.map +1 -1
  74. package/dist/src/core/text-rendering/renderers/CanvasTextRenderer.d.ts +2 -0
  75. package/dist/src/core/text-rendering/renderers/CanvasTextRenderer.js +26 -2
  76. package/dist/src/core/text-rendering/renderers/CanvasTextRenderer.js.map +1 -1
  77. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.d.ts +8 -0
  78. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.js +34 -6
  79. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.js.map +1 -1
  80. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/findNearestMultiple.d.ts +8 -0
  81. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/findNearestMultiple.js +29 -0
  82. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/findNearestMultiple.js.map +1 -0
  83. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText.js +1 -3
  84. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText.js.map +1 -1
  85. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText2/SdfBufferHelper.d.ts +19 -0
  86. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText2/SdfBufferHelper.js +84 -0
  87. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText2/SdfBufferHelper.js.map +1 -0
  88. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText2/layoutLine.d.ts +8 -0
  89. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText2/layoutLine.js +40 -0
  90. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText2/layoutLine.js.map +1 -0
  91. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText2/layoutText2.d.ts +2 -0
  92. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText2/layoutText2.js +41 -0
  93. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText2/layoutText2.js.map +1 -0
  94. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText2/utils.d.ts +1 -0
  95. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText2/utils.js +4 -0
  96. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText2/utils.js.map +1 -0
  97. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText2.d.ts +1 -0
  98. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText2.js +2 -0
  99. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText2.js.map +1 -0
  100. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/makeRenderWindow.d.ts +20 -0
  101. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/makeRenderWindow.js +55 -0
  102. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/makeRenderWindow.js.map +1 -0
  103. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/roundUpToMultiple.d.ts +9 -0
  104. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/roundUpToMultiple.js +32 -0
  105. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/roundUpToMultiple.js.map +1 -0
  106. package/dist/src/core/text-rendering/renderers/TextRenderer.d.ts +31 -0
  107. package/dist/src/core/text-rendering/renderers/TextRenderer.js +26 -0
  108. package/dist/src/core/text-rendering/renderers/TextRenderer.js.map +1 -1
  109. package/dist/src/core/textures/ImageTexture.js +16 -2
  110. package/dist/src/core/textures/ImageTexture.js.map +1 -1
  111. package/dist/src/core/textures/Texture.d.ts +27 -2
  112. package/dist/src/core/textures/Texture.js +30 -1
  113. package/dist/src/core/textures/Texture.js.map +1 -1
  114. package/dist/src/core/utils.d.ts +1 -1
  115. package/dist/src/main-api/ICoreDriver.d.ts +1 -0
  116. package/dist/src/main-api/Inspector.js +2 -1
  117. package/dist/src/main-api/Inspector.js.map +1 -1
  118. package/dist/src/main-api/RendererMain.d.ts +15 -0
  119. package/dist/src/main-api/RendererMain.js +7 -1
  120. package/dist/src/main-api/RendererMain.js.map +1 -1
  121. package/dist/src/render-drivers/main/MainCoreDriver.d.ts +1 -0
  122. package/dist/src/render-drivers/main/MainCoreDriver.js +8 -0
  123. package/dist/src/render-drivers/main/MainCoreDriver.js.map +1 -1
  124. package/dist/src/render-drivers/main/MainOnlyNode.d.ts +5 -0
  125. package/dist/src/render-drivers/main/MainOnlyNode.js +26 -0
  126. package/dist/src/render-drivers/main/MainOnlyNode.js.map +1 -1
  127. package/dist/src/render-drivers/threadx/ThreadXCoreDriver.js +2 -0
  128. package/dist/src/render-drivers/threadx/ThreadXCoreDriver.js.map +1 -1
  129. package/dist/src/render-drivers/threadx/ThreadXRendererMessage.d.ts +2 -0
  130. package/dist/src/render-drivers/threadx/ThreadXRendererMessage.js.map +1 -1
  131. package/dist/src/render-drivers/threadx/worker/ThreadXRendererNode.js +3 -0
  132. package/dist/src/render-drivers/threadx/worker/ThreadXRendererNode.js.map +1 -1
  133. package/dist/src/render-drivers/threadx/worker/renderer.js +2 -0
  134. package/dist/src/render-drivers/threadx/worker/renderer.js.map +1 -1
  135. package/dist/src/utils.d.ts +6 -0
  136. package/dist/src/utils.js +9 -1
  137. package/dist/src/utils.js.map +1 -1
  138. package/dist/tsconfig.dist.tsbuildinfo +1 -1
  139. package/exports/core-api.ts +102 -102
  140. package/exports/main-api.ts +60 -60
  141. package/exports/utils.ts +41 -41
  142. package/package.json +1 -1
  143. package/scripts/please-use-pnpm.js +13 -13
  144. package/src/common/CommonTypes.ts +132 -113
  145. package/src/common/EventEmitter.ts +77 -77
  146. package/src/common/IAnimationController.ts +29 -29
  147. package/src/core/CoreExtension.ts +32 -32
  148. package/src/core/CoreNode.ts +1199 -955
  149. package/src/core/CoreShaderManager.ts +243 -243
  150. package/src/core/CoreTextNode.ts +400 -391
  151. package/src/core/CoreTextureManager.ts +339 -326
  152. package/src/core/Stage.ts +375 -354
  153. package/src/core/TextureMemoryManager.ts +66 -0
  154. package/src/core/animations/AnimationManager.ts +38 -38
  155. package/src/core/animations/CoreAnimation.ts +181 -181
  156. package/src/core/animations/CoreAnimationController.ts +148 -148
  157. package/src/core/lib/ContextSpy.ts +41 -41
  158. package/src/core/lib/ImageWorker.ts +149 -135
  159. package/src/core/lib/Matrix3d.ts +290 -290
  160. package/src/core/lib/RenderCoords.ts +86 -0
  161. package/src/core/lib/WebGlContextWrapper.ts +992 -992
  162. package/src/core/lib/textureCompression.ts +152 -152
  163. package/src/core/lib/utils.ts +250 -241
  164. package/src/core/platform.ts +54 -46
  165. package/src/core/renderers/CoreContextTexture.ts +35 -30
  166. package/src/core/renderers/CoreRenderOp.ts +22 -22
  167. package/src/core/renderers/CoreRenderer.ts +63 -63
  168. package/src/core/renderers/CoreShader.ts +41 -41
  169. package/src/core/renderers/webgl/WebGlCoreCtxSubTexture.ts +42 -37
  170. package/src/core/renderers/webgl/WebGlCoreCtxTexture.ts +261 -230
  171. package/src/core/renderers/webgl/WebGlCoreRenderOp.ts +107 -107
  172. package/src/core/renderers/webgl/WebGlCoreRenderer.ts +528 -520
  173. package/src/core/renderers/webgl/WebGlCoreShader.ts +337 -337
  174. package/src/core/renderers/webgl/internal/BufferCollection.ts +54 -54
  175. package/src/core/renderers/webgl/internal/RendererUtils.ts +148 -131
  176. package/src/core/renderers/webgl/internal/ShaderUtils.ts +136 -136
  177. package/src/core/renderers/webgl/internal/WebGlUtils.ts +35 -35
  178. package/src/core/renderers/webgl/shaders/DefaultShader.ts +95 -95
  179. package/src/core/renderers/webgl/shaders/DefaultShaderBatched.ts +132 -132
  180. package/src/core/renderers/webgl/shaders/DynamicShader.ts +474 -474
  181. package/src/core/renderers/webgl/shaders/RoundedRectangle.ts +161 -161
  182. package/src/core/renderers/webgl/shaders/SdfShader.ts +174 -174
  183. package/src/core/renderers/webgl/shaders/effects/BorderBottomEffect.ts +101 -101
  184. package/src/core/renderers/webgl/shaders/effects/BorderEffect.ts +86 -86
  185. package/src/core/renderers/webgl/shaders/effects/BorderLeftEffect.ts +101 -101
  186. package/src/core/renderers/webgl/shaders/effects/BorderRightEffect.ts +101 -101
  187. package/src/core/renderers/webgl/shaders/effects/BorderTopEffect.ts +101 -101
  188. package/src/core/renderers/webgl/shaders/effects/EffectUtils.ts +33 -33
  189. package/src/core/renderers/webgl/shaders/effects/FadeOutEffect.ts +135 -135
  190. package/src/core/renderers/webgl/shaders/effects/GlitchEffect.ts +145 -145
  191. package/src/core/renderers/webgl/shaders/effects/GrayscaleEffect.ts +67 -67
  192. package/src/core/renderers/webgl/shaders/effects/LinearGradientEffect.ts +160 -176
  193. package/src/core/renderers/webgl/shaders/effects/RadialGradientEffect.ts +153 -159
  194. package/src/core/renderers/webgl/shaders/effects/RadialProgressEffect.ts +186 -186
  195. package/src/core/renderers/webgl/shaders/effects/RadiusEffect.ts +121 -121
  196. package/src/core/renderers/webgl/shaders/effects/ShaderEffect.ts +114 -114
  197. package/src/core/text-rendering/TextTextureRendererUtils.ts +189 -189
  198. package/src/core/text-rendering/TrFontManager.ts +170 -166
  199. package/src/core/text-rendering/font-face-types/SdfTrFontFace/SdfTrFontFace.ts +141 -141
  200. package/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/FontShaper.ts +139 -139
  201. package/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/SdfFontShaper.test.ts +173 -173
  202. package/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/SdfFontShaper.ts +169 -169
  203. package/src/core/text-rendering/font-face-types/TrFontFace.ts +105 -105
  204. package/src/core/text-rendering/font-face-types/WebTrFontFace.ts +77 -77
  205. package/src/core/text-rendering/renderers/CanvasTextRenderer.ts +780 -751
  206. package/src/core/text-rendering/renderers/LightningTextTextureRenderer.ts +741 -741
  207. package/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.ts +812 -778
  208. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/PeekableGenerator.test.ts +48 -48
  209. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/PeekableGenerator.ts +66 -66
  210. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/SpecialCodepoints.ts +52 -52
  211. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/constants.ts +32 -32
  212. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/getStartConditions.ts +84 -84
  213. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/getUnicodeCodepoints.test.ts +133 -133
  214. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/getUnicodeCodepoints.ts +38 -38
  215. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText.ts +391 -393
  216. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/measureText.test.ts +49 -49
  217. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/measureText.ts +51 -51
  218. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/setRenderWindow.test.ts +205 -205
  219. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/setRenderWindow.ts +93 -93
  220. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/util.ts +40 -40
  221. package/src/core/text-rendering/renderers/TextRenderer.ts +548 -504
  222. package/src/core/textures/ColorTexture.ts +86 -86
  223. package/src/core/textures/ImageTexture.ts +154 -140
  224. package/src/core/textures/NoiseTexture.ts +96 -96
  225. package/src/core/textures/SubTexture.ts +143 -143
  226. package/src/core/textures/Texture.ts +261 -218
  227. package/src/core/utils.ts +224 -224
  228. package/src/env.d.ts +7 -7
  229. package/src/main-api/ICoreDriver.ts +68 -66
  230. package/src/main-api/INode.ts +499 -499
  231. package/src/main-api/Inspector.ts +440 -439
  232. package/src/main-api/RendererMain.ts +676 -652
  233. package/src/main-api/texture-usage-trackers/FinalizationRegistryTextureUsageTracker.ts +45 -45
  234. package/src/main-api/texture-usage-trackers/ManualCountTextureUsageTracker.ts +154 -154
  235. package/src/main-api/texture-usage-trackers/TextureUsageTracker.ts +54 -54
  236. package/src/render-drivers/main/MainCoreDriver.ts +158 -148
  237. package/src/render-drivers/main/MainOnlyNode.ts +500 -466
  238. package/src/render-drivers/main/MainOnlyTextNode.ts +261 -261
  239. package/src/render-drivers/threadx/NodeStruct.ts +300 -300
  240. package/src/render-drivers/threadx/SharedNode.ts +97 -97
  241. package/src/render-drivers/threadx/TextNodeStruct.ts +211 -211
  242. package/src/render-drivers/threadx/ThreadXCoreDriver.ts +287 -285
  243. package/src/render-drivers/threadx/ThreadXMainAnimationController.ts +99 -99
  244. package/src/render-drivers/threadx/ThreadXMainNode.ts +192 -192
  245. package/src/render-drivers/threadx/ThreadXMainTextNode.ts +85 -85
  246. package/src/render-drivers/threadx/ThreadXRendererMessage.ts +112 -110
  247. package/src/render-drivers/threadx/worker/ThreadXRendererNode.ts +245 -238
  248. package/src/render-drivers/threadx/worker/ThreadXRendererTextNode.ts +149 -149
  249. package/src/render-drivers/threadx/worker/renderer.ts +153 -151
  250. package/src/render-drivers/utils.ts +97 -97
  251. package/src/utils.ts +216 -207
  252. package/COPYING +0 -1
@@ -1,326 +1,339 @@
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 { assertTruthy } from '../utils.js';
21
- import { ImageWorkerManager } from './lib/ImageWorker.js';
22
- import type { CoreContextTexture } from './renderers/CoreContextTexture.js';
23
- import type { CoreRenderer } from './renderers/CoreRenderer.js';
24
- import { ColorTexture } from './textures/ColorTexture.js';
25
- import { ImageTexture } from './textures/ImageTexture.js';
26
- import { NoiseTexture } from './textures/NoiseTexture.js';
27
- import { SubTexture } from './textures/SubTexture.js';
28
- import type { Texture } from './textures/Texture.js';
29
-
30
- /**
31
- * Augmentable map of texture types
32
- *
33
- * @remarks
34
- * This interface can be augmented by other modules/apps to add additional
35
- * texture types. The ones included directly here are the ones that are
36
- * included in the core library.
37
- */
38
- export interface TextureMap {
39
- ColorTexture: typeof ColorTexture;
40
- ImageTexture: typeof ImageTexture;
41
- NoiseTexture: typeof NoiseTexture;
42
- SubTexture: typeof SubTexture;
43
- }
44
-
45
- export type ExtractProps<Type> = Type extends { z$__type__Props: infer Props }
46
- ? Props
47
- : never;
48
-
49
- /**
50
- * Contains information about the texture manager's internal state
51
- * for debugging purposes.
52
- */
53
- export interface TextureManagerDebugInfo {
54
- keyCacheSize: number;
55
- idCacheSize: number;
56
- }
57
-
58
- /**
59
- * Universal options for all texture types
60
- *
61
- * @remarks
62
- * Texture Options provide a way to specify options that are relevant to the
63
- * texture loading process (including caching) and specifically for how a
64
- * texture is rendered within a specific Node (or set of Nodes).
65
- *
66
- * They are not used in determining the cache key for a texture (except if
67
- * the `cacheKey` option is provided explicitly to oveerride the default
68
- * cache key for the texture instance) nor are they stored/referenced within
69
- * the texture instance itself. Instead, the options are stored/referenced
70
- * within individual Nodes. So a single texture instance can be used in
71
- * multiple Nodes each using a different set of options.
72
- */
73
- export interface TextureOptions {
74
- /**
75
- * Preload the texture immediately even if it's not being rendered to the
76
- * screen.
77
- *
78
- * @remarks
79
- * This allows the texture to be used immediately without any delay when it
80
- * is first needed for rendering. Otherwise the loading process will start
81
- * when the texture is first rendered, which may cause a delay in that texture
82
- * being shown properly.
83
- *
84
- * @defaultValue `false`
85
- */
86
- preload?: boolean;
87
-
88
- /**
89
- * ID to use for this texture.
90
- *
91
- * @remarks
92
- * This is for internal use only as an optimization.
93
- *
94
- * @privateRemarks
95
- * This is used to avoid having to look up the texture in the texture cache
96
- * by its cache key. Theoretically this should be faster.
97
- *
98
- * @defaultValue Automatically generated
99
- */
100
- id?: number;
101
-
102
- /**
103
- * Cache key to use for this texture
104
- *
105
- * @remarks
106
- * If this is set, the texture will be cached using this key. If a texture
107
- * with the same key is already cached, it will be returned instead of
108
- * creating a new texture.
109
- *
110
- * If this is not set (undefined), it will be automatically generated via
111
- * the specified `Texture`'s `makeCacheKey()` method.
112
- *
113
- * @defaultValue Automatically generated via `Texture.makeCacheKey()`
114
- */
115
- cacheKey?: string | false;
116
-
117
- /**
118
- * Flip the texture horizontally when rendering
119
- *
120
- * @defaultValue `false`
121
- */
122
- flipX?: boolean;
123
-
124
- /**
125
- * Flip the texture vertically when rendering
126
- *
127
- * @defaultValue `false`
128
- */
129
- flipY?: boolean;
130
- }
131
-
132
- export class CoreTextureManager {
133
- /**
134
- * Amount of used memory defined in pixels
135
- */
136
- usedMemory = 0;
137
-
138
- txConstructors: Partial<TextureMap> = {};
139
-
140
- textureKeyCache: Map<string, Texture> = new Map();
141
- textureIdCache: Map<number, Texture> = new Map();
142
-
143
- ctxTextureCache: WeakMap<Texture, CoreContextTexture> = new WeakMap();
144
- textureRefCountMap: WeakMap<
145
- Texture,
146
- { cacheKey: string | false; count: number }
147
- > = new WeakMap();
148
- imageWorkerManager: ImageWorkerManager;
149
- /**
150
- * Renderer that this texture manager is associated with
151
- *
152
- * @remarks
153
- * This MUST be set before the texture manager is used. Otherwise errors
154
- * will occur when using the texture manager.
155
- */
156
- renderer!: CoreRenderer;
157
-
158
- constructor(numImageWorkers: number) {
159
- // Register default known texture types
160
- this.imageWorkerManager = new ImageWorkerManager(numImageWorkers);
161
- this.registerTextureType('ImageTexture', ImageTexture);
162
- this.registerTextureType('ColorTexture', ColorTexture);
163
- this.registerTextureType('NoiseTexture', NoiseTexture);
164
- this.registerTextureType('SubTexture', SubTexture);
165
- }
166
-
167
- registerTextureType<Type extends keyof TextureMap>(
168
- textureType: Type,
169
- textureClass: TextureMap[Type],
170
- ): void {
171
- this.txConstructors[textureType] = textureClass;
172
- }
173
-
174
- loadTexture<Type extends keyof TextureMap>(
175
- textureType: Type,
176
- props: ExtractProps<TextureMap[Type]>,
177
- options: TextureOptions | null = null,
178
- ): InstanceType<TextureMap[Type]> {
179
- const TextureClass = this.txConstructors[textureType];
180
- if (!TextureClass) {
181
- throw new Error(`Texture type "${textureType}" is not registered`);
182
- }
183
- let texture: Texture | undefined;
184
- // If an ID is specified, try to get the texture from the ID cache first
185
- if (options?.id !== undefined && this.textureIdCache.has(options.id)) {
186
- // console.log('Getting texture by texture desc ID', options.id);
187
- // eslint-disable-next-line @typescript-eslint/no-non-null-assertion
188
- texture = this.textureIdCache.get(options.id)!;
189
- }
190
- // If the texture is not found in the ID cache, try to get it from the key cache
191
- if (!texture) {
192
- const descId = options?.id;
193
- const cacheKey =
194
- options?.cacheKey ?? TextureClass.makeCacheKey(props as any);
195
- if (cacheKey && this.textureKeyCache.has(cacheKey)) {
196
- // console.log('Getting texture by cache key', cacheKey);
197
- // eslint-disable-next-line @typescript-eslint/no-non-null-assertion
198
- texture = this.textureKeyCache.get(cacheKey)!;
199
- } else {
200
- // eslint-disable-next-line @typescript-eslint/no-unsafe-argument, @typescript-eslint/no-explicit-any
201
- texture = new TextureClass(this, props as any);
202
- }
203
- if (descId) {
204
- this.addTextureIdToCache(descId, cacheKey, texture);
205
- }
206
- }
207
- if (options?.preload) {
208
- const ctxTx = this.getCtxTexture(texture);
209
- ctxTx.load();
210
- }
211
- return texture as InstanceType<TextureMap[Type]>;
212
- }
213
-
214
- /**
215
- * Add a `Texture` to the texture cache by its texture desc ID and cache key
216
- *
217
- * @remarks
218
- * This is used internally by the `CoreTextureManager` to cache textures
219
- * when they are created.
220
- *
221
- * It handles updating the texture ID cache, texture key cache, and texture
222
- * reference count map.
223
- *
224
- * @param textureDescId
225
- * @param cacheKey
226
- * @param texture
227
- */
228
- private addTextureIdToCache(
229
- textureDescId: number,
230
- cacheKey: string | false,
231
- texture: Texture,
232
- ): void {
233
- const { textureIdCache, textureRefCountMap } = this;
234
- textureIdCache.set(textureDescId, texture);
235
- if (textureRefCountMap.has(texture)) {
236
- // eslint-disable-next-line @typescript-eslint/no-non-null-assertion
237
- textureRefCountMap.get(texture)!.count++;
238
- } else {
239
- textureRefCountMap.set(texture, { cacheKey, count: 1 });
240
- if (cacheKey) {
241
- this.textureKeyCache.set(cacheKey, texture);
242
- }
243
- }
244
- }
245
-
246
- /**
247
- * Remove a `Texture` from the texture cache by its texture desc ID
248
- *
249
- * @remarks
250
- * This is called externally by when we know (at least reasonably well) that
251
- * the `TextureRef` in the Main API space has been is no longer used. This
252
- * allows us to remove the `Texture` from the Usage Cache so that it can be
253
- * garbage collected as well.
254
- *
255
- * @param textureDescId
256
- */
257
- removeTextureIdFromCache(textureDescId: number): void {
258
- const { textureIdCache, textureRefCountMap } = this;
259
- const texture = textureIdCache.get(textureDescId);
260
- if (!texture) {
261
- // Sometimes a texture is removed from the cache before it ever gets
262
- // added to the cache. This is fine and not an error.
263
- return;
264
- }
265
- textureIdCache.delete(textureDescId);
266
- if (textureRefCountMap.has(texture)) {
267
- const refCountObj = textureRefCountMap.get(texture);
268
- assertTruthy(refCountObj);
269
- refCountObj.count--;
270
- if (refCountObj.count === 0) {
271
- textureRefCountMap.delete(texture);
272
- // If the texture is not referenced anywhere else, remove it from the key cache
273
- // as well.
274
- // This should allow the `Texture` instance to be garbage collected.
275
- if (refCountObj.cacheKey) {
276
- this.textureKeyCache.delete(refCountObj.cacheKey);
277
- }
278
- }
279
- }
280
- }
281
-
282
- /**
283
- * Get an object containing debug information about the texture manager.
284
- *
285
- * @returns
286
- */
287
- getDebugInfo(): TextureManagerDebugInfo {
288
- // const textureSet = new Set<Texture>();
289
- // for (const texture of this.textureIdCache.values()) {
290
- // textureSet.add(texture);
291
- // }
292
- // for (const texture of this.textureKeyCache.values()) {
293
- // textureSet.add(texture);
294
- // }
295
- // TODO: Output number of bytes used by textures
296
- return {
297
- keyCacheSize: this.textureKeyCache.size,
298
- idCacheSize: this.textureIdCache.size,
299
- };
300
- }
301
-
302
- /**
303
- * Get a CoreContextTexture for the given Texture source.
304
- *
305
- * @remarks
306
- * If the texture source already has an allocated CoreContextTexture, it will be
307
- * returned from the cache. Otherwise, a new CoreContextTexture will be created
308
- * and cached.
309
- *
310
- * ContextTextures are stored in a WeakMap, so they will be garbage collected
311
- * when the Texture source is no longer referenced.
312
- *
313
- * @param textureSource
314
- * @returns
315
- */
316
- getCtxTexture(textureSource: Texture): CoreContextTexture {
317
- if (this.ctxTextureCache.has(textureSource)) {
318
- // eslint-disable-next-line @typescript-eslint/no-non-null-assertion
319
- return this.ctxTextureCache.get(textureSource)!;
320
- }
321
- const texture = this.renderer.createCtxTexture(textureSource);
322
-
323
- this.ctxTextureCache.set(textureSource, texture);
324
- return texture;
325
- }
326
- }
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 { assertTruthy } from '../utils.js';
21
+ import { ImageWorkerManager } from './lib/ImageWorker.js';
22
+ import type { CoreContextTexture } from './renderers/CoreContextTexture.js';
23
+ import type { CoreRenderer } from './renderers/CoreRenderer.js';
24
+ import { ColorTexture } from './textures/ColorTexture.js';
25
+ import { ImageTexture } from './textures/ImageTexture.js';
26
+ import { NoiseTexture } from './textures/NoiseTexture.js';
27
+ import { SubTexture } from './textures/SubTexture.js';
28
+ import type { Texture } from './textures/Texture.js';
29
+
30
+ /**
31
+ * Augmentable map of texture types
32
+ *
33
+ * @remarks
34
+ * This interface can be augmented by other modules/apps to add additional
35
+ * texture types. The ones included directly here are the ones that are
36
+ * included in the core library.
37
+ */
38
+ export interface TextureMap {
39
+ ColorTexture: typeof ColorTexture;
40
+ ImageTexture: typeof ImageTexture;
41
+ NoiseTexture: typeof NoiseTexture;
42
+ SubTexture: typeof SubTexture;
43
+ }
44
+
45
+ export type ExtractProps<Type> = Type extends { z$__type__Props: infer Props }
46
+ ? Props
47
+ : never;
48
+
49
+ /**
50
+ * Contains information about the texture manager's internal state
51
+ * for debugging purposes.
52
+ */
53
+ export interface TextureManagerDebugInfo {
54
+ keyCacheSize: number;
55
+ idCacheSize: number;
56
+ }
57
+
58
+ /**
59
+ * Universal options for all texture types
60
+ *
61
+ * @remarks
62
+ * Texture Options provide a way to specify options that are relevant to the
63
+ * texture loading process (including caching) and specifically for how a
64
+ * texture is rendered within a specific Node (or set of Nodes).
65
+ *
66
+ * They are not used in determining the cache key for a texture (except if
67
+ * the `cacheKey` option is provided explicitly to oveerride the default
68
+ * cache key for the texture instance) nor are they stored/referenced within
69
+ * the texture instance itself. Instead, the options are stored/referenced
70
+ * within individual Nodes. So a single texture instance can be used in
71
+ * multiple Nodes each using a different set of options.
72
+ */
73
+ export interface TextureOptions {
74
+ /**
75
+ * Preload the texture immediately even if it's not being rendered to the
76
+ * screen.
77
+ *
78
+ * @remarks
79
+ * This allows the texture to be used immediately without any delay when it
80
+ * is first needed for rendering. Otherwise the loading process will start
81
+ * when the texture is first rendered, which may cause a delay in that texture
82
+ * being shown properly.
83
+ *
84
+ * @defaultValue `false`
85
+ */
86
+ preload?: boolean;
87
+
88
+ /**
89
+ * ID to use for this texture.
90
+ *
91
+ * @remarks
92
+ * This is for internal use only as an optimization.
93
+ *
94
+ * @privateRemarks
95
+ * This is used to avoid having to look up the texture in the texture cache
96
+ * by its cache key. Theoretically this should be faster.
97
+ *
98
+ * @defaultValue Automatically generated
99
+ */
100
+ id?: number;
101
+
102
+ /**
103
+ * Cache key to use for this texture
104
+ *
105
+ * @remarks
106
+ * If this is set, the texture will be cached using this key. If a texture
107
+ * with the same key is already cached, it will be returned instead of
108
+ * creating a new texture.
109
+ *
110
+ * If this is not set (undefined), it will be automatically generated via
111
+ * the specified `Texture`'s `makeCacheKey()` method.
112
+ *
113
+ * @defaultValue Automatically generated via `Texture.makeCacheKey()`
114
+ */
115
+ cacheKey?: string | false;
116
+
117
+ /**
118
+ * Flip the texture horizontally when rendering
119
+ *
120
+ * @defaultValue `false`
121
+ */
122
+ flipX?: boolean;
123
+
124
+ /**
125
+ * Flip the texture vertically when rendering
126
+ *
127
+ * @defaultValue `false`
128
+ */
129
+ flipY?: boolean;
130
+ }
131
+
132
+ export class CoreTextureManager {
133
+ /**
134
+ * Amount of used memory defined in pixels
135
+ */
136
+ usedMemory = 0;
137
+
138
+ txConstructors: Partial<TextureMap> = {};
139
+
140
+ textureKeyCache: Map<string, Texture> = new Map();
141
+ textureIdCache: Map<number, Texture> = new Map();
142
+
143
+ ctxTextureCache: WeakMap<Texture, CoreContextTexture> = new WeakMap();
144
+ textureRefCountMap: WeakMap<
145
+ Texture,
146
+ { cacheKey: string | false; count: number }
147
+ > = new WeakMap();
148
+ imageWorkerManager: ImageWorkerManager | null = null;
149
+ hasCreateImageBitmap = !!self.createImageBitmap;
150
+ hasWorker = !!self.Worker;
151
+ /**
152
+ * Renderer that this texture manager is associated with
153
+ *
154
+ * @remarks
155
+ * This MUST be set before the texture manager is used. Otherwise errors
156
+ * will occur when using the texture manager.
157
+ */
158
+ renderer!: CoreRenderer;
159
+
160
+ constructor(numImageWorkers: number) {
161
+ // Register default known texture types
162
+ if (this.hasCreateImageBitmap && this.hasWorker) {
163
+ this.imageWorkerManager = new ImageWorkerManager(numImageWorkers);
164
+ }
165
+
166
+ if (!this.hasCreateImageBitmap) {
167
+ console.warn(
168
+ '[Lightning] createImageBitmap is not supported on this browser. ImageTexture will be slower.',
169
+ );
170
+ }
171
+
172
+ this.registerTextureType('ImageTexture', ImageTexture);
173
+ this.registerTextureType('ColorTexture', ColorTexture);
174
+ this.registerTextureType('NoiseTexture', NoiseTexture);
175
+ this.registerTextureType('SubTexture', SubTexture);
176
+ }
177
+
178
+ registerTextureType<Type extends keyof TextureMap>(
179
+ textureType: Type,
180
+ textureClass: TextureMap[Type],
181
+ ): void {
182
+ this.txConstructors[textureType] = textureClass;
183
+ }
184
+
185
+ loadTexture<Type extends keyof TextureMap>(
186
+ textureType: Type,
187
+ props: ExtractProps<TextureMap[Type]>,
188
+ options: TextureOptions | null = null,
189
+ ): InstanceType<TextureMap[Type]> {
190
+ const TextureClass = this.txConstructors[textureType];
191
+ if (!TextureClass) {
192
+ throw new Error(`Texture type "${textureType}" is not registered`);
193
+ }
194
+ let texture: Texture | undefined;
195
+ // If an ID is specified, try to get the texture from the ID cache first
196
+ if (options?.id !== undefined && this.textureIdCache.has(options.id)) {
197
+ // console.log('Getting texture by texture desc ID', options.id);
198
+ // eslint-disable-next-line @typescript-eslint/no-non-null-assertion
199
+ texture = this.textureIdCache.get(options.id)!;
200
+ }
201
+ // If the texture is not found in the ID cache, try to get it from the key cache
202
+ if (!texture) {
203
+ const descId = options?.id;
204
+ const cacheKey =
205
+ options?.cacheKey ?? TextureClass.makeCacheKey(props as any);
206
+ if (cacheKey && this.textureKeyCache.has(cacheKey)) {
207
+ // console.log('Getting texture by cache key', cacheKey);
208
+ // eslint-disable-next-line @typescript-eslint/no-non-null-assertion
209
+ texture = this.textureKeyCache.get(cacheKey)!;
210
+ } else {
211
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-argument, @typescript-eslint/no-explicit-any
212
+ texture = new TextureClass(this, props as any);
213
+ }
214
+ if (descId) {
215
+ this.addTextureIdToCache(descId, cacheKey, texture);
216
+ }
217
+ }
218
+ if (options?.preload) {
219
+ const ctxTx = this.getCtxTexture(texture);
220
+ ctxTx.load();
221
+ }
222
+ return texture as InstanceType<TextureMap[Type]>;
223
+ }
224
+
225
+ /**
226
+ * Add a `Texture` to the texture cache by its texture desc ID and cache key
227
+ *
228
+ * @remarks
229
+ * This is used internally by the `CoreTextureManager` to cache textures
230
+ * when they are created.
231
+ *
232
+ * It handles updating the texture ID cache, texture key cache, and texture
233
+ * reference count map.
234
+ *
235
+ * @param textureDescId
236
+ * @param cacheKey
237
+ * @param texture
238
+ */
239
+ private addTextureIdToCache(
240
+ textureDescId: number,
241
+ cacheKey: string | false,
242
+ texture: Texture,
243
+ ): void {
244
+ const { textureIdCache, textureRefCountMap } = this;
245
+ textureIdCache.set(textureDescId, texture);
246
+ if (textureRefCountMap.has(texture)) {
247
+ // eslint-disable-next-line @typescript-eslint/no-non-null-assertion
248
+ textureRefCountMap.get(texture)!.count++;
249
+ } else {
250
+ textureRefCountMap.set(texture, { cacheKey, count: 1 });
251
+ if (cacheKey) {
252
+ this.textureKeyCache.set(cacheKey, texture);
253
+ }
254
+ }
255
+ }
256
+
257
+ /**
258
+ * Remove a `Texture` from the texture cache by its texture desc ID
259
+ *
260
+ * @remarks
261
+ * This is called externally by when we know (at least reasonably well) that
262
+ * the `TextureRef` in the Main API space has been is no longer used. This
263
+ * allows us to remove the `Texture` from the Usage Cache so that it can be
264
+ * garbage collected as well.
265
+ *
266
+ * @param textureDescId
267
+ */
268
+ removeTextureIdFromCache(textureDescId: number): void {
269
+ const { textureIdCache, textureRefCountMap } = this;
270
+ const texture = textureIdCache.get(textureDescId);
271
+ if (!texture) {
272
+ // Sometimes a texture is removed from the cache before it ever gets
273
+ // added to the cache. This is fine and not an error.
274
+ return;
275
+ }
276
+ textureIdCache.delete(textureDescId);
277
+ if (textureRefCountMap.has(texture)) {
278
+ const refCountObj = textureRefCountMap.get(texture);
279
+ assertTruthy(refCountObj);
280
+ refCountObj.count--;
281
+ if (refCountObj.count === 0) {
282
+ textureRefCountMap.delete(texture);
283
+ // If the texture is not referenced anywhere else, remove it from the key cache
284
+ // as well.
285
+ // This should allow the `Texture` instance to be garbage collected.
286
+ if (refCountObj.cacheKey) {
287
+ this.textureKeyCache.delete(refCountObj.cacheKey);
288
+ }
289
+ }
290
+ }
291
+ // Free the ctx texture if it exists.
292
+ this.ctxTextureCache.get(texture)?.free();
293
+ }
294
+
295
+ /**
296
+ * Get an object containing debug information about the texture manager.
297
+ *
298
+ * @returns
299
+ */
300
+ getDebugInfo(): TextureManagerDebugInfo {
301
+ // const textureSet = new Set<Texture>();
302
+ // for (const texture of this.textureIdCache.values()) {
303
+ // textureSet.add(texture);
304
+ // }
305
+ // for (const texture of this.textureKeyCache.values()) {
306
+ // textureSet.add(texture);
307
+ // }
308
+ // TODO: Output number of bytes used by textures
309
+ return {
310
+ keyCacheSize: this.textureKeyCache.size,
311
+ idCacheSize: this.textureIdCache.size,
312
+ };
313
+ }
314
+
315
+ /**
316
+ * Get a CoreContextTexture for the given Texture source.
317
+ *
318
+ * @remarks
319
+ * If the texture source already has an allocated CoreContextTexture, it will be
320
+ * returned from the cache. Otherwise, a new CoreContextTexture will be created
321
+ * and cached.
322
+ *
323
+ * ContextTextures are stored in a WeakMap, so they will be garbage collected
324
+ * when the Texture source is no longer referenced.
325
+ *
326
+ * @param textureSource
327
+ * @returns
328
+ */
329
+ getCtxTexture(textureSource: Texture): CoreContextTexture {
330
+ if (this.ctxTextureCache.has(textureSource)) {
331
+ // eslint-disable-next-line @typescript-eslint/no-non-null-assertion
332
+ return this.ctxTextureCache.get(textureSource)!;
333
+ }
334
+ const texture = this.renderer.createCtxTexture(textureSource);
335
+
336
+ this.ctxTextureCache.set(textureSource, texture);
337
+ return texture;
338
+ }
339
+ }