@lightningjs/renderer 2.9.0-beta2 → 2.9.0-beta4

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 (193) hide show
  1. package/COPYING +1 -0
  2. package/LICENSE +202 -202
  3. package/NOTICE +3 -3
  4. package/README.md +147 -147
  5. package/dist/src/core/CoreNode.d.ts +29 -6
  6. package/dist/src/core/CoreNode.js +118 -79
  7. package/dist/src/core/CoreNode.js.map +1 -1
  8. package/dist/src/core/CoreTextNode.d.ts +2 -2
  9. package/dist/src/core/CoreTextNode.js +7 -4
  10. package/dist/src/core/CoreTextNode.js.map +1 -1
  11. package/dist/src/core/CoreTextureManager.d.ts +61 -15
  12. package/dist/src/core/CoreTextureManager.js +179 -104
  13. package/dist/src/core/CoreTextureManager.js.map +1 -1
  14. package/dist/src/core/Stage.d.ts +7 -0
  15. package/dist/src/core/Stage.js +34 -1
  16. package/dist/src/core/Stage.js.map +1 -1
  17. package/dist/src/core/TextureMemoryManager.js +2 -5
  18. package/dist/src/core/TextureMemoryManager.js.map +1 -1
  19. package/dist/src/core/lib/ImageWorker.js +31 -28
  20. package/dist/src/core/lib/ImageWorker.js.map +1 -1
  21. package/dist/src/core/lib/WebGlContextWrapper.d.ts +1 -0
  22. package/dist/src/core/lib/WebGlContextWrapper.js +2 -0
  23. package/dist/src/core/lib/WebGlContextWrapper.js.map +1 -1
  24. package/dist/src/core/renderers/CoreContextTexture.d.ts +1 -0
  25. package/dist/src/core/renderers/CoreContextTexture.js +1 -0
  26. package/dist/src/core/renderers/CoreContextTexture.js.map +1 -1
  27. package/dist/src/core/renderers/canvas/CanvasCoreRenderer.d.ts +1 -1
  28. package/dist/src/core/renderers/canvas/CanvasCoreRenderer.js +13 -5
  29. package/dist/src/core/renderers/canvas/CanvasCoreRenderer.js.map +1 -1
  30. package/dist/src/core/renderers/canvas/CanvasCoreTexture.js +6 -8
  31. package/dist/src/core/renderers/canvas/CanvasCoreTexture.js.map +1 -1
  32. package/dist/src/core/renderers/webgl/WebGlCoreCtxSubTexture.js +3 -1
  33. package/dist/src/core/renderers/webgl/WebGlCoreCtxSubTexture.js.map +1 -1
  34. package/dist/src/core/renderers/webgl/WebGlCoreCtxTexture.d.ts +1 -2
  35. package/dist/src/core/renderers/webgl/WebGlCoreCtxTexture.js +26 -24
  36. package/dist/src/core/renderers/webgl/WebGlCoreCtxTexture.js.map +1 -1
  37. package/dist/src/core/renderers/webgl/WebGlCoreRenderer.d.ts +0 -1
  38. package/dist/src/core/renderers/webgl/WebGlCoreRenderer.js +7 -17
  39. package/dist/src/core/renderers/webgl/WebGlCoreRenderer.js.map +1 -1
  40. package/dist/src/core/renderers/webgl/shaders/DefaultShader.js +45 -45
  41. package/dist/src/core/renderers/webgl/shaders/DefaultShaderBatched.js +61 -61
  42. package/dist/src/core/renderers/webgl/shaders/DynamicShader.js +93 -93
  43. package/dist/src/core/renderers/webgl/shaders/RoundedRectangle.js +63 -63
  44. package/dist/src/core/renderers/webgl/shaders/SdfShader.js +62 -62
  45. package/dist/src/core/renderers/webgl/shaders/effects/BorderBottomEffect.js +15 -15
  46. package/dist/src/core/renderers/webgl/shaders/effects/BorderEffect.js +6 -6
  47. package/dist/src/core/renderers/webgl/shaders/effects/BorderLeftEffect.js +15 -15
  48. package/dist/src/core/renderers/webgl/shaders/effects/BorderRightEffect.js +15 -15
  49. package/dist/src/core/renderers/webgl/shaders/effects/BorderTopEffect.js +15 -15
  50. package/dist/src/core/renderers/webgl/shaders/effects/FadeOutEffect.js +42 -42
  51. package/dist/src/core/renderers/webgl/shaders/effects/GlitchEffect.js +44 -44
  52. package/dist/src/core/renderers/webgl/shaders/effects/GrayscaleEffect.js +3 -3
  53. package/dist/src/core/renderers/webgl/shaders/effects/HolePunchEffect.js +22 -22
  54. package/dist/src/core/renderers/webgl/shaders/effects/LinearGradientEffect.js +28 -28
  55. package/dist/src/core/renderers/webgl/shaders/effects/RadialGradientEffect.js +12 -12
  56. package/dist/src/core/renderers/webgl/shaders/effects/RadialProgressEffect.js +37 -37
  57. package/dist/src/core/renderers/webgl/shaders/effects/RadiusEffect.js +19 -19
  58. package/dist/src/core/text-rendering/font-face-types/SdfTrFontFace/SdfTrFontFace.js +9 -5
  59. package/dist/src/core/text-rendering/font-face-types/SdfTrFontFace/SdfTrFontFace.js.map +1 -1
  60. package/dist/src/core/text-rendering/renderers/CanvasTextRenderer.js +2 -1
  61. package/dist/src/core/text-rendering/renderers/CanvasTextRenderer.js.map +1 -1
  62. package/dist/src/core/textures/ColorTexture.d.ts +1 -1
  63. package/dist/src/core/textures/ColorTexture.js +2 -1
  64. package/dist/src/core/textures/ColorTexture.js.map +1 -1
  65. package/dist/src/core/textures/ImageTexture.d.ts +8 -1
  66. package/dist/src/core/textures/ImageTexture.js +39 -1
  67. package/dist/src/core/textures/ImageTexture.js.map +1 -1
  68. package/dist/src/core/textures/NoiseTexture.d.ts +1 -1
  69. package/dist/src/core/textures/NoiseTexture.js +2 -1
  70. package/dist/src/core/textures/NoiseTexture.js.map +1 -1
  71. package/dist/src/core/textures/RenderTexture.d.ts +1 -1
  72. package/dist/src/core/textures/RenderTexture.js +2 -1
  73. package/dist/src/core/textures/RenderTexture.js.map +1 -1
  74. package/dist/src/core/textures/SubTexture.d.ts +1 -1
  75. package/dist/src/core/textures/SubTexture.js +21 -4
  76. package/dist/src/core/textures/SubTexture.js.map +1 -1
  77. package/dist/src/core/textures/Texture.d.ts +44 -22
  78. package/dist/src/core/textures/Texture.js +116 -36
  79. package/dist/src/core/textures/Texture.js.map +1 -1
  80. package/dist/src/main-api/Renderer.d.ts +18 -0
  81. package/dist/src/main-api/Renderer.js +6 -4
  82. package/dist/src/main-api/Renderer.js.map +1 -1
  83. package/dist/tsconfig.dist.tsbuildinfo +1 -1
  84. package/exports/canvas.ts +39 -39
  85. package/exports/index.ts +89 -89
  86. package/exports/inspector.ts +24 -24
  87. package/exports/utils.ts +44 -44
  88. package/exports/webgl.ts +38 -38
  89. package/package.json +1 -1
  90. package/scripts/please-use-pnpm.js +13 -13
  91. package/src/common/CommonTypes.ts +139 -139
  92. package/src/common/EventEmitter.ts +77 -77
  93. package/src/common/IAnimationController.ts +92 -92
  94. package/src/common/IEventEmitter.ts +28 -28
  95. package/src/core/CoreNode.test.ts +199 -95
  96. package/src/core/CoreNode.ts +2313 -2258
  97. package/src/core/CoreShaderManager.ts +292 -292
  98. package/src/core/CoreTextNode.ts +455 -450
  99. package/src/core/CoreTextureManager.ts +522 -432
  100. package/src/core/Stage.ts +700 -652
  101. package/src/core/TextureMemoryManager.ts +277 -279
  102. package/src/core/animations/AnimationManager.ts +38 -38
  103. package/src/core/animations/CoreAnimation.ts +340 -340
  104. package/src/core/animations/CoreAnimationController.ts +157 -157
  105. package/src/core/lib/ContextSpy.ts +41 -41
  106. package/src/core/lib/ImageWorker.ts +270 -267
  107. package/src/core/lib/Matrix3d.ts +244 -244
  108. package/src/core/lib/RenderCoords.ts +86 -86
  109. package/src/core/lib/WebGlContextWrapper.ts +1322 -1320
  110. package/src/core/lib/textureCompression.ts +152 -152
  111. package/src/core/lib/textureSvg.ts +78 -78
  112. package/src/core/lib/utils.ts +306 -306
  113. package/src/core/platform.ts +61 -61
  114. package/src/core/renderers/CoreContextTexture.ts +43 -42
  115. package/src/core/renderers/CoreRenderOp.ts +22 -22
  116. package/src/core/renderers/CoreRenderer.ts +114 -114
  117. package/src/core/renderers/CoreShader.ts +41 -41
  118. package/src/core/renderers/canvas/CanvasCoreRenderer.ts +364 -353
  119. package/src/core/renderers/canvas/CanvasCoreTexture.ts +150 -149
  120. package/src/core/renderers/canvas/internal/C2DShaderUtils.ts +231 -231
  121. package/src/core/renderers/canvas/internal/ColorUtils.ts +69 -69
  122. package/src/core/renderers/canvas/shaders/UnsupportedShader.ts +48 -48
  123. package/src/core/renderers/webgl/WebGlCoreCtxRenderTexture.ts +79 -79
  124. package/src/core/renderers/webgl/WebGlCoreCtxSubTexture.ts +50 -48
  125. package/src/core/renderers/webgl/WebGlCoreCtxTexture.ts +298 -290
  126. package/src/core/renderers/webgl/WebGlCoreRenderOp.ts +125 -125
  127. package/src/core/renderers/webgl/WebGlCoreRenderer.ts +805 -817
  128. package/src/core/renderers/webgl/WebGlCoreShader.ts +362 -362
  129. package/src/core/renderers/webgl/internal/BufferCollection.ts +54 -54
  130. package/src/core/renderers/webgl/internal/RendererUtils.ts +155 -155
  131. package/src/core/renderers/webgl/internal/ShaderUtils.ts +143 -143
  132. package/src/core/renderers/webgl/internal/WebGlUtils.ts +35 -35
  133. package/src/core/renderers/webgl/shaders/DefaultShader.ts +93 -93
  134. package/src/core/renderers/webgl/shaders/DefaultShaderBatched.ts +132 -132
  135. package/src/core/renderers/webgl/shaders/DynamicShader.ts +580 -580
  136. package/src/core/renderers/webgl/shaders/RoundedRectangle.ts +167 -167
  137. package/src/core/renderers/webgl/shaders/SdfShader.ts +204 -204
  138. package/src/core/renderers/webgl/shaders/effects/BorderBottomEffect.ts +101 -101
  139. package/src/core/renderers/webgl/shaders/effects/BorderEffect.ts +87 -87
  140. package/src/core/renderers/webgl/shaders/effects/BorderLeftEffect.ts +101 -101
  141. package/src/core/renderers/webgl/shaders/effects/BorderRightEffect.ts +101 -101
  142. package/src/core/renderers/webgl/shaders/effects/BorderTopEffect.ts +101 -101
  143. package/src/core/renderers/webgl/shaders/effects/EffectUtils.ts +159 -159
  144. package/src/core/renderers/webgl/shaders/effects/FadeOutEffect.ts +127 -127
  145. package/src/core/renderers/webgl/shaders/effects/GlitchEffect.ts +148 -148
  146. package/src/core/renderers/webgl/shaders/effects/GrayscaleEffect.ts +67 -67
  147. package/src/core/renderers/webgl/shaders/effects/HolePunchEffect.ts +157 -157
  148. package/src/core/renderers/webgl/shaders/effects/LinearGradientEffect.ts +171 -171
  149. package/src/core/renderers/webgl/shaders/effects/RadialGradientEffect.ts +168 -168
  150. package/src/core/renderers/webgl/shaders/effects/RadialProgressEffect.ts +187 -187
  151. package/src/core/renderers/webgl/shaders/effects/RadiusEffect.ts +110 -110
  152. package/src/core/renderers/webgl/shaders/effects/ShaderEffect.ts +196 -196
  153. package/src/core/text-rendering/TextRenderingUtils.ts +36 -36
  154. package/src/core/text-rendering/TextTextureRendererUtils.ts +263 -263
  155. package/src/core/text-rendering/TrFontManager.ts +183 -183
  156. package/src/core/text-rendering/font-face-types/SdfTrFontFace/SdfTrFontFace.ts +176 -171
  157. package/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/FontShaper.ts +139 -139
  158. package/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/SdfFontShaper.test.ts +173 -173
  159. package/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/SdfFontShaper.ts +171 -171
  160. package/src/core/text-rendering/font-face-types/TrFontFace.ts +187 -187
  161. package/src/core/text-rendering/font-face-types/WebTrFontFace.ts +89 -89
  162. package/src/core/text-rendering/renderers/CanvasTextRenderer.ts +509 -507
  163. package/src/core/text-rendering/renderers/LightningTextTextureRenderer.ts +798 -798
  164. package/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.ts +853 -853
  165. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/PeekableGenerator.test.ts +48 -48
  166. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/PeekableGenerator.ts +66 -66
  167. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/SpecialCodepoints.ts +52 -52
  168. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/constants.ts +32 -32
  169. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/getStartConditions.ts +117 -117
  170. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/getUnicodeCodepoints.test.ts +133 -133
  171. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/getUnicodeCodepoints.ts +38 -38
  172. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText.ts +403 -403
  173. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/measureText.test.ts +49 -49
  174. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/measureText.ts +52 -52
  175. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/setRenderWindow.test.ts +205 -205
  176. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/setRenderWindow.ts +93 -93
  177. package/src/core/text-rendering/renderers/SdfTextRenderer/internal/util.ts +40 -40
  178. package/src/core/text-rendering/renderers/TextRenderer.ts +557 -557
  179. package/src/core/textures/ColorTexture.ts +102 -100
  180. package/src/core/textures/ImageTexture.ts +378 -337
  181. package/src/core/textures/NoiseTexture.ts +104 -101
  182. package/src/core/textures/RenderTexture.ts +85 -83
  183. package/src/core/textures/SubTexture.ts +171 -146
  184. package/src/core/textures/Texture.ts +423 -318
  185. package/src/core/utils.ts +227 -227
  186. package/src/env.d.ts +7 -7
  187. package/src/main-api/DynamicShaderController.ts +104 -104
  188. package/src/main-api/INode.ts +101 -101
  189. package/src/main-api/Inspector.ts +505 -505
  190. package/src/main-api/Renderer.ts +693 -670
  191. package/src/main-api/ShaderController.ts +80 -80
  192. package/src/main-api/utils.ts +45 -45
  193. package/src/utils.ts +248 -248
@@ -47,25 +47,25 @@ export class BorderTopEffect extends ShaderEffect {
47
47
  },
48
48
  };
49
49
  static methods = {
50
- fillMask: `
51
- float function(float dist) {
52
- return clamp(-dist, 0.0, 1.0);
53
- }
50
+ fillMask: `
51
+ float function(float dist) {
52
+ return clamp(-dist, 0.0, 1.0);
53
+ }
54
54
  `,
55
- rectDist: `
56
- float function(vec2 p, vec2 size) {
57
- vec2 d = abs(p) - size;
58
- return min(max(d.x, d.y), 0.0) + length(max(d, 0.0));
59
- }
55
+ rectDist: `
56
+ float function(vec2 p, vec2 size) {
57
+ vec2 d = abs(p) - size;
58
+ return min(max(d.x, d.y), 0.0) + length(max(d, 0.0));
59
+ }
60
60
  `,
61
61
  };
62
- static onEffectMask = `
63
- vec2 pos = vec2(0.0, width * 0.5);
64
- float mask = $rectDist(v_textureCoordinate.xy * u_dimensions - pos, vec2(u_dimensions.x, width*0.5));
65
- return mix(shaderColor, maskColor, $fillMask(mask));
62
+ static onEffectMask = `
63
+ vec2 pos = vec2(0.0, width * 0.5);
64
+ float mask = $rectDist(v_textureCoordinate.xy * u_dimensions - pos, vec2(u_dimensions.x, width*0.5));
65
+ return mix(shaderColor, maskColor, $fillMask(mask));
66
66
  `;
67
- static onColorize = `
68
- return color;
67
+ static onColorize = `
68
+ return color;
69
69
  `;
70
70
  }
71
71
  //# sourceMappingURL=BorderTopEffect.js.map
@@ -38,48 +38,48 @@ export class FadeOutEffect extends ShaderEffect {
38
38
  fade: props.fade ?? 10,
39
39
  };
40
40
  }
41
- static onColorize = `
42
- vec2 point = v_textureCoordinate.xy * u_dimensions.xy;
43
- vec2 pos1;
44
- vec2 pos2;
45
- vec2 d;
46
- float c;
47
- vec4 result = maskColor;
48
-
49
-
50
- if(fade[0] > 0.0) {
51
- pos1 = vec2(point.x, point.y);
52
- pos2 = vec2(point.x, point.y + fade[0]);
53
- d = pos2 - pos1;
54
- c = dot(pos1, d) / dot(d, d);
55
- result = mix(vec4(0.0), result, smoothstep(0.0, 1.0, clamp(c, 0.0, 1.0)));
56
- }
57
-
58
- if(fade[1] > 0.0) {
59
- pos1 = vec2(point.x - u_dimensions.x - fade[1], v_textureCoordinate.y);
60
- pos2 = vec2(point.x - u_dimensions.x, v_textureCoordinate.y);
61
- d = pos1 - pos2;
62
- c = dot(pos2, d) / dot(d, d);
63
- result = mix(vec4(0.0), result, smoothstep(0.0, 1.0, clamp(c, 0.0, 1.0)));
64
- }
65
-
66
- if(fade[2] > 0.0) {
67
- pos1 = vec2(v_textureCoordinate.x, point.y - u_dimensions.y - fade[2]);
68
- pos2 = vec2(v_textureCoordinate.x, point.y - u_dimensions.y);
69
- d = pos1 - pos2;
70
- c = dot(pos2, d) / dot(d, d);
71
- result = mix(vec4(0.0), result, smoothstep(0.0, 1.0, clamp(c, 0.0, 1.0)));
72
- }
73
-
74
- if(fade[3] > 0.0) {
75
- pos1 = vec2(point.x, point.y);
76
- pos2 = vec2(point.x + fade[3], point.y);
77
- d = pos2 - pos1;
78
- c = dot(pos1, d) / dot(d, d);
79
- result = mix(vec4(0.0), result, smoothstep(0.0, 1.0, clamp(c, 0.0, 1.0)));
80
- }
81
-
82
- return result;
41
+ static onColorize = `
42
+ vec2 point = v_textureCoordinate.xy * u_dimensions.xy;
43
+ vec2 pos1;
44
+ vec2 pos2;
45
+ vec2 d;
46
+ float c;
47
+ vec4 result = maskColor;
48
+
49
+
50
+ if(fade[0] > 0.0) {
51
+ pos1 = vec2(point.x, point.y);
52
+ pos2 = vec2(point.x, point.y + fade[0]);
53
+ d = pos2 - pos1;
54
+ c = dot(pos1, d) / dot(d, d);
55
+ result = mix(vec4(0.0), result, smoothstep(0.0, 1.0, clamp(c, 0.0, 1.0)));
56
+ }
57
+
58
+ if(fade[1] > 0.0) {
59
+ pos1 = vec2(point.x - u_dimensions.x - fade[1], v_textureCoordinate.y);
60
+ pos2 = vec2(point.x - u_dimensions.x, v_textureCoordinate.y);
61
+ d = pos1 - pos2;
62
+ c = dot(pos2, d) / dot(d, d);
63
+ result = mix(vec4(0.0), result, smoothstep(0.0, 1.0, clamp(c, 0.0, 1.0)));
64
+ }
65
+
66
+ if(fade[2] > 0.0) {
67
+ pos1 = vec2(v_textureCoordinate.x, point.y - u_dimensions.y - fade[2]);
68
+ pos2 = vec2(v_textureCoordinate.x, point.y - u_dimensions.y);
69
+ d = pos1 - pos2;
70
+ c = dot(pos2, d) / dot(d, d);
71
+ result = mix(vec4(0.0), result, smoothstep(0.0, 1.0, clamp(c, 0.0, 1.0)));
72
+ }
73
+
74
+ if(fade[3] > 0.0) {
75
+ pos1 = vec2(point.x, point.y);
76
+ pos2 = vec2(point.x + fade[3], point.y);
77
+ d = pos2 - pos1;
78
+ c = dot(pos1, d) / dot(d, d);
79
+ result = mix(vec4(0.0), result, smoothstep(0.0, 1.0, clamp(c, 0.0, 1.0)));
80
+ }
81
+
82
+ return result;
83
83
  `;
84
84
  }
85
85
  //# sourceMappingURL=FadeOutEffect.js.map
@@ -51,54 +51,54 @@ export class GlitchEffect extends ShaderEffect {
51
51
  },
52
52
  };
53
53
  static methods = {
54
- rand: `
55
- float function(vec2 p, float time) {
56
- float t = floor(time * 20.) / 10.;
57
- return fract(sin(dot(p, vec2(t * 12.9898, t * 78.233))) * 43758.5453);
58
- }
54
+ rand: `
55
+ float function(vec2 p, float time) {
56
+ float t = floor(time * 20.) / 10.;
57
+ return fract(sin(dot(p, vec2(t * 12.9898, t * 78.233))) * 43758.5453);
58
+ }
59
59
  `,
60
- noise: `
61
- float function(vec2 uv, float blockiness, float time) {
62
- vec2 lv = fract(uv);
63
- vec2 id = floor(uv);
64
-
65
- float n1 = rand(id, time);
66
- float n2 = rand(id+vec2(1,0), time);
67
- float n3 = rand(id+vec2(0,1), time);
68
- float n4 = rand(id+vec2(1,1), time);
69
- vec2 u = smoothstep(0.0, 1.0 + blockiness, lv);
70
- return mix(mix(n1, n2, u.x), mix(n3, n4, u.x), u.y);
71
- }
60
+ noise: `
61
+ float function(vec2 uv, float blockiness, float time) {
62
+ vec2 lv = fract(uv);
63
+ vec2 id = floor(uv);
64
+
65
+ float n1 = rand(id, time);
66
+ float n2 = rand(id+vec2(1,0), time);
67
+ float n3 = rand(id+vec2(0,1), time);
68
+ float n4 = rand(id+vec2(1,1), time);
69
+ vec2 u = smoothstep(0.0, 1.0 + blockiness, lv);
70
+ return mix(mix(n1, n2, u.x), mix(n3, n4, u.x), u.y);
71
+ }
72
72
  `,
73
- fbm: `
74
- float function(vec2 uv, int count, float blockiness, float complexity, float time) {
75
- float val = 0.0;
76
- float amp = 0.5;
77
- const int MAX_ITERATIONS = 10;
78
-
79
- for(int i = 0; i < MAX_ITERATIONS; i++) {
80
- if(i >= count) {break;}
81
- val += amp * noise(uv, blockiness, time);
82
- amp *= 0.5;
83
- uv *= complexity;
84
- }
85
- return val;
86
- }
73
+ fbm: `
74
+ float function(vec2 uv, int count, float blockiness, float complexity, float time) {
75
+ float val = 0.0;
76
+ float amp = 0.5;
77
+ const int MAX_ITERATIONS = 10;
78
+
79
+ for(int i = 0; i < MAX_ITERATIONS; i++) {
80
+ if(i >= count) {break;}
81
+ val += amp * noise(uv, blockiness, time);
82
+ amp *= 0.5;
83
+ uv *= complexity;
84
+ }
85
+ return val;
86
+ }
87
87
  `,
88
88
  };
89
- static onColorize = `
90
- vec2 uv = v_textureCoordinate.xy;
91
- float aspect = u_dimensions.x / u_dimensions.y;
92
- vec2 a = vec2(uv.x * aspect , uv.y);
93
- vec2 uv2 = vec2(a.x / u_dimensions.x, exp(a.y));
94
-
95
- float shift = amplitude * pow($fbm(uv2, 4, blockiness, narrowness, time), minimizer);
96
- float colR = texture2D(u_texture, vec2(uv.x + shift, uv.y)).r * (1. - shift);
97
- float colG = texture2D(u_texture, vec2(uv.x - shift, uv.y)).g * (1. - shift);
98
- float colB = texture2D(u_texture, vec2(uv.x - shift, uv.y)).b * (1. - shift);
99
-
100
- vec3 f = vec3(colR, colG, colB);
101
- return vec4(f, texture2D(u_texture, vec2(uv.x - shift, uv.y)).a);
89
+ static onColorize = `
90
+ vec2 uv = v_textureCoordinate.xy;
91
+ float aspect = u_dimensions.x / u_dimensions.y;
92
+ vec2 a = vec2(uv.x * aspect , uv.y);
93
+ vec2 uv2 = vec2(a.x / u_dimensions.x, exp(a.y));
94
+
95
+ float shift = amplitude * pow($fbm(uv2, 4, blockiness, narrowness, time), minimizer);
96
+ float colR = texture2D(u_texture, vec2(uv.x + shift, uv.y)).r * (1. - shift);
97
+ float colG = texture2D(u_texture, vec2(uv.x - shift, uv.y)).g * (1. - shift);
98
+ float colB = texture2D(u_texture, vec2(uv.x - shift, uv.y)).b * (1. - shift);
99
+
100
+ vec3 f = vec3(colR, colG, colB);
101
+ return vec4(f, texture2D(u_texture, vec2(uv.x - shift, uv.y)).a);
102
102
  `;
103
103
  }
104
104
  //# sourceMappingURL=GlitchEffect.js.map
@@ -37,9 +37,9 @@ export class GrayscaleEffect extends ShaderEffect {
37
37
  type: 'float',
38
38
  },
39
39
  };
40
- static onColorize = `
41
- float grayness = 0.2 * maskColor.r + 0.6 * maskColor.g + 0.2 * maskColor.b;
42
- return vec4(amount * vec3(grayness) + (1.0 - amount) * maskColor.rgb, maskColor.a);
40
+ static onColorize = `
41
+ float grayness = 0.2 * maskColor.r + 0.6 * maskColor.g + 0.2 * maskColor.b;
42
+ return vec4(amount * vec3(grayness) + (1.0 - amount) * maskColor.rgb, maskColor.a);
43
43
  `;
44
44
  }
45
45
  //# sourceMappingURL=GrayscaleEffect.js.map
@@ -49,32 +49,32 @@ export class HolePunchEffect extends ShaderEffect {
49
49
  };
50
50
  }
51
51
  static methods = {
52
- fillMask: `
53
- float function(float dist) {
54
- return clamp(-dist, 0.0, 1.0);
55
- }
52
+ fillMask: `
53
+ float function(float dist) {
54
+ return clamp(-dist, 0.0, 1.0);
55
+ }
56
56
  `,
57
- boxDist: `
58
- float function(vec2 p, vec2 size, float radius) {
59
- size -= vec2(radius);
60
- vec2 d = abs(p) - size;
61
- return min(max(d.x, d.y), 0.0) + length(max(d, 0.0)) - radius;
62
- }
57
+ boxDist: `
58
+ float function(vec2 p, vec2 size, float radius) {
59
+ size -= vec2(radius);
60
+ vec2 d = abs(p) - size;
61
+ return min(max(d.x, d.y), 0.0) + length(max(d, 0.0)) - radius;
62
+ }
63
63
  `,
64
64
  };
65
- static onShaderMask = `
66
- vec2 halfDimensions = u_dimensions * 0.5;
67
- vec2 size = vec2(width, height) * 0.5;
68
- vec2 basePos = v_textureCoordinate.xy * u_dimensions.xy - vec2(x, y);
69
- vec2 pos = basePos - size;
70
- float r = radius[0] * step(pos.x, 0.5) * step(pos.y, 0.5);
71
- r = r + radius[1] * step(0.5, pos.x) * step(pos.y, 0.5);
72
- r = r + radius[2] * step(0.5, pos.x) * step(0.5, pos.y);
73
- r = r + radius[3] * step(pos.x, 0.5) * step(0.5, pos.y);
74
- return $boxDist(pos, size, r);
65
+ static onShaderMask = `
66
+ vec2 halfDimensions = u_dimensions * 0.5;
67
+ vec2 size = vec2(width, height) * 0.5;
68
+ vec2 basePos = v_textureCoordinate.xy * u_dimensions.xy - vec2(x, y);
69
+ vec2 pos = basePos - size;
70
+ float r = radius[0] * step(pos.x, 0.5) * step(pos.y, 0.5);
71
+ r = r + radius[1] * step(0.5, pos.x) * step(pos.y, 0.5);
72
+ r = r + radius[2] * step(0.5, pos.x) * step(0.5, pos.y);
73
+ r = r + radius[3] * step(pos.x, 0.5) * step(0.5, pos.y);
74
+ return $boxDist(pos, size, r);
75
75
  `;
76
- static onEffectMask = `
77
- return mix(maskColor, vec4(0.0), $fillMask(shaderMask));
76
+ static onEffectMask = `
77
+ return mix(maskColor, vec4(0.0), $fillMask(shaderMask));
78
78
  `;
79
79
  }
80
80
  //# sourceMappingURL=HolePunchEffect.js.map
@@ -82,24 +82,24 @@ export class LinearGradientEffect extends ShaderEffect {
82
82
  },
83
83
  };
84
84
  static methods = {
85
- fromLinear: `
86
- vec4 function(vec4 linearRGB) {
87
- vec4 higher = vec4(1.055)*pow(linearRGB, vec4(1.0/2.4)) - vec4(0.055);
88
- vec4 lower = linearRGB * vec4(12.92);
89
- return mix(higher, lower, 1.0);
90
- }
85
+ fromLinear: `
86
+ vec4 function(vec4 linearRGB) {
87
+ vec4 higher = vec4(1.055)*pow(linearRGB, vec4(1.0/2.4)) - vec4(0.055);
88
+ vec4 lower = linearRGB * vec4(12.92);
89
+ return mix(higher, lower, 1.0);
90
+ }
91
91
  `,
92
- toLinear: `
93
- vec4 function(vec4 sRGB) {
94
- vec4 higher = pow((sRGB + vec4(0.055))/vec4(1.055), vec4(2.4));
95
- vec4 lower = sRGB/vec4(12.92);
96
- return mix(higher, lower, 1.0);
97
- }
92
+ toLinear: `
93
+ vec4 function(vec4 sRGB) {
94
+ vec4 higher = pow((sRGB + vec4(0.055))/vec4(1.055), vec4(2.4));
95
+ vec4 lower = sRGB/vec4(12.92);
96
+ return mix(higher, lower, 1.0);
97
+ }
98
98
  `,
99
- calcPoint: `
100
- vec2 function(float d, float angle) {
101
- return d * vec2(cos(angle), sin(angle)) + (u_dimensions * 0.5);
102
- }
99
+ calcPoint: `
100
+ vec2 function(float d, float angle) {
101
+ return d * vec2(cos(angle), sin(angle)) + (u_dimensions * 0.5);
102
+ }
103
103
  `,
104
104
  };
105
105
  static ColorLoop = (amount) => {
@@ -111,18 +111,18 @@ export class LinearGradientEffect extends ShaderEffect {
111
111
  };
112
112
  static onColorize = (props) => {
113
113
  const colors = props.colors.length || 1;
114
- return `
115
- float a = angle - (PI / 180.0 * 90.0);
116
- float lineDist = abs(u_dimensions.x * cos(a)) + abs(u_dimensions.y * sin(a));
117
- vec2 f = $calcPoint(lineDist * 0.5, a);
118
- vec2 t = $calcPoint(lineDist * 0.5, a + PI);
119
- vec2 gradVec = t - f;
120
- float dist = dot(v_textureCoordinate.xy * u_dimensions - f, gradVec) / dot(gradVec, gradVec);
121
-
122
- float stopCalc = (dist - stops[0]) / (stops[1] - stops[0]);
123
- vec4 colorOut = $fromLinear(mix($toLinear(colors[0]), $toLinear(colors[1]), stopCalc));
124
- ${this.ColorLoop(colors)}
125
- return mix(maskColor, colorOut, clamp(colorOut.a, 0.0, 1.0));
114
+ return `
115
+ float a = angle - (PI / 180.0 * 90.0);
116
+ float lineDist = abs(u_dimensions.x * cos(a)) + abs(u_dimensions.y * sin(a));
117
+ vec2 f = $calcPoint(lineDist * 0.5, a);
118
+ vec2 t = $calcPoint(lineDist * 0.5, a + PI);
119
+ vec2 gradVec = t - f;
120
+ float dist = dot(v_textureCoordinate.xy * u_dimensions - f, gradVec) / dot(gradVec, gradVec);
121
+
122
+ float stopCalc = (dist - stops[0]) / (stops[1] - stops[0]);
123
+ vec4 colorOut = $fromLinear(mix($toLinear(colors[0]), $toLinear(colors[1]), stopCalc));
124
+ ${this.ColorLoop(colors)}
125
+ return mix(maskColor, colorOut, clamp(colorOut.a, 0.0, 1.0));
126
126
  `;
127
127
  };
128
128
  }
@@ -24,10 +24,10 @@ export class RadialGradientEffect extends ShaderEffect {
24
24
  name = 'radialGradient';
25
25
  static getEffectKey(props) {
26
26
  if (props.colors.value) {
27
- return `linearGradient${props.colors.value
27
+ return `radialGradient${props.colors.value
28
28
  .length}`;
29
29
  }
30
- return `linearGradient${props.colors.length}`;
30
+ return `radialGradient${props.colors.length}`;
31
31
  }
32
32
  static resolveDefaults(props) {
33
33
  const colors = props.colors ?? [0xff000000, 0xffffffff];
@@ -100,16 +100,16 @@ export class RadialGradientEffect extends ShaderEffect {
100
100
  };
101
101
  static onColorize = (props) => {
102
102
  const colors = props.colors.length || 1;
103
- return `
104
- vec2 point = v_textureCoordinate.xy * u_dimensions;
105
- vec2 projection = vec2(pivot.x * u_dimensions.x, pivot.y * u_dimensions.y);
106
-
107
- float dist = length((point - projection) / vec2(width, height));
108
-
109
- float stopCalc = (dist - stops[0]) / (stops[1] - stops[0]);
110
- vec4 colorOut = mix(colors[0], colors[1], stopCalc);
111
- ${this.ColorLoop(colors)}
112
- return mix(maskColor, colorOut, clamp(colorOut.a, 0.0, 1.0));
103
+ return `
104
+ vec2 point = v_textureCoordinate.xy * u_dimensions;
105
+ vec2 projection = vec2(pivot.x * u_dimensions.x, pivot.y * u_dimensions.y);
106
+
107
+ float dist = length((point - projection) / vec2(width, height));
108
+
109
+ float stopCalc = (dist - stops[0]) / (stops[1] - stops[0]);
110
+ vec4 colorOut = mix(colors[0], colors[1], stopCalc);
111
+ ${this.ColorLoop(colors)}
112
+ return mix(maskColor, colorOut, clamp(colorOut.a, 0.0, 1.0));
113
113
  `;
114
114
  };
115
115
  }
@@ -81,47 +81,47 @@ export class RadialProgressEffect extends ShaderEffect {
81
81
  },
82
82
  };
83
83
  static methods = {
84
- rotateUV: `
85
- vec2 function(vec2 uv, float d) {
86
- float s = sin(d);
87
- float c = cos(d);
88
- mat2 rotMatrix = mat2(c, -s, s, c);
89
- return uv * rotMatrix;
90
- }
84
+ rotateUV: `
85
+ vec2 function(vec2 uv, float d) {
86
+ float s = sin(d);
87
+ float c = cos(d);
88
+ mat2 rotMatrix = mat2(c, -s, s, c);
89
+ return uv * rotMatrix;
90
+ }
91
91
  `,
92
- drawDot: `
93
- float function(vec2 uv, vec2 p, float r) {
94
- uv += p;
95
- float circle = length(uv) - r;
96
- return clamp(-circle, 0.0, 1.0);
97
- }
92
+ drawDot: `
93
+ float function(vec2 uv, vec2 p, float r) {
94
+ uv += p;
95
+ float circle = length(uv) - r;
96
+ return clamp(-circle, 0.0, 1.0);
97
+ }
98
98
  `,
99
99
  };
100
- static onEffectMask = `
101
- float outerRadius = radius * u_dimensions.y * 0.5;
102
-
103
- float endAngle = range * progress - 0.0005;
104
-
105
- vec2 uv = v_textureCoordinate.xy * u_dimensions.xy - u_dimensions * 0.5;
106
-
107
- uv = $rotateUV(uv, -(offset));
108
- float linewidth = width * u_pixelRatio;
109
- float circle = length(uv) - (outerRadius - linewidth) ;
110
- circle = abs(circle) - linewidth;
111
- circle = clamp(-circle, 0.0, 1.0);
112
-
113
- float angle = (atan(uv.x, -uv.y) / 3.14159265359 * 0.5);
114
- float p = endAngle / (PI * 2.);
115
-
116
- circle *= step(fract(angle), fract(p));
117
-
118
- circle = rounded < 1. ? circle : max(circle, $drawDot(uv, vec2(0, outerRadius - linewidth), linewidth));
119
- circle = rounded < 1. ? circle : max(circle, $drawDot($rotateUV(uv, -(endAngle)), vec2(0, outerRadius - linewidth), linewidth));
120
-
121
- return mix(shaderColor, maskColor, circle);
100
+ static onEffectMask = `
101
+ float outerRadius = radius * u_dimensions.y * 0.5;
102
+
103
+ float endAngle = range * progress - 0.0005;
104
+
105
+ vec2 uv = v_textureCoordinate.xy * u_dimensions.xy - u_dimensions * 0.5;
106
+
107
+ uv = $rotateUV(uv, -(offset));
108
+ float linewidth = width * u_pixelRatio;
109
+ float circle = length(uv) - (outerRadius - linewidth) ;
110
+ circle = abs(circle) - linewidth;
111
+ circle = clamp(-circle, 0.0, 1.0);
112
+
113
+ float angle = (atan(uv.x, -uv.y) / 3.14159265359 * 0.5);
114
+ float p = endAngle / (PI * 2.);
115
+
116
+ circle *= step(fract(angle), fract(p));
117
+
118
+ circle = rounded < 1. ? circle : max(circle, $drawDot(uv, vec2(0, outerRadius - linewidth), linewidth));
119
+ circle = rounded < 1. ? circle : max(circle, $drawDot($rotateUV(uv, -(endAngle)), vec2(0, outerRadius - linewidth), linewidth));
120
+
121
+ return mix(shaderColor, maskColor, circle);
122
122
  `;
123
- static onColorize = `
124
- return color;
123
+ static onColorize = `
124
+ return color;
125
125
  `;
126
126
  }
127
127
  //# sourceMappingURL=RadialProgressEffect.js.map
@@ -38,17 +38,17 @@ export class RadiusEffect extends ShaderEffect {
38
38
  },
39
39
  };
40
40
  static methods = {
41
- fillMask: `
42
- float function(float dist) {
43
- return clamp(-dist, 0.0, 1.0);
44
- }
41
+ fillMask: `
42
+ float function(float dist) {
43
+ return clamp(-dist, 0.0, 1.0);
44
+ }
45
45
  `,
46
- boxDist: `
47
- float function(vec2 p, vec2 size, float radius) {
48
- size -= vec2(radius);
49
- vec2 d = abs(p) - size;
50
- return min(max(d.x, d.y), 0.0) + length(max(d, 0.0)) - radius;
51
- }
46
+ boxDist: `
47
+ float function(vec2 p, vec2 size, float radius) {
48
+ size -= vec2(radius);
49
+ vec2 d = abs(p) - size;
50
+ return min(max(d.x, d.y), 0.0) + length(max(d, 0.0)) - radius;
51
+ }
52
52
  `,
53
53
  };
54
54
  static resolveDefaults(props) {
@@ -56,16 +56,16 @@ export class RadiusEffect extends ShaderEffect {
56
56
  radius: props.radius ?? 10,
57
57
  };
58
58
  }
59
- static onShaderMask = `
60
- vec2 halfDimensions = u_dimensions * 0.5;
61
- float r = radius[0] * step(v_textureCoordinate.x, 0.5) * step(v_textureCoordinate.y, 0.5);
62
- r = r + radius[1] * step(0.5, v_textureCoordinate.x) * step(v_textureCoordinate.y, 0.5);
63
- r = r + radius[2] * step(0.5, v_textureCoordinate.x) * step(0.5, v_textureCoordinate.y);
64
- r = r + radius[3] * step(v_textureCoordinate.x, 0.5) * step(0.5, v_textureCoordinate.y);
65
- return $boxDist(v_textureCoordinate.xy * u_dimensions - halfDimensions, halfDimensions, r);
59
+ static onShaderMask = `
60
+ vec2 halfDimensions = u_dimensions * 0.5;
61
+ float r = radius[0] * step(v_textureCoordinate.x, 0.5) * step(v_textureCoordinate.y, 0.5);
62
+ r = r + radius[1] * step(0.5, v_textureCoordinate.x) * step(v_textureCoordinate.y, 0.5);
63
+ r = r + radius[2] * step(0.5, v_textureCoordinate.x) * step(0.5, v_textureCoordinate.y);
64
+ r = r + radius[3] * step(v_textureCoordinate.x, 0.5) * step(0.5, v_textureCoordinate.y);
65
+ return $boxDist(v_textureCoordinate.xy * u_dimensions - halfDimensions, halfDimensions, r);
66
66
  `;
67
- static onEffectMask = `
68
- return mix(vec4(0.0), maskColor, $fillMask(shaderMask));
67
+ static onEffectMask = `
68
+ return mix(vec4(0.0), maskColor, $fillMask(shaderMask));
69
69
  `;
70
70
  }
71
71
  //# sourceMappingURL=RadiusEffect.js.map
@@ -40,7 +40,7 @@ export class SdfTrFontFace extends TrFontFace {
40
40
  const renderer = stage.renderer;
41
41
  assertTruthy(renderer instanceof WebGlCoreRenderer, 'SDF Font Faces can only be used with the WebGL Renderer');
42
42
  // Load image
43
- this.texture = stage.txManager.loadTexture('ImageTexture', {
43
+ this.texture = stage.txManager.createTexture('ImageTexture', {
44
44
  src: atlasUrl,
45
45
  // IMPORTANT: The SDF shader requires the alpha channel to NOT be
46
46
  // premultiplied on the atlas texture. If it is premultiplied, the
@@ -48,15 +48,19 @@ export class SdfTrFontFace extends TrFontFace {
48
48
  // be very jagged.
49
49
  premultiplyAlpha: false,
50
50
  });
51
+ // Load the texture
52
+ stage.txManager.loadTexture(this.texture, true);
53
+ // FIXME This is a stop-gap solution to avoid Font Face textures to be cleaned up
54
+ // Ideally we do want to clean up the textures if they're not being used to save as much memory as possible
55
+ // However, we need to make sure that the font face is reloaded if the texture is cleaned up and needed again
56
+ // and make sure the SdfFontRenderer is properly guarded against textures being reloaded
57
+ // for now this will do the trick and the increase on memory is not that big
58
+ this.texture.preventCleanup = true;
51
59
  this.texture.on('loaded', () => {
52
60
  this.checkLoaded();
53
61
  // Make sure we mark the stage for a re-render (in case the font's texture was freed and reloaded)
54
62
  stage.requestRender();
55
63
  });
56
- // Pre-load it
57
- stage.txManager.once('initialized', () => {
58
- this.texture.ctxTexture.load();
59
- });
60
64
  // Set this.data to the fetched data from dataUrl
61
65
  fetch(atlasDataUrl)
62
66
  .then(async (response) => {
@@ -1 +1 @@
1
- {"version":3,"file":"SdfTrFontFace.js","sourceRoot":"","sources":["../../../../../../src/core/text-rendering/font-face-types/SdfTrFontFace/SdfTrFontFace.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"SdfTrFontFace.js","sourceRoot":"","sources":["../../../../../../src/core/text-rendering/font-face-types/SdfTrFontFace/SdfTrFontFace.ts"],"names":[],"mappings":"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"}
@@ -261,7 +261,8 @@ export class CanvasTextRenderer extends TextRenderer {
261
261
  renderSingleCanvasPage(state) {
262
262
  assertTruthy(state.renderInfo);
263
263
  const node = state.node;
264
- const texture = this.stage.txManager.loadTexture('ImageTexture', {
264
+ const texture = this.stage.txManager.createTexture('ImageTexture', {
265
+ premultiplyAlpha: true,
265
266
  src: function (lightning2TextRenderer, renderInfo) {
266
267
  // load the canvas texture
267
268
  assertTruthy(renderInfo);