@lightningjs/renderer 0.3.0 → 0.3.2

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 (295) hide show
  1. package/NOTICE +1 -2
  2. package/dist/exports/core-api.js +1 -1
  3. package/dist/exports/main-api.js +1 -1
  4. package/dist/exports/utils.js +1 -1
  5. package/dist/src/common/CommonTypes.js +1 -1
  6. package/dist/src/common/EventEmitter.js +1 -1
  7. package/dist/src/common/IAnimationController.js +1 -1
  8. package/dist/src/core/CoreExtension.js +1 -1
  9. package/dist/src/core/CoreNode.d.ts +5 -1
  10. package/dist/src/core/CoreNode.js +9 -2
  11. package/dist/src/core/CoreNode.js.map +1 -1
  12. package/dist/src/core/CoreTextNode.d.ts +2 -1
  13. package/dist/src/core/CoreTextNode.js +3 -3
  14. package/dist/src/core/CoreTextNode.js.map +1 -1
  15. package/dist/src/core/CoreTextureManager.js +1 -1
  16. package/dist/src/core/Matrix2DContext.js +1 -1
  17. package/dist/src/core/Stage.d.ts +2 -1
  18. package/dist/src/core/Stage.js +20 -6
  19. package/dist/src/core/Stage.js.map +1 -1
  20. package/dist/src/core/animations/AnimationManager.js +1 -1
  21. package/dist/src/core/animations/CoreAnimation.js +1 -1
  22. package/dist/src/core/animations/CoreAnimationController.js +1 -1
  23. package/dist/src/core/lib/glm/common.js +1 -1
  24. package/dist/src/core/lib/glm/index.js +1 -1
  25. package/dist/src/core/lib/glm/mat2.js +1 -1
  26. package/dist/src/core/lib/glm/mat2d.js +1 -1
  27. package/dist/src/core/lib/glm/mat3.js +1 -1
  28. package/dist/src/core/lib/glm/mat4.js +1 -1
  29. package/dist/src/core/lib/glm/quat.js +1 -1
  30. package/dist/src/core/lib/glm/quat2.js +1 -1
  31. package/dist/src/core/lib/glm/vec2.js +1 -1
  32. package/dist/src/core/lib/glm/vec3.js +1 -1
  33. package/dist/src/core/lib/glm/vec4.js +1 -1
  34. package/dist/src/core/lib/utils.d.ts +1 -0
  35. package/dist/src/core/lib/utils.js +10 -1
  36. package/dist/src/core/lib/utils.js.map +1 -1
  37. package/dist/src/core/platform.js +1 -1
  38. package/dist/src/core/renderers/CoreContextTexture.js +1 -1
  39. package/dist/src/core/renderers/CoreRenderOp.js +1 -1
  40. package/dist/src/core/renderers/CoreRenderer.d.ts +2 -0
  41. package/dist/src/core/renderers/CoreRenderer.js +1 -1
  42. package/dist/src/core/renderers/CoreRenderer.js.map +1 -1
  43. package/dist/src/core/renderers/CoreShader.d.ts +2 -2
  44. package/dist/src/core/renderers/CoreShader.js +1 -1
  45. package/dist/src/core/renderers/CoreShader.js.map +1 -1
  46. package/dist/src/core/renderers/webgl/WebGlCoreCtxSubTexture.js +1 -1
  47. package/dist/src/core/renderers/webgl/WebGlCoreCtxTexture.js +1 -1
  48. package/dist/src/core/renderers/webgl/WebGlCoreRenderOp.d.ts +4 -1
  49. package/dist/src/core/renderers/webgl/WebGlCoreRenderOp.js +22 -4
  50. package/dist/src/core/renderers/webgl/WebGlCoreRenderOp.js.map +1 -1
  51. package/dist/src/core/renderers/webgl/WebGlCoreRenderer.d.ts +2 -2
  52. package/dist/src/core/renderers/webgl/WebGlCoreRenderer.js +29 -15
  53. package/dist/src/core/renderers/webgl/WebGlCoreRenderer.js.map +1 -1
  54. package/dist/src/core/renderers/webgl/WebGlCoreShader.d.ts +46 -3
  55. package/dist/src/core/renderers/webgl/WebGlCoreShader.js +44 -9
  56. package/dist/src/core/renderers/webgl/WebGlCoreShader.js.map +1 -1
  57. package/dist/src/core/renderers/webgl/internal/BufferCollection.js +1 -1
  58. package/dist/src/core/renderers/webgl/internal/RendererUtils.js +1 -1
  59. package/dist/src/core/renderers/webgl/internal/ShaderUtils.js +1 -1
  60. package/dist/src/core/renderers/webgl/internal/WebGlUtils.js +1 -1
  61. package/dist/src/core/renderers/webgl/shaders/DefaultShader.js +1 -1
  62. package/dist/src/core/renderers/webgl/shaders/DefaultShaderBatched.js +1 -1
  63. package/dist/src/core/renderers/webgl/shaders/DynamicShader.d.ts +8 -6
  64. package/dist/src/core/renderers/webgl/shaders/DynamicShader.js +20 -13
  65. package/dist/src/core/renderers/webgl/shaders/DynamicShader.js.map +1 -1
  66. package/dist/src/core/renderers/webgl/shaders/RoundedRectangle.d.ts +5 -6
  67. package/dist/src/core/renderers/webgl/shaders/RoundedRectangle.js +12 -11
  68. package/dist/src/core/renderers/webgl/shaders/RoundedRectangle.js.map +1 -1
  69. package/dist/src/core/renderers/webgl/shaders/SdfShader.d.ts +1 -1
  70. package/dist/src/core/renderers/webgl/shaders/SdfShader.js +1 -1
  71. package/dist/src/core/renderers/webgl/shaders/SdfShader.js.map +1 -1
  72. package/dist/src/core/renderers/webgl/shaders/effects/BorderBottomEffect.d.ts +16 -0
  73. package/dist/src/core/renderers/webgl/shaders/effects/BorderBottomEffect.js +5 -2
  74. package/dist/src/core/renderers/webgl/shaders/effects/BorderBottomEffect.js.map +1 -1
  75. package/dist/src/core/renderers/webgl/shaders/effects/BorderEffect.d.ts +16 -0
  76. package/dist/src/core/renderers/webgl/shaders/effects/BorderEffect.js +5 -2
  77. package/dist/src/core/renderers/webgl/shaders/effects/BorderEffect.js.map +1 -1
  78. package/dist/src/core/renderers/webgl/shaders/effects/BorderLeftEffect.d.ts +16 -0
  79. package/dist/src/core/renderers/webgl/shaders/effects/BorderLeftEffect.js +5 -2
  80. package/dist/src/core/renderers/webgl/shaders/effects/BorderLeftEffect.js.map +1 -1
  81. package/dist/src/core/renderers/webgl/shaders/effects/BorderRightEffect.d.ts +16 -0
  82. package/dist/src/core/renderers/webgl/shaders/effects/BorderRightEffect.js +5 -2
  83. package/dist/src/core/renderers/webgl/shaders/effects/BorderRightEffect.js.map +1 -1
  84. package/dist/src/core/renderers/webgl/shaders/effects/BorderTopEffect.d.ts +16 -0
  85. package/dist/src/core/renderers/webgl/shaders/effects/BorderTopEffect.js +5 -2
  86. package/dist/src/core/renderers/webgl/shaders/effects/BorderTopEffect.js.map +1 -1
  87. package/dist/src/core/renderers/webgl/shaders/effects/EffectUtils.js +1 -1
  88. package/dist/src/core/renderers/webgl/shaders/effects/FadeOutEffect.d.ts +12 -0
  89. package/dist/src/core/renderers/webgl/shaders/effects/FadeOutEffect.js +100 -0
  90. package/dist/src/core/renderers/webgl/shaders/effects/FadeOutEffect.js.map +1 -0
  91. package/dist/src/core/renderers/webgl/shaders/effects/GlitchEffect.d.ts +28 -0
  92. package/dist/src/core/renderers/webgl/shaders/effects/GlitchEffect.js +3 -0
  93. package/dist/src/core/renderers/webgl/shaders/effects/GlitchEffect.js.map +1 -1
  94. package/dist/src/core/renderers/webgl/shaders/effects/GrayscaleEffect.d.ts +3 -0
  95. package/dist/src/core/renderers/webgl/shaders/effects/GrayscaleEffect.js +4 -1
  96. package/dist/src/core/renderers/webgl/shaders/effects/GrayscaleEffect.js.map +1 -1
  97. package/dist/src/core/renderers/webgl/shaders/effects/LinearGradientEffect.d.ts +19 -0
  98. package/dist/src/core/renderers/webgl/shaders/effects/LinearGradientEffect.js +5 -2
  99. package/dist/src/core/renderers/webgl/shaders/effects/LinearGradientEffect.js.map +1 -1
  100. package/dist/src/core/renderers/webgl/shaders/effects/RadialGradientEffect.d.ts +38 -0
  101. package/dist/src/core/renderers/webgl/shaders/effects/RadialGradientEffect.js +116 -0
  102. package/dist/src/core/renderers/webgl/shaders/effects/RadialGradientEffect.js.map +1 -0
  103. package/dist/src/core/renderers/webgl/shaders/effects/RadiusEffect.d.ts +11 -0
  104. package/dist/src/core/renderers/webgl/shaders/effects/RadiusEffect.js +4 -1
  105. package/dist/src/core/renderers/webgl/shaders/effects/RadiusEffect.js.map +1 -1
  106. package/dist/src/core/scene/Scene.js +1 -1
  107. package/dist/src/core/text-rendering/TextTextureRendererUtils.js +1 -1
  108. package/dist/src/core/text-rendering/TrFontManager.js +1 -1
  109. package/dist/src/core/text-rendering/font-face-types/SdfTrFontFace/SdfTrFontFace.js +1 -1
  110. package/dist/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/FontShaper.js +1 -1
  111. package/dist/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/SdfFontShaper.js +1 -1
  112. package/dist/src/core/text-rendering/font-face-types/TrFontFace.js +1 -1
  113. package/dist/src/core/text-rendering/font-face-types/WebTrFontFace.js +1 -1
  114. package/dist/src/core/text-rendering/renderers/CanvasTextRenderer.d.ts +2 -2
  115. package/dist/src/core/text-rendering/renderers/CanvasTextRenderer.js +5 -2
  116. package/dist/src/core/text-rendering/renderers/CanvasTextRenderer.js.map +1 -1
  117. package/dist/src/core/text-rendering/renderers/LightningTextTextureRenderer.js +1 -1
  118. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.d.ts +2 -2
  119. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.js +3 -3
  120. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.js.map +1 -1
  121. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/PeekableGenerator.js +1 -1
  122. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/SpecialCodepoints.js +1 -1
  123. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/constants.js +1 -1
  124. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/getStartConditions.js +1 -1
  125. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/getUnicodeCodepoints.js +1 -1
  126. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText.js +1 -1
  127. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/makeRenderWindow.js +1 -1
  128. package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/measureText.js +1 -1
  129. package/dist/src/core/text-rendering/renderers/TextRenderer.d.ts +2 -1
  130. package/dist/src/core/text-rendering/renderers/TextRenderer.js +1 -1
  131. package/dist/src/core/text-rendering/renderers/TextRenderer.js.map +1 -1
  132. package/dist/src/core/textures/ColorTexture.js +1 -1
  133. package/dist/src/core/textures/ImageTexture.js +1 -1
  134. package/dist/src/core/textures/NoiseTexture.js +1 -1
  135. package/dist/src/core/textures/SubTexture.js +1 -1
  136. package/dist/src/core/textures/Texture.js +1 -1
  137. package/dist/src/core/utils.js +1 -1
  138. package/dist/src/main-api/INode.d.ts +19 -0
  139. package/dist/src/main-api/INode.js +1 -1
  140. package/dist/src/main-api/IRenderDriver.js +1 -1
  141. package/dist/src/main-api/RendererMain.d.ts +1 -1
  142. package/dist/src/main-api/RendererMain.js +2 -1
  143. package/dist/src/main-api/RendererMain.js.map +1 -1
  144. package/dist/src/main-api/TextureRegistry.d.ts +33 -0
  145. package/dist/src/main-api/TextureRegistry.js +97 -0
  146. package/dist/src/main-api/TextureRegistry.js.map +1 -0
  147. package/dist/src/main-api/TextureUsageRegistry/TextureRegistry.d.ts +33 -0
  148. package/dist/src/main-api/TextureUsageRegistry/TextureRegistry.js +97 -0
  149. package/dist/src/main-api/TextureUsageRegistry/TextureRegistry.js.map +1 -0
  150. package/dist/src/main-api/texture-usage-trackers/FinalizationRegistryTextureUsageTracker.d.ts +9 -0
  151. package/dist/src/main-api/texture-usage-trackers/FinalizationRegistryTextureUsageTracker.js +38 -0
  152. package/dist/src/main-api/texture-usage-trackers/FinalizationRegistryTextureUsageTracker.js.map +1 -0
  153. package/dist/src/main-api/texture-usage-trackers/ManualCountTextureUsageTracker.d.ts +56 -0
  154. package/dist/src/main-api/texture-usage-trackers/ManualCountTextureUsageTracker.js +101 -0
  155. package/dist/src/main-api/texture-usage-trackers/ManualCountTextureUsageTracker.js.map +1 -0
  156. package/dist/src/main-api/texture-usage-trackers/TextureUsageTracker.d.ts +32 -0
  157. package/dist/src/main-api/texture-usage-trackers/TextureUsageTracker.js +28 -0
  158. package/dist/src/main-api/texture-usage-trackers/TextureUsageTracker.js.map +1 -0
  159. package/dist/src/render-drivers/main/MainOnlyNode.d.ts +2 -0
  160. package/dist/src/render-drivers/main/MainOnlyNode.js +8 -1
  161. package/dist/src/render-drivers/main/MainOnlyNode.js.map +1 -1
  162. package/dist/src/render-drivers/main/MainOnlyTextNode.js +2 -1
  163. package/dist/src/render-drivers/main/MainOnlyTextNode.js.map +1 -1
  164. package/dist/src/render-drivers/main/MainRenderDriver.js +1 -1
  165. package/dist/src/render-drivers/threadx/NodeStruct.d.ts +3 -0
  166. package/dist/src/render-drivers/threadx/NodeStruct.js +10 -1
  167. package/dist/src/render-drivers/threadx/NodeStruct.js.map +1 -1
  168. package/dist/src/render-drivers/threadx/SharedNode.d.ts +1 -0
  169. package/dist/src/render-drivers/threadx/SharedNode.js +2 -1
  170. package/dist/src/render-drivers/threadx/SharedNode.js.map +1 -1
  171. package/dist/src/render-drivers/threadx/TextNodeStruct.js +1 -1
  172. package/dist/src/render-drivers/threadx/ThreadXMainAnimationController.js +1 -1
  173. package/dist/src/render-drivers/threadx/ThreadXMainNode.js +1 -1
  174. package/dist/src/render-drivers/threadx/ThreadXMainTextNode.js +1 -1
  175. package/dist/src/render-drivers/threadx/ThreadXRenderDriver.js +3 -1
  176. package/dist/src/render-drivers/threadx/ThreadXRenderDriver.js.map +1 -1
  177. package/dist/src/render-drivers/threadx/ThreadXRendererMessage.js +1 -1
  178. package/dist/src/render-drivers/threadx/worker/ThreadXRendererNode.js +2 -1
  179. package/dist/src/render-drivers/threadx/worker/ThreadXRendererNode.js.map +1 -1
  180. package/dist/src/render-drivers/threadx/worker/ThreadXRendererTextNode.js +2 -1
  181. package/dist/src/render-drivers/threadx/worker/ThreadXRendererTextNode.js.map +1 -1
  182. package/dist/src/render-drivers/threadx/worker/renderer.js +2 -1
  183. package/dist/src/render-drivers/threadx/worker/renderer.js.map +1 -1
  184. package/dist/src/utils.d.ts +10 -2
  185. package/dist/src/utils.js +13 -3
  186. package/dist/src/utils.js.map +1 -1
  187. package/dist/tsconfig.dist.tsbuildinfo +1 -1
  188. package/package.json +6 -5
  189. package/src/common/CommonTypes.ts +70 -0
  190. package/src/common/EventEmitter.ts +77 -0
  191. package/src/common/IAnimationController.ts +29 -0
  192. package/src/core/CoreExtension.ts +32 -0
  193. package/src/core/CoreNode.ts +700 -0
  194. package/src/core/CoreShaderManager.ts +111 -0
  195. package/src/core/CoreTextNode.ts +342 -0
  196. package/src/core/CoreTextureManager.ts +323 -0
  197. package/src/core/Matrix2DContext.ts +52 -0
  198. package/src/core/Stage.ts +280 -0
  199. package/src/core/animations/AnimationManager.ts +38 -0
  200. package/src/core/animations/CoreAnimation.ts +139 -0
  201. package/src/core/animations/CoreAnimationController.ts +117 -0
  202. package/src/core/lib/glm/common.ts +231 -0
  203. package/src/core/lib/glm/index.ts +31 -0
  204. package/src/core/lib/glm/mat2.ts +499 -0
  205. package/src/core/lib/glm/mat2d.ts +547 -0
  206. package/src/core/lib/glm/mat3.ts +849 -0
  207. package/src/core/lib/glm/mat4.ts +2169 -0
  208. package/src/core/lib/glm/quat.ts +828 -0
  209. package/src/core/lib/glm/quat2.ts +951 -0
  210. package/src/core/lib/glm/vec2.ts +671 -0
  211. package/src/core/lib/glm/vec3.ts +859 -0
  212. package/src/core/lib/glm/vec4.ts +708 -0
  213. package/src/core/lib/utils.ts +144 -0
  214. package/src/core/platform.ts +40 -0
  215. package/src/core/renderers/CoreContextTexture.ts +30 -0
  216. package/src/core/renderers/CoreRenderOp.ts +22 -0
  217. package/src/core/renderers/CoreRenderer.ts +66 -0
  218. package/src/core/renderers/CoreShader.ts +41 -0
  219. package/src/core/renderers/webgl/WebGlCoreCtxSubTexture.ts +36 -0
  220. package/src/core/renderers/webgl/WebGlCoreCtxTexture.ts +208 -0
  221. package/src/core/renderers/webgl/WebGlCoreRenderOp.ts +111 -0
  222. package/src/core/renderers/webgl/WebGlCoreRenderer.ts +567 -0
  223. package/src/core/renderers/webgl/WebGlCoreShader.ts +328 -0
  224. package/src/core/renderers/webgl/internal/BufferCollection.ts +54 -0
  225. package/src/core/renderers/webgl/internal/RendererUtils.ts +134 -0
  226. package/src/core/renderers/webgl/internal/ShaderUtils.ts +135 -0
  227. package/src/core/renderers/webgl/internal/WebGlUtils.ts +35 -0
  228. package/src/core/renderers/webgl/shaders/DefaultShader.ts +95 -0
  229. package/src/core/renderers/webgl/shaders/DefaultShaderBatched.ts +132 -0
  230. package/src/core/renderers/webgl/shaders/DynamicShader.ts +430 -0
  231. package/src/core/renderers/webgl/shaders/RoundedRectangle.ts +168 -0
  232. package/src/core/renderers/webgl/shaders/SdfShader.ts +165 -0
  233. package/src/core/renderers/webgl/shaders/effects/BorderBottomEffect.ts +101 -0
  234. package/src/core/renderers/webgl/shaders/effects/BorderEffect.ts +86 -0
  235. package/src/core/renderers/webgl/shaders/effects/BorderLeftEffect.ts +101 -0
  236. package/src/core/renderers/webgl/shaders/effects/BorderRightEffect.ts +101 -0
  237. package/src/core/renderers/webgl/shaders/effects/BorderTopEffect.ts +101 -0
  238. package/src/core/renderers/webgl/shaders/effects/EffectUtils.ts +33 -0
  239. package/src/core/renderers/webgl/shaders/effects/FadeOutEffect.ts +111 -0
  240. package/src/core/renderers/webgl/shaders/effects/GlitchEffect.ts +145 -0
  241. package/src/core/renderers/webgl/shaders/effects/GrayscaleEffect.ts +37 -0
  242. package/src/core/renderers/webgl/shaders/effects/LinearGradientEffect.ts +182 -0
  243. package/src/core/renderers/webgl/shaders/effects/RadialGradientEffect.ts +159 -0
  244. package/src/core/renderers/webgl/shaders/effects/RadiusEffect.ts +106 -0
  245. package/src/core/renderers/webgl/shaders/effects/ShaderEffect.ts +114 -0
  246. package/src/core/scene/Scene.ts +120 -0
  247. package/src/core/text-rendering/TextTextureRendererUtils.ts +189 -0
  248. package/src/core/text-rendering/TrFontManager.ts +96 -0
  249. package/src/core/text-rendering/font-face-types/SdfTrFontFace/SdfTrFontFace.ts +128 -0
  250. package/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/FontShaper.ts +139 -0
  251. package/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/SdfFontShaper.test.ts +159 -0
  252. package/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/SdfFontShaper.ts +164 -0
  253. package/src/core/text-rendering/font-face-types/TrFontFace.ts +105 -0
  254. package/src/core/text-rendering/font-face-types/WebTrFontFace.ts +77 -0
  255. package/src/core/text-rendering/renderers/CanvasTextRenderer.ts +634 -0
  256. package/src/core/text-rendering/renderers/LightningTextTextureRenderer.ts +705 -0
  257. package/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.ts +647 -0
  258. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/PeekableGenerator.test.ts +48 -0
  259. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/PeekableGenerator.ts +66 -0
  260. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/SpecialCodepoints.ts +52 -0
  261. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/constants.ts +32 -0
  262. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/getStartConditions.ts +76 -0
  263. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/getUnicodeCodepoints.test.ts +133 -0
  264. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/getUnicodeCodepoints.ts +38 -0
  265. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText.ts +381 -0
  266. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/makeRenderWindow.test.ts +136 -0
  267. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/makeRenderWindow.ts +64 -0
  268. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/measureText.test.ts +41 -0
  269. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/measureText.ts +51 -0
  270. package/src/core/text-rendering/renderers/TextRenderer.ts +371 -0
  271. package/src/core/textures/ColorTexture.ts +85 -0
  272. package/src/core/textures/ImageTexture.ts +113 -0
  273. package/src/core/textures/NoiseTexture.ts +96 -0
  274. package/src/core/textures/SubTexture.ts +140 -0
  275. package/src/core/textures/Texture.ts +162 -0
  276. package/src/core/utils.ts +222 -0
  277. package/src/main-api/INode.ts +443 -0
  278. package/src/main-api/IRenderDriver.ts +58 -0
  279. package/src/main-api/RendererMain.ts +451 -0
  280. package/src/render-drivers/main/MainOnlyNode.ts +429 -0
  281. package/src/render-drivers/main/MainOnlyTextNode.ts +220 -0
  282. package/src/render-drivers/main/MainRenderDriver.ts +117 -0
  283. package/src/render-drivers/threadx/NodeStruct.ts +290 -0
  284. package/src/render-drivers/threadx/SharedNode.ts +95 -0
  285. package/src/render-drivers/threadx/TextNodeStruct.ts +166 -0
  286. package/src/render-drivers/threadx/ThreadXMainAnimationController.ts +99 -0
  287. package/src/render-drivers/threadx/ThreadXMainNode.ts +151 -0
  288. package/src/render-drivers/threadx/ThreadXMainTextNode.ts +75 -0
  289. package/src/render-drivers/threadx/ThreadXRenderDriver.ts +247 -0
  290. package/src/render-drivers/threadx/ThreadXRendererMessage.ts +82 -0
  291. package/src/render-drivers/threadx/worker/ThreadXRendererNode.ts +232 -0
  292. package/src/render-drivers/threadx/worker/ThreadXRendererTextNode.ts +146 -0
  293. package/src/render-drivers/threadx/worker/renderer.ts +138 -0
  294. package/src/render-drivers/utils.ts +57 -0
  295. package/src/utils.ts +202 -0
@@ -0,0 +1,140 @@
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 {
21
+ TextureFailedEventHandler,
22
+ TextureLoadedEventHandler,
23
+ } from '../../common/CommonTypes.js';
24
+ import type { TextureDesc } from '../../main-api/RendererMain.js';
25
+ import type { CoreTextureManager } from '../CoreTextureManager.js';
26
+ import { Texture } from './Texture.js';
27
+
28
+ /**
29
+ * Properties of the {@link SubTexture}
30
+ */
31
+ export interface SubTextureProps {
32
+ /**
33
+ * The texture that this sub-texture is a sub-region of.
34
+ */
35
+ texture: TextureDesc;
36
+
37
+ /**
38
+ * The x pixel position of the top-left of the sub-texture within the parent
39
+ * texture.
40
+ *
41
+ * @default 0
42
+ */
43
+ x?: number;
44
+
45
+ /**
46
+ * The y pixel position of the top-left sub-texture within the parent
47
+ * texture.
48
+ *
49
+ * @default 0
50
+ **/
51
+ y?: number;
52
+
53
+ /**
54
+ * The width of the sub-texture in pixels.
55
+ *
56
+ * @default 0
57
+ */
58
+ width?: number;
59
+
60
+ /**
61
+ * The height of the sub-texture in pixels
62
+ **/
63
+ height?: number;
64
+ }
65
+
66
+ /**
67
+ * A Texture that is a sub-region of another Texture.
68
+ *
69
+ * @remarks
70
+ * The parent texture can be a Sprite Sheet/Texture Atlas and set using the
71
+ * {@link SubTextureProps.texture} prop. The sub-region relative to the parent
72
+ * texture is defined with the {@link SubTextureProps.x},
73
+ * {@link SubTextureProps.y}, {@link SubTextureProps.width}, and
74
+ * {@link SubTextureProps.height} pixel values.
75
+ */
76
+ export class SubTexture extends Texture {
77
+ props: Required<SubTextureProps>;
78
+ parentTexture: Texture;
79
+
80
+ constructor(txManager: CoreTextureManager, props: SubTextureProps) {
81
+ super(txManager);
82
+ this.parentTexture = this.txManager.loadTexture(
83
+ props.texture.txType,
84
+ props.texture.props,
85
+ props.texture.options,
86
+ );
87
+ this.props = SubTexture.resolveDefaults(props || {});
88
+
89
+ // If parent texture is already loaded / failed, trigger loaded event manually
90
+ // so that users get a consistent event experience.
91
+ // We do this in a microtask to allow listeners to be attached in the same
92
+ // synchronous task after calling loadTexture()
93
+ queueMicrotask(() => {
94
+ const parentTx = this.parentTexture;
95
+ if (parentTx.state === 'loaded') {
96
+ this.onParentTxLoaded(parentTx, parentTx.dimensions!);
97
+ } else if (parentTx.state === 'failed') {
98
+ this.onParentTxFailed(parentTx, parentTx.error!);
99
+ }
100
+ parentTx.on('loaded', this.onParentTxLoaded);
101
+ parentTx.on('failed', this.onParentTxFailed);
102
+ });
103
+ }
104
+
105
+ private onParentTxLoaded: TextureLoadedEventHandler = () => {
106
+ // We ignore the parent's passed dimensions, and simply use the SubTexture's
107
+ // configured dimensions (because that's all that matters here)
108
+ this.setState('loaded', {
109
+ width: this.props.width,
110
+ height: this.props.height,
111
+ });
112
+ };
113
+
114
+ private onParentTxFailed: TextureFailedEventHandler = (target, error) => {
115
+ this.setState('failed', error);
116
+ };
117
+
118
+ override async getTextureData(): Promise<SubTextureProps> {
119
+ return this.props;
120
+ }
121
+
122
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
123
+ static override makeCacheKey(props: SubTextureProps): string | false {
124
+ return false;
125
+ }
126
+
127
+ static override resolveDefaults(
128
+ props: SubTextureProps,
129
+ ): Required<SubTextureProps> {
130
+ return {
131
+ texture: props.texture,
132
+ x: props.x || 0,
133
+ y: props.y || 0,
134
+ width: props.width || 0,
135
+ height: props.height || 0,
136
+ };
137
+ }
138
+
139
+ static z$__type__Props: SubTextureProps;
140
+ }
@@ -0,0 +1,162 @@
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 { CoreTextureManager } from '../CoreTextureManager.js';
21
+ import type { SubTextureProps } from './SubTexture.js';
22
+ import type {
23
+ Dimensions,
24
+ TextureFailedEventHandler,
25
+ TextureLoadedEventHandler,
26
+ TextureLoadingEventHandler,
27
+ } from '../../common/CommonTypes.js';
28
+ import { EventEmitter } from '../../common/EventEmitter.js';
29
+
30
+ /**
31
+ * Texture sources that are used to populate a CoreContextTexture
32
+ */
33
+ export type TextureData = ImageBitmap | SubTextureProps | null;
34
+
35
+ export type TextureState = 'loading' | 'loaded' | 'failed';
36
+
37
+ export interface TextureStateEventMap {
38
+ loading: TextureLoadingEventHandler;
39
+ loaded: TextureLoadedEventHandler;
40
+ failed: TextureFailedEventHandler;
41
+ }
42
+
43
+ /**
44
+ * Like the built-in Parameters<> type but skips the first parameter (which is
45
+ * `target` currently)
46
+ */
47
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
48
+ type ParametersSkipTarget<T extends (...args: any) => any> = T extends (
49
+ target: any,
50
+ ...args: infer P
51
+ ) => any
52
+ ? P
53
+ : never;
54
+
55
+ /**
56
+ * Represents a source of texture data for a CoreContextTexture.
57
+ *
58
+ * @remarks
59
+ * Texture sources are used to populate a CoreContextTexture when that texture
60
+ * is loaded. Texture data retrieved by the CoreContextTexture by the
61
+ * `getTextureData` method. It's the responsibility of the concerete `Texture`
62
+ * subclass to implement this method appropriately.
63
+ */
64
+ export abstract class Texture extends EventEmitter {
65
+ /**
66
+ * The dimensions of the texture
67
+ *
68
+ * @remarks
69
+ * Until the texture data is loaded for the first time the value will be
70
+ * `null`.
71
+ */
72
+ readonly dimensions: Readonly<Dimensions> | null = null;
73
+
74
+ readonly error: Error | null = null;
75
+
76
+ readonly state: TextureState = 'loading';
77
+
78
+ constructor(protected txManager: CoreTextureManager) {
79
+ super();
80
+ }
81
+
82
+ /**
83
+ * Set the state of the texture
84
+ *
85
+ * @remark
86
+ * Intended for internal-use only but declared public so that it can be set
87
+ * by it's associated {@link CoreContextTexture}
88
+ *
89
+ * @param state
90
+ * @param args
91
+ */
92
+ setState<State extends TextureState>(
93
+ state: State,
94
+ ...args: ParametersSkipTarget<TextureStateEventMap[State]>
95
+ ): void {
96
+ if (this.state !== state) {
97
+ // eslint-disable-next-line @typescript-eslint/no-unnecessary-type-assertion
98
+ (this.state as TextureState) = state;
99
+ if (state === 'loaded') {
100
+ const loadedArgs = args as ParametersSkipTarget<
101
+ TextureStateEventMap['loaded']
102
+ >;
103
+ (this.dimensions as Dimensions) = loadedArgs[0];
104
+ } else if (state === 'failed') {
105
+ const failedArgs = args as ParametersSkipTarget<
106
+ TextureStateEventMap['failed']
107
+ >;
108
+ (this.error as Error) = failedArgs[0];
109
+ }
110
+ this.emit(state, ...args);
111
+ }
112
+ }
113
+
114
+ /**
115
+ * Get the texture data for this texture.
116
+ *
117
+ * @remarks
118
+ * This method is called by the CoreContextTexture when the texture is loaded.
119
+ * The texture data is then used to populate the CoreContextTexture.
120
+ *
121
+ * @returns
122
+ * The texture data for this texture.
123
+ */
124
+ abstract getTextureData(): Promise<TextureData>;
125
+
126
+ /**
127
+ * Make a cache key for this texture.
128
+ *
129
+ * @remarks
130
+ * Each concrete `Texture` subclass must implement this method to provide an
131
+ * appropriate cache key for the texture type including the texture's
132
+ * properties that uniquely identify a copy of the texture. If the texture
133
+ * type does not support caching, then this method should return `false`.
134
+ *
135
+ * @param props
136
+ * @returns
137
+ * A cache key for this texture or `false` if the texture type does not
138
+ * support caching.
139
+ */
140
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
141
+ static makeCacheKey(props: unknown): string | false {
142
+ return false;
143
+ }
144
+
145
+ /**
146
+ * Resolve the default values for the texture's properties.
147
+ *
148
+ * @remarks
149
+ * Each concrete `Texture` subclass must implement this method to provide
150
+ * default values for the texture's optional properties.
151
+ *
152
+ * @param props
153
+ * @returns
154
+ * The default values for the texture's properties.
155
+ */
156
+ static resolveDefaults(
157
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
158
+ props: unknown,
159
+ ): Record<string, unknown> {
160
+ return {};
161
+ }
162
+ }
@@ -0,0 +1,222 @@
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
+ /**
21
+ * Core Utility Functions
22
+ *
23
+ * @module
24
+ */
25
+
26
+ export const EPSILON = 0.000001;
27
+ export let ARRAY_TYPE =
28
+ typeof Float32Array !== 'undefined' ? Float32Array : Array;
29
+ export const RANDOM = Math.random;
30
+ export const ANGLE_ORDER = 'zyx';
31
+ const degree = Math.PI / 180;
32
+
33
+ export const setMatrixArrayType = (
34
+ type: Float32ArrayConstructor | ArrayConstructor,
35
+ ) => {
36
+ ARRAY_TYPE = type;
37
+ };
38
+
39
+ export const toRadian = (a: number) => {
40
+ return a * degree;
41
+ };
42
+
43
+ export const equals = (a: number, b: number) => {
44
+ return Math.abs(a - b) <= EPSILON * Math.max(1.0, Math.abs(a), Math.abs(b));
45
+ };
46
+
47
+ export const rand = (min: number, max: number) => {
48
+ return Math.floor(Math.random() * (max - min + 1) + min);
49
+ };
50
+
51
+ export const isPowerOfTwo = (value: number) => {
52
+ return value && !(value & (value - 1));
53
+ };
54
+
55
+ const getTimingBezier = (
56
+ a: number,
57
+ b: number,
58
+ c: number,
59
+ d: number,
60
+ ): ((time: number) => number | undefined) => {
61
+ const xc = 3.0 * a;
62
+ const xb = 3.0 * (c - a) - xc;
63
+ const xa = 1.0 - xc - xb;
64
+ const yc = 3.0 * b;
65
+ const yb = 3.0 * (d - b) - yc;
66
+ const ya = 1.0 - yc - yb;
67
+
68
+ return function (time: number): number | undefined {
69
+ if (time >= 1.0) {
70
+ return 1;
71
+ }
72
+ if (time <= 0) {
73
+ return 0;
74
+ }
75
+
76
+ let t = 0.5,
77
+ cbx,
78
+ cbxd,
79
+ dx;
80
+
81
+ for (let it = 0; it < 20; it++) {
82
+ cbx = t * (t * (t * xa + xb) + xc);
83
+ dx = time - cbx;
84
+ if (dx > -1e-8 && dx < 1e-8) {
85
+ return t * (t * (t * ya + yb) + yc);
86
+ }
87
+
88
+ // Cubic bezier derivative.
89
+ cbxd = t * (t * (3 * xa) + 2 * xb) + xc;
90
+
91
+ if (cbxd > 1e-10 && cbxd < 1e-10) {
92
+ // Problematic. Fall back to binary search method.
93
+ break;
94
+ }
95
+
96
+ t += dx / cbxd;
97
+ }
98
+
99
+ // Fallback: binary search method. This is more reliable when there are near-0 slopes.
100
+ let minT = 0;
101
+ let maxT = 1;
102
+ for (let it = 0; it < 20; it++) {
103
+ t = 0.5 * (minT + maxT);
104
+
105
+ cbx = t * (t * (t * xa + xb) + xc);
106
+
107
+ dx = time - cbx;
108
+ if (dx > -1e-8 && dx < 1e-8) {
109
+ // Solution found!
110
+ return t * (t * (t * ya + yb) + yc);
111
+ }
112
+
113
+ if (dx < 0) {
114
+ maxT = t;
115
+ } else {
116
+ minT = t;
117
+ }
118
+ }
119
+ };
120
+ };
121
+
122
+ export const getTimingFunction = (
123
+ str: string,
124
+ ): ((time: number) => number | undefined) => {
125
+ switch (str) {
126
+ case 'linear':
127
+ return function (time: number) {
128
+ return time;
129
+ };
130
+ case 'ease':
131
+ return getTimingBezier(0.25, 0.1, 0.25, 1.0);
132
+
133
+ case 'ease-in':
134
+ return getTimingBezier(0.42, 0, 1.0, 1.0);
135
+ case 'ease-out':
136
+ return getTimingBezier(0, 0, 0.58, 1.0);
137
+ case 'ease-in-out':
138
+ return getTimingBezier(0.42, 0, 0.58, 1.0);
139
+
140
+ case 'ease-in-sine':
141
+ return getTimingBezier(0.12, 0, 0.39, 0);
142
+ case 'ease-out-sine':
143
+ return getTimingBezier(0.12, 0, 0.39, 0);
144
+ case 'ease-in-out-sine':
145
+ return getTimingBezier(0.37, 0, 0.63, 1);
146
+
147
+ case 'ease-in-cubic':
148
+ return getTimingBezier(0.32, 0, 0.67, 0);
149
+ case 'ease-out-cubic':
150
+ return getTimingBezier(0.33, 1, 0.68, 1);
151
+ case 'ease-in-out-cubic':
152
+ return getTimingBezier(0.65, 0, 0.35, 1);
153
+
154
+ case 'ease-in-circ':
155
+ return getTimingBezier(0.55, 0, 1, 0.45);
156
+ case 'ease-out-circ':
157
+ return getTimingBezier(0, 0.55, 0.45, 1);
158
+ case 'ease-in-out-circ':
159
+ return getTimingBezier(0.85, 0, 0.15, 1);
160
+
161
+ case 'ease-in-back':
162
+ return getTimingBezier(0.36, 0, 0.66, -0.56);
163
+ case 'ease-out-back':
164
+ return getTimingBezier(0.34, 1.56, 0.64, 1);
165
+ case 'ease-in-out-back':
166
+ return getTimingBezier(0.68, -0.6, 0.32, 1.6);
167
+
168
+ case 'step-start':
169
+ return function () {
170
+ return 1;
171
+ };
172
+ case 'step-end':
173
+ return function (time: number) {
174
+ return time === 1 ? 1 : 0;
175
+ };
176
+ default:
177
+ // eslint-disable-next-line no-case-declarations
178
+ const s = 'cubic-bezier(';
179
+ if (str && str.indexOf(s) === 0) {
180
+ const parts = str
181
+ .substr(s.length, str.length - s.length - 1)
182
+ .split(',');
183
+ if (parts.length !== 4) {
184
+ console.warn('Unknown timing function: ' + str);
185
+ // Fallback: use linear.
186
+ return function (time) {
187
+ return time;
188
+ };
189
+ }
190
+ const a = parseFloat(parts[0] || '0.42');
191
+ const b = parseFloat(parts[1] || '0');
192
+ const c = parseFloat(parts[2] || '1');
193
+ const d = parseFloat(parts[3] || '1');
194
+
195
+ if (isNaN(a) || isNaN(b) || isNaN(c) || isNaN(d)) {
196
+ console.warn(' Unknown timing function: ' + str);
197
+ // Fallback: use linear.
198
+ return function (time) {
199
+ return time;
200
+ };
201
+ }
202
+
203
+ return getTimingBezier(a, b, c, d);
204
+ } else {
205
+ console.warn('Unknown timing function: ' + str);
206
+ // Fallback: use linear.
207
+ return function (time) {
208
+ return time;
209
+ };
210
+ }
211
+ }
212
+ };
213
+
214
+ if (!Math.hypot)
215
+ Math.hypot = (...args: number[]) => {
216
+ let y = 0,
217
+ i = args.length;
218
+ while (i--) {
219
+ y += args[i]! * args[i]!;
220
+ }
221
+ return Math.sqrt(y);
222
+ };