@lightningjs/renderer 2.8.0 → 2.9.0-beta2
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.
- package/README.md +7 -4
- package/dist/src/common/EventEmitter.js.map +1 -1
- package/dist/src/core/CoreNode.js.map +1 -1
- package/dist/src/core/CoreShaderManager.js.map +1 -1
- package/dist/src/core/CoreTextNode.js.map +1 -1
- package/dist/src/core/CoreTextureManager.d.ts +13 -1
- package/dist/src/core/CoreTextureManager.js +163 -7
- package/dist/src/core/CoreTextureManager.js.map +1 -1
- package/dist/src/core/Stage.js +1 -1
- package/dist/src/core/Stage.js.map +1 -1
- package/dist/src/core/TextureMemoryManager.js.map +1 -1
- package/dist/src/core/animations/CoreAnimation.js.map +1 -1
- package/dist/src/core/animations/CoreAnimationController.js.map +1 -1
- package/dist/src/core/lib/ContextSpy.js.map +1 -1
- package/dist/src/core/lib/ImageWorker.d.ts +2 -1
- package/dist/src/core/lib/ImageWorker.js +40 -11
- package/dist/src/core/lib/ImageWorker.js.map +1 -1
- package/dist/src/core/lib/Matrix3d.js.map +1 -1
- package/dist/src/core/lib/RenderCoords.js.map +1 -1
- package/dist/src/core/lib/WebGlContextWrapper.d.ts +10 -0
- package/dist/src/core/lib/WebGlContextWrapper.js +15 -0
- package/dist/src/core/lib/WebGlContextWrapper.js.map +1 -1
- package/dist/src/core/lib/textureCompression.js.map +1 -1
- package/dist/src/core/lib/utils.js.map +1 -1
- package/dist/src/core/platform.js.map +1 -1
- package/dist/src/core/renderers/canvas/CanvasCoreRenderer.js +10 -5
- package/dist/src/core/renderers/canvas/CanvasCoreRenderer.js.map +1 -1
- package/dist/src/core/renderers/canvas/CanvasCoreTexture.d.ts +3 -3
- package/dist/src/core/renderers/canvas/CanvasCoreTexture.js +2 -2
- package/dist/src/core/renderers/canvas/CanvasCoreTexture.js.map +1 -1
- package/dist/src/core/renderers/canvas/internal/C2DShaderUtils.d.ts +1 -0
- package/dist/src/core/renderers/canvas/internal/C2DShaderUtils.js +38 -0
- package/dist/src/core/renderers/canvas/internal/C2DShaderUtils.js.map +1 -1
- package/dist/src/core/renderers/canvas/internal/ColorUtils.js.map +1 -1
- package/dist/src/core/renderers/webgl/WebGlCoreCtxSubTexture.js.map +1 -1
- package/dist/src/core/renderers/webgl/WebGlCoreCtxTexture.js +12 -13
- package/dist/src/core/renderers/webgl/WebGlCoreCtxTexture.js.map +1 -1
- package/dist/src/core/renderers/webgl/WebGlCoreRenderOp.js +9 -3
- package/dist/src/core/renderers/webgl/WebGlCoreRenderOp.js.map +1 -1
- package/dist/src/core/renderers/webgl/WebGlCoreRenderer.js +4 -4
- package/dist/src/core/renderers/webgl/WebGlCoreRenderer.js.map +1 -1
- package/dist/src/core/renderers/webgl/WebGlCoreShader.js +6 -1
- package/dist/src/core/renderers/webgl/WebGlCoreShader.js.map +1 -1
- package/dist/src/core/renderers/webgl/internal/RendererUtils.js +6 -4
- package/dist/src/core/renderers/webgl/internal/RendererUtils.js.map +1 -1
- package/dist/src/core/renderers/webgl/internal/ShaderUtils.js +4 -3
- package/dist/src/core/renderers/webgl/internal/ShaderUtils.js.map +1 -1
- package/dist/src/core/renderers/webgl/shaders/DefaultShaderBatched.js.map +1 -1
- package/dist/src/core/renderers/webgl/shaders/DynamicShader.js.map +1 -1
- package/dist/src/core/renderers/webgl/shaders/SdfShader.js.map +1 -1
- package/dist/src/core/renderers/webgl/shaders/effects/EffectUtils.js.map +1 -1
- package/dist/src/core/renderers/webgl/shaders/effects/LinearGradientEffect.js.map +1 -1
- package/dist/src/core/renderers/webgl/shaders/effects/RadialGradientEffect.js.map +1 -1
- package/dist/src/core/renderers/webgl/shaders/effects/ShaderEffect.js.map +1 -1
- package/dist/src/core/text-rendering/TextTextureRendererUtils.js.map +1 -1
- package/dist/src/core/text-rendering/TrFontManager.js.map +1 -1
- package/dist/src/core/text-rendering/font-face-types/SdfTrFontFace/SdfTrFontFace.js +3 -4
- package/dist/src/core/text-rendering/font-face-types/SdfTrFontFace/SdfTrFontFace.js.map +1 -1
- package/dist/src/core/text-rendering/font-face-types/SdfTrFontFace/internal/SdfFontShaper.js.map +1 -1
- package/dist/src/core/text-rendering/font-face-types/TrFontFace.js.map +1 -1
- package/dist/src/core/text-rendering/font-face-types/WebTrFontFace.js.map +1 -1
- package/dist/src/core/text-rendering/renderers/CanvasTextRenderer.js +1 -2
- package/dist/src/core/text-rendering/renderers/CanvasTextRenderer.js.map +1 -1
- package/dist/src/core/text-rendering/renderers/LightningTextTextureRenderer.js.map +1 -1
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.js +4 -4
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.js.map +1 -1
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/PeekableGenerator.js.map +1 -1
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/getStartConditions.js.map +1 -1
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/getUnicodeCodepoints.js.map +1 -1
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/layoutText.js.map +1 -1
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/measureText.js.map +1 -1
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/setRenderWindow.js.map +1 -1
- package/dist/src/core/text-rendering/renderers/TextRenderer.js +1 -1
- package/dist/src/core/text-rendering/renderers/TextRenderer.js.map +1 -1
- package/dist/src/core/textures/ColorTexture.js.map +1 -1
- package/dist/src/core/textures/ImageTexture.d.ts +8 -0
- package/dist/src/core/textures/ImageTexture.js +55 -39
- package/dist/src/core/textures/ImageTexture.js.map +1 -1
- package/dist/src/core/textures/NoiseTexture.js.map +1 -1
- package/dist/src/core/textures/SubTexture.js.map +1 -1
- package/dist/src/core/textures/Texture.js.map +1 -1
- package/dist/src/core/utils.d.ts +1 -1
- package/dist/src/core/utils.js.map +1 -1
- package/dist/src/main-api/DynamicShaderController.js.map +1 -1
- package/dist/src/main-api/Inspector.js +1 -1
- package/dist/src/main-api/Inspector.js.map +1 -1
- package/dist/src/main-api/Renderer.js.map +1 -1
- package/dist/src/main-api/ShaderController.js.map +1 -1
- package/dist/src/main-api/utils.js.map +1 -1
- package/dist/src/utils.js.map +1 -1
- package/dist/tsconfig.dist.tsbuildinfo +1 -1
- package/package.json +10 -11
- package/src/core/CoreTextureManager.ts +188 -10
- package/src/core/lib/ImageWorker.ts +63 -11
- package/src/core/lib/WebGlContextWrapper.ts +16 -0
- package/src/core/renderers/canvas/CanvasCoreRenderer.ts +15 -5
- package/src/core/renderers/canvas/CanvasCoreTexture.ts +11 -5
- package/src/core/renderers/canvas/internal/C2DShaderUtils.ts +93 -0
- package/src/core/renderers/webgl/WebGlCoreCtxTexture.ts +12 -19
- package/src/core/renderers/webgl/WebGlCoreRenderOp.ts +12 -5
- package/src/core/renderers/webgl/WebGlCoreShader.ts +7 -1
- package/src/core/renderers/webgl/internal/RendererUtils.ts +5 -3
- package/src/core/renderers/webgl/internal/ShaderUtils.ts +9 -3
- package/src/core/text-rendering/font-face-types/SdfTrFontFace/SdfTrFontFace.ts +6 -4
- package/src/core/text-rendering/renderers/CanvasTextRenderer.ts +3 -4
- package/src/core/textures/ImageTexture.ts +82 -45
- package/src/main-api/Inspector.ts +1 -1
- package/dist/exports/core-api.d.ts +0 -74
- package/dist/exports/core-api.js +0 -96
- package/dist/exports/core-api.js.map +0 -1
- package/dist/exports/main-api.d.ts +0 -30
- package/dist/exports/main-api.js +0 -45
- package/dist/exports/main-api.js.map +0 -1
- package/dist/src/core/CoreExtension.d.ts +0 -12
- package/dist/src/core/CoreExtension.js +0 -29
- package/dist/src/core/CoreExtension.js.map +0 -1
- package/dist/src/core/CoreStuff.d.ts +0 -1
- package/dist/src/core/CoreStuff.js +0 -138
- package/dist/src/core/CoreStuff.js.map +0 -1
- package/dist/src/core/LngNode.d.ts +0 -736
- package/dist/src/core/LngNode.js +0 -1174
- package/dist/src/core/LngNode.js.map +0 -1
- package/dist/src/core/Matrix2DContext.d.ts +0 -15
- package/dist/src/core/Matrix2DContext.js +0 -45
- package/dist/src/core/Matrix2DContext.js.map +0 -1
- package/dist/src/core/ShaderNode.d.ts +0 -10
- package/dist/src/core/ShaderNode.js +0 -30
- package/dist/src/core/ShaderNode.js.map +0 -1
- package/dist/src/core/TextNode.d.ts +0 -103
- package/dist/src/core/TextNode.js +0 -331
- package/dist/src/core/TextNode.js.map +0 -1
- package/dist/src/core/lib/Coords.d.ts +0 -14
- package/dist/src/core/lib/Coords.js +0 -55
- package/dist/src/core/lib/Coords.js.map +0 -1
- package/dist/src/core/lib/glm/common.d.ts +0 -162
- package/dist/src/core/lib/glm/common.js +0 -81
- package/dist/src/core/lib/glm/common.js.map +0 -1
- package/dist/src/core/lib/glm/index.d.ts +0 -11
- package/dist/src/core/lib/glm/index.js +0 -30
- package/dist/src/core/lib/glm/index.js.map +0 -1
- package/dist/src/core/lib/glm/mat2.d.ts +0 -219
- package/dist/src/core/lib/glm/mat2.js +0 -396
- package/dist/src/core/lib/glm/mat2.js.map +0 -1
- package/dist/src/core/lib/glm/mat2d.d.ts +0 -237
- package/dist/src/core/lib/glm/mat2d.js +0 -442
- package/dist/src/core/lib/glm/mat2d.js.map +0 -1
- package/dist/src/core/lib/glm/mat3.d.ts +0 -283
- package/dist/src/core/lib/glm/mat3.js +0 -680
- package/dist/src/core/lib/glm/mat3.js.map +0 -1
- package/dist/src/core/lib/glm/mat4.d.ts +0 -550
- package/dist/src/core/lib/glm/mat4.js +0 -1802
- package/dist/src/core/lib/glm/mat4.js.map +0 -1
- package/dist/src/core/lib/glm/quat.d.ts +0 -363
- package/dist/src/core/lib/glm/quat.js +0 -693
- package/dist/src/core/lib/glm/quat.js.map +0 -1
- package/dist/src/core/lib/glm/quat2.d.ts +0 -356
- package/dist/src/core/lib/glm/quat2.js +0 -754
- package/dist/src/core/lib/glm/quat2.js.map +0 -1
- package/dist/src/core/lib/glm/vec2.d.ts +0 -365
- package/dist/src/core/lib/glm/vec2.js +0 -569
- package/dist/src/core/lib/glm/vec2.js.map +0 -1
- package/dist/src/core/lib/glm/vec3.d.ts +0 -406
- package/dist/src/core/lib/glm/vec3.js +0 -720
- package/dist/src/core/lib/glm/vec3.js.map +0 -1
- package/dist/src/core/lib/glm/vec4.d.ts +0 -330
- package/dist/src/core/lib/glm/vec4.js +0 -608
- package/dist/src/core/lib/glm/vec4.js.map +0 -1
- package/dist/src/core/renderers/CoreShaderManager.d.ts +0 -19
- package/dist/src/core/renderers/CoreShaderManager.js +0 -33
- package/dist/src/core/renderers/CoreShaderManager.js.map +0 -1
- package/dist/src/core/renderers/webgl/WebGlCoreShaderManager.d.ts +0 -27
- package/dist/src/core/renderers/webgl/WebGlCoreShaderManager.js +0 -82
- package/dist/src/core/renderers/webgl/WebGlCoreShaderManager.js.map +0 -1
- package/dist/src/core/renderers/webgl/WebGlCoreShaderProgram.d.ts +0 -11
- package/dist/src/core/renderers/webgl/WebGlCoreShaderProgram.js +0 -34
- package/dist/src/core/renderers/webgl/WebGlCoreShaderProgram.js.map +0 -1
- package/dist/src/core/scene/Scene.d.ts +0 -59
- package/dist/src/core/scene/Scene.js +0 -106
- package/dist/src/core/scene/Scene.js.map +0 -1
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/makeRenderWindow.d.ts +0 -20
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/makeRenderWindow.js +0 -55
- package/dist/src/core/text-rendering/renderers/SdfTextRenderer/internal/makeRenderWindow.js.map +0 -1
- package/dist/src/main-api/ICoreDriver.d.ts +0 -27
- package/dist/src/main-api/ICoreDriver.js +0 -20
- package/dist/src/main-api/ICoreDriver.js.map +0 -1
- package/dist/src/main-api/IRenderDriver.d.ts +0 -20
- package/dist/src/main-api/IRenderDriver.js +0 -20
- package/dist/src/main-api/IRenderDriver.js.map +0 -1
- package/dist/src/main-api/IShaderController.d.ts +0 -14
- package/dist/src/main-api/IShaderController.js +0 -30
- package/dist/src/main-api/IShaderController.js.map +0 -1
- package/dist/src/main-api/IShaderNode.d.ts +0 -17
- package/dist/src/main-api/IShaderNode.js +0 -19
- package/dist/src/main-api/IShaderNode.js.map +0 -1
- package/dist/src/main-api/RendererMain.d.ts +0 -375
- package/dist/src/main-api/RendererMain.js +0 -365
- package/dist/src/main-api/RendererMain.js.map +0 -1
- package/dist/src/main-api/texture-usage-trackers/FinalizationRegistryTextureUsageTracker.d.ts +0 -9
- package/dist/src/main-api/texture-usage-trackers/FinalizationRegistryTextureUsageTracker.js +0 -38
- package/dist/src/main-api/texture-usage-trackers/FinalizationRegistryTextureUsageTracker.js.map +0 -1
- package/dist/src/main-api/texture-usage-trackers/ManualCountTextureUsageTracker.d.ts +0 -56
- package/dist/src/main-api/texture-usage-trackers/ManualCountTextureUsageTracker.js +0 -101
- package/dist/src/main-api/texture-usage-trackers/ManualCountTextureUsageTracker.js.map +0 -1
- package/dist/src/main-api/texture-usage-trackers/TextureUsageTracker.d.ts +0 -32
- package/dist/src/main-api/texture-usage-trackers/TextureUsageTracker.js +0 -28
- package/dist/src/main-api/texture-usage-trackers/TextureUsageTracker.js.map +0 -1
- package/dist/src/render-drivers/main/MainCoreDriver.d.ts +0 -24
- package/dist/src/render-drivers/main/MainCoreDriver.js +0 -118
- package/dist/src/render-drivers/main/MainCoreDriver.js.map +0 -1
- package/dist/src/render-drivers/main/MainOnlyNode.d.ts +0 -99
- package/dist/src/render-drivers/main/MainOnlyNode.js +0 -396
- package/dist/src/render-drivers/main/MainOnlyNode.js.map +0 -1
- package/dist/src/render-drivers/main/MainOnlyShaderController.d.ts +0 -6
- package/dist/src/render-drivers/main/MainOnlyShaderController.js +0 -15
- package/dist/src/render-drivers/main/MainOnlyShaderController.js.map +0 -1
- package/dist/src/render-drivers/main/MainOnlyShaderNode.d.ts +0 -7
- package/dist/src/render-drivers/main/MainOnlyShaderNode.js +0 -34
- package/dist/src/render-drivers/main/MainOnlyShaderNode.js.map +0 -1
- package/dist/src/render-drivers/main/MainOnlyTextNode.d.ts +0 -47
- package/dist/src/render-drivers/main/MainOnlyTextNode.js +0 -205
- package/dist/src/render-drivers/main/MainOnlyTextNode.js.map +0 -1
- package/dist/src/render-drivers/main/MainRenderDriver.d.ts +0 -17
- package/dist/src/render-drivers/main/MainRenderDriver.js +0 -88
- package/dist/src/render-drivers/main/MainRenderDriver.js.map +0 -1
- package/dist/src/render-drivers/threadx/NodeStruct.d.ts +0 -90
- package/dist/src/render-drivers/threadx/NodeStruct.js +0 -281
- package/dist/src/render-drivers/threadx/NodeStruct.js.map +0 -1
- package/dist/src/render-drivers/threadx/SharedNode.d.ts +0 -39
- package/dist/src/render-drivers/threadx/SharedNode.js +0 -60
- package/dist/src/render-drivers/threadx/SharedNode.js.map +0 -1
- package/dist/src/render-drivers/threadx/TextNodeStruct.d.ts +0 -44
- package/dist/src/render-drivers/threadx/TextNodeStruct.js +0 -201
- package/dist/src/render-drivers/threadx/TextNodeStruct.js.map +0 -1
- package/dist/src/render-drivers/threadx/ThreadXCoreDriver.d.ts +0 -28
- package/dist/src/render-drivers/threadx/ThreadXCoreDriver.js +0 -234
- package/dist/src/render-drivers/threadx/ThreadXCoreDriver.js.map +0 -1
- package/dist/src/render-drivers/threadx/ThreadXMainAnimationController.d.ts +0 -20
- package/dist/src/render-drivers/threadx/ThreadXMainAnimationController.js +0 -84
- package/dist/src/render-drivers/threadx/ThreadXMainAnimationController.js.map +0 -1
- package/dist/src/render-drivers/threadx/ThreadXMainNode.d.ts +0 -44
- package/dist/src/render-drivers/threadx/ThreadXMainNode.js +0 -154
- package/dist/src/render-drivers/threadx/ThreadXMainNode.js.map +0 -1
- package/dist/src/render-drivers/threadx/ThreadXMainShaderController.d.ts +0 -6
- package/dist/src/render-drivers/threadx/ThreadXMainShaderController.js +0 -16
- package/dist/src/render-drivers/threadx/ThreadXMainShaderController.js.map +0 -1
- package/dist/src/render-drivers/threadx/ThreadXMainShaderNode.d.ts +0 -7
- package/dist/src/render-drivers/threadx/ThreadXMainShaderNode.js +0 -15
- package/dist/src/render-drivers/threadx/ThreadXMainShaderNode.js.map +0 -1
- package/dist/src/render-drivers/threadx/ThreadXMainTextNode.d.ts +0 -28
- package/dist/src/render-drivers/threadx/ThreadXMainTextNode.js +0 -55
- package/dist/src/render-drivers/threadx/ThreadXMainTextNode.js.map +0 -1
- package/dist/src/render-drivers/threadx/ThreadXRenderDriver.d.ts +0 -21
- package/dist/src/render-drivers/threadx/ThreadXRenderDriver.js +0 -198
- package/dist/src/render-drivers/threadx/ThreadXRenderDriver.js.map +0 -1
- package/dist/src/render-drivers/threadx/ThreadXRendererMessage.d.ts +0 -70
- package/dist/src/render-drivers/threadx/ThreadXRendererMessage.js +0 -32
- package/dist/src/render-drivers/threadx/ThreadXRendererMessage.js.map +0 -1
- package/dist/src/render-drivers/threadx/worker/ThreadXRendererNode.d.ts +0 -19
- package/dist/src/render-drivers/threadx/worker/ThreadXRendererNode.js +0 -177
- package/dist/src/render-drivers/threadx/worker/ThreadXRendererNode.js.map +0 -1
- package/dist/src/render-drivers/threadx/worker/ThreadXRendererTextNode.d.ts +0 -27
- package/dist/src/render-drivers/threadx/worker/ThreadXRendererTextNode.js +0 -108
- package/dist/src/render-drivers/threadx/worker/ThreadXRendererTextNode.js.map +0 -1
- package/dist/src/render-drivers/threadx/worker/renderer.d.ts +0 -1
- package/dist/src/render-drivers/threadx/worker/renderer.js +0 -145
- package/dist/src/render-drivers/threadx/worker/renderer.js.map +0 -1
- package/dist/src/render-drivers/utils.d.ts +0 -12
- package/dist/src/render-drivers/utils.js +0 -69
- package/dist/src/render-drivers/utils.js.map +0 -1
|
@@ -132,61 +132,98 @@ export class ImageTexture extends Texture {
|
|
|
132
132
|
return mimeType.indexOf('image/png') !== -1;
|
|
133
133
|
}
|
|
134
134
|
|
|
135
|
-
async
|
|
136
|
-
const
|
|
135
|
+
async loadImageFallback(src: string, hasAlpha: boolean) {
|
|
136
|
+
const img = new Image();
|
|
137
137
|
|
|
138
|
-
if (
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
premultiplyAlpha,
|
|
142
|
-
sx,
|
|
143
|
-
sy,
|
|
144
|
-
sw,
|
|
145
|
-
sh,
|
|
146
|
-
);
|
|
147
|
-
} else if (this.txManager.hasCreateImageBitmap === true) {
|
|
148
|
-
const response = await fetch(src);
|
|
149
|
-
const blob = await response.blob();
|
|
150
|
-
const hasAlphaChannel =
|
|
151
|
-
premultiplyAlpha ?? this.hasAlphaChannel(blob.type);
|
|
138
|
+
if (!src.startsWith('data:')) {
|
|
139
|
+
img.crossOrigin = 'Anonymous';
|
|
140
|
+
}
|
|
152
141
|
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
colorSpaceConversion: 'none',
|
|
158
|
-
imageOrientation: 'none',
|
|
159
|
-
}),
|
|
160
|
-
premultiplyAlpha: hasAlphaChannel,
|
|
142
|
+
return new Promise<{ data: HTMLImageElement; premultiplyAlpha: boolean }>(
|
|
143
|
+
(resolve) => {
|
|
144
|
+
img.onload = () => {
|
|
145
|
+
resolve({ data: img, premultiplyAlpha: hasAlpha });
|
|
161
146
|
};
|
|
162
|
-
}
|
|
163
147
|
|
|
148
|
+
img.onerror = () => {
|
|
149
|
+
console.warn('Image loading failed, returning fallback object.');
|
|
150
|
+
resolve({ data: img, premultiplyAlpha: hasAlpha });
|
|
151
|
+
};
|
|
152
|
+
|
|
153
|
+
img.src = src;
|
|
154
|
+
},
|
|
155
|
+
);
|
|
156
|
+
}
|
|
157
|
+
|
|
158
|
+
async createImageBitmap(
|
|
159
|
+
blob: Blob,
|
|
160
|
+
premultiplyAlpha: boolean | null,
|
|
161
|
+
sx: number | null,
|
|
162
|
+
sy: number | null,
|
|
163
|
+
sw: number | null,
|
|
164
|
+
sh: number | null,
|
|
165
|
+
): Promise<{
|
|
166
|
+
data: ImageBitmap | HTMLImageElement;
|
|
167
|
+
premultiplyAlpha: boolean;
|
|
168
|
+
}> {
|
|
169
|
+
const hasAlphaChannel = premultiplyAlpha ?? blob.type.includes('image/png');
|
|
170
|
+
const imageBitmapSupported = this.txManager.imageBitmapSupported;
|
|
171
|
+
|
|
172
|
+
if (
|
|
173
|
+
imageBitmapSupported.full === true &&
|
|
174
|
+
sx !== null &&
|
|
175
|
+
sy !== null &&
|
|
176
|
+
sw !== null &&
|
|
177
|
+
sh !== null
|
|
178
|
+
) {
|
|
179
|
+
// createImageBitmap with crop
|
|
180
|
+
const bitmap = await createImageBitmap(blob, sx, sy, sw, sh, {
|
|
181
|
+
premultiplyAlpha: hasAlphaChannel ? 'premultiply' : 'none',
|
|
182
|
+
colorSpaceConversion: 'none',
|
|
183
|
+
imageOrientation: 'none',
|
|
184
|
+
});
|
|
185
|
+
return { data: bitmap, premultiplyAlpha: hasAlphaChannel };
|
|
186
|
+
} else if (imageBitmapSupported.options === true) {
|
|
187
|
+
// createImageBitmap without crop but with options
|
|
188
|
+
const bitmap = await createImageBitmap(blob, {
|
|
189
|
+
premultiplyAlpha: hasAlphaChannel ? 'premultiply' : 'none',
|
|
190
|
+
colorSpaceConversion: 'none',
|
|
191
|
+
imageOrientation: 'none',
|
|
192
|
+
});
|
|
193
|
+
return { data: bitmap, premultiplyAlpha: hasAlphaChannel };
|
|
194
|
+
} else {
|
|
195
|
+
// basic createImageBitmap without options or crop
|
|
196
|
+
// this is supported for Chrome v50 to v52/54 that doesn't support options
|
|
164
197
|
return {
|
|
165
|
-
data: await createImageBitmap(blob,
|
|
166
|
-
premultiplyAlpha: hasAlphaChannel ? 'premultiply' : 'none',
|
|
167
|
-
colorSpaceConversion: 'none',
|
|
168
|
-
imageOrientation: 'none',
|
|
169
|
-
}),
|
|
198
|
+
data: await createImageBitmap(blob),
|
|
170
199
|
premultiplyAlpha: hasAlphaChannel,
|
|
171
200
|
};
|
|
172
|
-
}
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
201
|
+
}
|
|
202
|
+
}
|
|
203
|
+
|
|
204
|
+
async loadImage(src: string) {
|
|
205
|
+
const { premultiplyAlpha, sx, sy, sw, sh } = this.props;
|
|
206
|
+
|
|
207
|
+
if (this.txManager.hasCreateImageBitmap === true) {
|
|
208
|
+
if (
|
|
209
|
+
this.txManager.hasWorker === true &&
|
|
210
|
+
this.txManager.imageWorkerManager !== null
|
|
211
|
+
) {
|
|
212
|
+
return this.txManager.imageWorkerManager.getImage(
|
|
213
|
+
src,
|
|
214
|
+
premultiplyAlpha,
|
|
215
|
+
sx,
|
|
216
|
+
sy,
|
|
217
|
+
sw,
|
|
218
|
+
sh,
|
|
219
|
+
);
|
|
176
220
|
}
|
|
177
|
-
img.src = src;
|
|
178
|
-
await new Promise<void>((resolve, reject) => {
|
|
179
|
-
img.onload = () => resolve();
|
|
180
|
-
img.onerror = () => reject(new Error(`Failed to load image`));
|
|
181
|
-
}).catch((e) => {
|
|
182
|
-
console.error(e);
|
|
183
|
-
});
|
|
184
221
|
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
premultiplyAlpha: premultiplyAlpha ?? true,
|
|
188
|
-
};
|
|
222
|
+
const blob = await fetch(src).then((response) => response.blob());
|
|
223
|
+
return this.createImageBitmap(blob, premultiplyAlpha, sx, sy, sw, sh);
|
|
189
224
|
}
|
|
225
|
+
|
|
226
|
+
return this.loadImageFallback(src, premultiplyAlpha ?? true);
|
|
190
227
|
}
|
|
191
228
|
|
|
192
229
|
override async getTextureData(): Promise<TextureData> {
|
|
@@ -148,6 +148,7 @@ const knownProperties = new Set<string>([
|
|
|
148
148
|
// ...gradientColorPropertyMap,
|
|
149
149
|
'src',
|
|
150
150
|
'parent',
|
|
151
|
+
'data',
|
|
151
152
|
]);
|
|
152
153
|
|
|
153
154
|
export class Inspector {
|
|
@@ -312,7 +313,6 @@ export class Inspector {
|
|
|
312
313
|
},
|
|
313
314
|
});
|
|
314
315
|
|
|
315
|
-
// eslint-disable-next-line @typescript-eslint/unbound-method
|
|
316
316
|
const originalAnimate = node.animate;
|
|
317
317
|
Object.defineProperty(node, 'animate', {
|
|
318
318
|
value: (
|
|
@@ -1,74 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Lightning 3 Renderer Core API
|
|
3
|
-
*
|
|
4
|
-
* @remarks
|
|
5
|
-
* ```
|
|
6
|
-
* import * from '@lightning/renderer/core';
|
|
7
|
-
* ```
|
|
8
|
-
*
|
|
9
|
-
* The Core API is used by developers to extend the capabilities of the Renderer
|
|
10
|
-
* by writing custom Shaders, Dynamic Shader Effects, Textures, Text Renderers,
|
|
11
|
-
* etc.
|
|
12
|
-
*
|
|
13
|
-
* Custom capabilities as well as fonts can be loaded via Core Extensions.
|
|
14
|
-
*
|
|
15
|
-
* A core extension module is structured like so:
|
|
16
|
-
* ```ts
|
|
17
|
-
* import {
|
|
18
|
-
* CoreExtension,
|
|
19
|
-
* WebTrFontFace,
|
|
20
|
-
* SdfTrFontFace,
|
|
21
|
-
* type Stage
|
|
22
|
-
* } from '@lightning/renderer/core';
|
|
23
|
-
*
|
|
24
|
-
* export default class MyCoreExtension extends CoreExtension {
|
|
25
|
-
* async run(stage: Stage) {
|
|
26
|
-
* stage.fontManager.addFontFace(
|
|
27
|
-
* new WebTrFontFace('Ubuntu', {}, '/fonts/Ubuntu-Regular.ttf'),
|
|
28
|
-
* );
|
|
29
|
-
*
|
|
30
|
-
* stage.fontManager.addFontFace(
|
|
31
|
-
* new SdfTrFontFace(
|
|
32
|
-
* 'Ubuntu',
|
|
33
|
-
* {},
|
|
34
|
-
* 'msdf',
|
|
35
|
-
* stage,
|
|
36
|
-
* '/fonts/Ubuntu-Regular.msdf.png',
|
|
37
|
-
* '/fonts/Ubuntu-Regular.msdf.json',
|
|
38
|
-
* ),
|
|
39
|
-
* );
|
|
40
|
-
* }
|
|
41
|
-
* }
|
|
42
|
-
* ```
|
|
43
|
-
*
|
|
44
|
-
* And then imported and registered in the application's entry point
|
|
45
|
-
* using the `@lightningjs/vite-plugin-import-chunk-url` plugin:
|
|
46
|
-
* ```ts
|
|
47
|
-
* import coreExtensionModuleUrl from './MyCoreExtension.js?importChunkUrl';
|
|
48
|
-
*
|
|
49
|
-
* // Set up driver, etc.
|
|
50
|
-
*
|
|
51
|
-
* // Initialize the Renderer
|
|
52
|
-
* const renderer = new RendererMain(
|
|
53
|
-
* {
|
|
54
|
-
* // Other Renderer Config...
|
|
55
|
-
* coreExtensionModule: coreExtensionModuleUrl,
|
|
56
|
-
* },
|
|
57
|
-
* 'app',
|
|
58
|
-
* driver,
|
|
59
|
-
* );
|
|
60
|
-
* ```
|
|
61
|
-
*
|
|
62
|
-
* @module
|
|
63
|
-
*/
|
|
64
|
-
export * from '../src/core/renderers/webgl/WebGlCoreShader.js';
|
|
65
|
-
export * from '../src/core/renderers/webgl/shaders/effects/ShaderEffect.js';
|
|
66
|
-
export * from '../src/core/textures/Texture.js';
|
|
67
|
-
export * from '../src/core/text-rendering/renderers/TextRenderer.js';
|
|
68
|
-
export * from '../src/core/text-rendering/renderers/CanvasTextRenderer.js';
|
|
69
|
-
export * from '../src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.js';
|
|
70
|
-
export * from '../src/core/text-rendering/font-face-types/TrFontFace.js';
|
|
71
|
-
export * from '../src/core/text-rendering/font-face-types/WebTrFontFace.js';
|
|
72
|
-
export * from '../src/core/text-rendering/font-face-types/SdfTrFontFace/SdfTrFontFace.js';
|
|
73
|
-
export * from '../src/core/CoreExtension.js';
|
|
74
|
-
export type * from '../src/core/Stage.js';
|
package/dist/exports/core-api.js
DELETED
|
@@ -1,96 +0,0 @@
|
|
|
1
|
-
/*
|
|
2
|
-
* If not stated otherwise in this file or this component's LICENSE file the
|
|
3
|
-
* following copyright and licenses apply:
|
|
4
|
-
*
|
|
5
|
-
* Copyright 2023 Comcast Cable Communications Management, LLC.
|
|
6
|
-
*
|
|
7
|
-
* Licensed under the Apache License, Version 2.0 (the License);
|
|
8
|
-
* you may not use this file except in compliance with the License.
|
|
9
|
-
* You may obtain a copy of the License at
|
|
10
|
-
*
|
|
11
|
-
* http://www.apache.org/licenses/LICENSE-2.0
|
|
12
|
-
*
|
|
13
|
-
* Unless required by applicable law or agreed to in writing, software
|
|
14
|
-
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
15
|
-
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
16
|
-
* See the License for the specific language governing permissions and
|
|
17
|
-
* limitations under the License.
|
|
18
|
-
*/
|
|
19
|
-
/**
|
|
20
|
-
* Lightning 3 Renderer Core API
|
|
21
|
-
*
|
|
22
|
-
* @remarks
|
|
23
|
-
* ```
|
|
24
|
-
* import * from '@lightning/renderer/core';
|
|
25
|
-
* ```
|
|
26
|
-
*
|
|
27
|
-
* The Core API is used by developers to extend the capabilities of the Renderer
|
|
28
|
-
* by writing custom Shaders, Dynamic Shader Effects, Textures, Text Renderers,
|
|
29
|
-
* etc.
|
|
30
|
-
*
|
|
31
|
-
* Custom capabilities as well as fonts can be loaded via Core Extensions.
|
|
32
|
-
*
|
|
33
|
-
* A core extension module is structured like so:
|
|
34
|
-
* ```ts
|
|
35
|
-
* import {
|
|
36
|
-
* CoreExtension,
|
|
37
|
-
* WebTrFontFace,
|
|
38
|
-
* SdfTrFontFace,
|
|
39
|
-
* type Stage
|
|
40
|
-
* } from '@lightning/renderer/core';
|
|
41
|
-
*
|
|
42
|
-
* export default class MyCoreExtension extends CoreExtension {
|
|
43
|
-
* async run(stage: Stage) {
|
|
44
|
-
* stage.fontManager.addFontFace(
|
|
45
|
-
* new WebTrFontFace('Ubuntu', {}, '/fonts/Ubuntu-Regular.ttf'),
|
|
46
|
-
* );
|
|
47
|
-
*
|
|
48
|
-
* stage.fontManager.addFontFace(
|
|
49
|
-
* new SdfTrFontFace(
|
|
50
|
-
* 'Ubuntu',
|
|
51
|
-
* {},
|
|
52
|
-
* 'msdf',
|
|
53
|
-
* stage,
|
|
54
|
-
* '/fonts/Ubuntu-Regular.msdf.png',
|
|
55
|
-
* '/fonts/Ubuntu-Regular.msdf.json',
|
|
56
|
-
* ),
|
|
57
|
-
* );
|
|
58
|
-
* }
|
|
59
|
-
* }
|
|
60
|
-
* ```
|
|
61
|
-
*
|
|
62
|
-
* And then imported and registered in the application's entry point
|
|
63
|
-
* using the `@lightningjs/vite-plugin-import-chunk-url` plugin:
|
|
64
|
-
* ```ts
|
|
65
|
-
* import coreExtensionModuleUrl from './MyCoreExtension.js?importChunkUrl';
|
|
66
|
-
*
|
|
67
|
-
* // Set up driver, etc.
|
|
68
|
-
*
|
|
69
|
-
* // Initialize the Renderer
|
|
70
|
-
* const renderer = new RendererMain(
|
|
71
|
-
* {
|
|
72
|
-
* // Other Renderer Config...
|
|
73
|
-
* coreExtensionModule: coreExtensionModuleUrl,
|
|
74
|
-
* },
|
|
75
|
-
* 'app',
|
|
76
|
-
* driver,
|
|
77
|
-
* );
|
|
78
|
-
* ```
|
|
79
|
-
*
|
|
80
|
-
* @module
|
|
81
|
-
*/
|
|
82
|
-
// Shaders
|
|
83
|
-
export * from '../src/core/renderers/webgl/WebGlCoreShader.js';
|
|
84
|
-
export * from '../src/core/renderers/webgl/shaders/effects/ShaderEffect.js';
|
|
85
|
-
// Textures
|
|
86
|
-
export * from '../src/core/textures/Texture.js';
|
|
87
|
-
// Text Rendering & Fonts
|
|
88
|
-
export * from '../src/core/text-rendering/renderers/TextRenderer.js';
|
|
89
|
-
export * from '../src/core/text-rendering/renderers/CanvasTextRenderer.js';
|
|
90
|
-
export * from '../src/core/text-rendering/renderers/SdfTextRenderer/SdfTextRenderer.js';
|
|
91
|
-
export * from '../src/core/text-rendering/font-face-types/TrFontFace.js';
|
|
92
|
-
export * from '../src/core/text-rendering/font-face-types/WebTrFontFace.js';
|
|
93
|
-
export * from '../src/core/text-rendering/font-face-types/SdfTrFontFace/SdfTrFontFace.js';
|
|
94
|
-
// Core Extensions
|
|
95
|
-
export * from '../src/core/CoreExtension.js';
|
|
96
|
-
//# sourceMappingURL=core-api.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"core-api.js","sourceRoot":"","sources":["../../exports/core-api.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;GAiBG;AACH;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA8DG;AAEH,UAAU;AACV,cAAc,gDAAgD,CAAC;AAC/D,cAAc,6DAA6D,CAAC;AAE5E,WAAW;AACX,cAAc,iCAAiC,CAAC;AAEhD,yBAAyB;AACzB,cAAc,sDAAsD,CAAC;AACrE,cAAc,4DAA4D,CAAC;AAC3E,cAAc,yEAAyE,CAAC;AACxF,cAAc,0DAA0D,CAAC;AACzE,cAAc,6DAA6D,CAAC;AAC5E,cAAc,2EAA2E,CAAC;AAE1F,kBAAkB;AAClB,cAAc,8BAA8B,CAAC"}
|
|
@@ -1,30 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Lightning 3 Renderer Main API
|
|
3
|
-
*
|
|
4
|
-
* @remarks
|
|
5
|
-
* This module exports the Main API for the Lightning 3 Renderer. You
|
|
6
|
-
* can import the exports from this module like so:
|
|
7
|
-
* ```ts
|
|
8
|
-
* import { RendererMain } from '@lightning/renderer';
|
|
9
|
-
* ```
|
|
10
|
-
*
|
|
11
|
-
* Generally developers/frameworks using the Renderer will use the Main API to
|
|
12
|
-
* render applications.
|
|
13
|
-
*
|
|
14
|
-
* Do not confuse the Main API with the Core API which is used to extend
|
|
15
|
-
* capabilities of the Renderer. The Main API code always runs from the main
|
|
16
|
-
* thread.
|
|
17
|
-
*
|
|
18
|
-
* @module
|
|
19
|
-
*/
|
|
20
|
-
export * from '../src/main-api/INode.js';
|
|
21
|
-
export * from '../src/main-api/ICoreDriver.js';
|
|
22
|
-
export * from '../src/main-api/RendererMain.js';
|
|
23
|
-
export * from '../src/render-drivers/main/MainCoreDriver.js';
|
|
24
|
-
export * from '../src/render-drivers/threadx/ThreadXCoreDriver.js';
|
|
25
|
-
export * from '../src/common/IAnimationController.js';
|
|
26
|
-
export * from '../src/common/CommonTypes.js';
|
|
27
|
-
export type { TextRendererMap } from '../src/core/text-rendering/renderers/TextRenderer.js';
|
|
28
|
-
export type { TrFontFaceMap } from '../src/core/text-rendering/font-face-types/TrFontFace.js';
|
|
29
|
-
export type { AnimationSettings } from '../src/core/animations/CoreAnimation.js';
|
|
30
|
-
export type { EffectProps, FadeOutEffectProps, LinearGradientEffectProps, RadialGradientEffectProps, GrayscaleEffectProps, GlitchEffectProps, RadialProgressEffectProps, } from '../src/core/CoreShaderManager.js';
|
package/dist/exports/main-api.js
DELETED
|
@@ -1,45 +0,0 @@
|
|
|
1
|
-
/*
|
|
2
|
-
* If not stated otherwise in this file or this component's LICENSE file the
|
|
3
|
-
* following copyright and licenses apply:
|
|
4
|
-
*
|
|
5
|
-
* Copyright 2023 Comcast Cable Communications Management, LLC.
|
|
6
|
-
*
|
|
7
|
-
* Licensed under the Apache License, Version 2.0 (the License);
|
|
8
|
-
* you may not use this file except in compliance with the License.
|
|
9
|
-
* You may obtain a copy of the License at
|
|
10
|
-
*
|
|
11
|
-
* http://www.apache.org/licenses/LICENSE-2.0
|
|
12
|
-
*
|
|
13
|
-
* Unless required by applicable law or agreed to in writing, software
|
|
14
|
-
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
15
|
-
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
16
|
-
* See the License for the specific language governing permissions and
|
|
17
|
-
* limitations under the License.
|
|
18
|
-
*/
|
|
19
|
-
/**
|
|
20
|
-
* Lightning 3 Renderer Main API
|
|
21
|
-
*
|
|
22
|
-
* @remarks
|
|
23
|
-
* This module exports the Main API for the Lightning 3 Renderer. You
|
|
24
|
-
* can import the exports from this module like so:
|
|
25
|
-
* ```ts
|
|
26
|
-
* import { RendererMain } from '@lightning/renderer';
|
|
27
|
-
* ```
|
|
28
|
-
*
|
|
29
|
-
* Generally developers/frameworks using the Renderer will use the Main API to
|
|
30
|
-
* render applications.
|
|
31
|
-
*
|
|
32
|
-
* Do not confuse the Main API with the Core API which is used to extend
|
|
33
|
-
* capabilities of the Renderer. The Main API code always runs from the main
|
|
34
|
-
* thread.
|
|
35
|
-
*
|
|
36
|
-
* @module
|
|
37
|
-
*/
|
|
38
|
-
export * from '../src/main-api/INode.js';
|
|
39
|
-
export * from '../src/main-api/ICoreDriver.js';
|
|
40
|
-
export * from '../src/main-api/RendererMain.js';
|
|
41
|
-
export * from '../src/render-drivers/main/MainCoreDriver.js';
|
|
42
|
-
export * from '../src/render-drivers/threadx/ThreadXCoreDriver.js';
|
|
43
|
-
export * from '../src/common/IAnimationController.js';
|
|
44
|
-
export * from '../src/common/CommonTypes.js';
|
|
45
|
-
//# sourceMappingURL=main-api.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"main-api.js","sourceRoot":"","sources":["../../exports/main-api.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;GAiBG;AAEH;;;;;;;;;;;;;;;;;;GAkBG;AACH,cAAc,0BAA0B,CAAC;AACzC,cAAc,gCAAgC,CAAC;AAC/C,cAAc,iCAAiC,CAAC;AAChD,cAAc,8CAA8C,CAAC;AAC7D,cAAc,oDAAoD,CAAC;AACnE,cAAc,uCAAuC,CAAC;AACtD,cAAc,8BAA8B,CAAC"}
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
import type { Stage } from './Stage.js';
|
|
2
|
-
/**
|
|
3
|
-
* Base class for Core extensions.
|
|
4
|
-
*
|
|
5
|
-
* @remarks
|
|
6
|
-
* Core extensions are used to extend the Core Renderer with custom code such as
|
|
7
|
-
* custom fonts, custom shaders, custom textures, custom animation functions,
|
|
8
|
-
* and more.
|
|
9
|
-
*/
|
|
10
|
-
export declare abstract class CoreExtension {
|
|
11
|
-
abstract run(stage: Stage): Promise<void>;
|
|
12
|
-
}
|
|
@@ -1,29 +0,0 @@
|
|
|
1
|
-
/*
|
|
2
|
-
* If not stated otherwise in this file or this component's LICENSE file the
|
|
3
|
-
* following copyright and licenses apply:
|
|
4
|
-
*
|
|
5
|
-
* Copyright 2023 Comcast Cable Communications Management, LLC.
|
|
6
|
-
*
|
|
7
|
-
* Licensed under the Apache License, Version 2.0 (the License);
|
|
8
|
-
* you may not use this file except in compliance with the License.
|
|
9
|
-
* You may obtain a copy of the License at
|
|
10
|
-
*
|
|
11
|
-
* http://www.apache.org/licenses/LICENSE-2.0
|
|
12
|
-
*
|
|
13
|
-
* Unless required by applicable law or agreed to in writing, software
|
|
14
|
-
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
15
|
-
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
16
|
-
* See the License for the specific language governing permissions and
|
|
17
|
-
* limitations under the License.
|
|
18
|
-
*/
|
|
19
|
-
/**
|
|
20
|
-
* Base class for Core extensions.
|
|
21
|
-
*
|
|
22
|
-
* @remarks
|
|
23
|
-
* Core extensions are used to extend the Core Renderer with custom code such as
|
|
24
|
-
* custom fonts, custom shaders, custom textures, custom animation functions,
|
|
25
|
-
* and more.
|
|
26
|
-
*/
|
|
27
|
-
export class CoreExtension {
|
|
28
|
-
}
|
|
29
|
-
//# sourceMappingURL=CoreExtension.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"CoreExtension.js","sourceRoot":"","sources":["../../../src/core/CoreExtension.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;GAiBG;AAIH;;;;;;;GAOG;AACH,MAAM,OAAgB,aAAa;CAElC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
|
@@ -1,138 +0,0 @@
|
|
|
1
|
-
export {};
|
|
2
|
-
/*interface InstanceMap {
|
|
3
|
-
renderer: CoreRenderer;
|
|
4
|
-
effect: CoreEffect;
|
|
5
|
-
program: new () => void;
|
|
6
|
-
}
|
|
7
|
-
|
|
8
|
-
type WebGlInstanceMap = InstanceMap & {
|
|
9
|
-
renderer: WebGlCoreRenderer;
|
|
10
|
-
effect: WebGlEffect;
|
|
11
|
-
};
|
|
12
|
-
|
|
13
|
-
interface AdvEffectProp {
|
|
14
|
-
default: any;
|
|
15
|
-
isColor?: boolean;
|
|
16
|
-
validator?: (value: any) => any;
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
interface EffectProps {
|
|
20
|
-
[key: string]: any | AdvEffectProp;
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
type EffectDescriptor<Effect, Props> = Effect & {
|
|
24
|
-
props?: Props;
|
|
25
|
-
};
|
|
26
|
-
|
|
27
|
-
type InferEffectProps<T> = {
|
|
28
|
-
[K in keyof T]: T[K] extends AdvEffectProp ? T[K]['default'] : T[K];
|
|
29
|
-
};
|
|
30
|
-
|
|
31
|
-
interface CoreEffect {
|
|
32
|
-
props?: EffectProps;
|
|
33
|
-
update?: (ctx: unknown) => void;
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
type WebGlEffect = CoreEffect & {
|
|
37
|
-
fragment: string;
|
|
38
|
-
update?: (glw: WebGLRenderingContext) => void;
|
|
39
|
-
};
|
|
40
|
-
|
|
41
|
-
type StageOptions<Renderer extends InstanceMap> = {
|
|
42
|
-
renderEngine?: new () => Renderer['renderer'];
|
|
43
|
-
};
|
|
44
|
-
|
|
45
|
-
class Stage<RendererMap extends InstanceMap> {
|
|
46
|
-
fxManager: CoreFxManager<RendererMap>;
|
|
47
|
-
constructor(options: StageOptions<RendererMap>) {
|
|
48
|
-
this.fxManager = new CoreFxManager();
|
|
49
|
-
const renderer = new options.renderEngine();
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
createShader<Effect extends RendererMap['effect'], Props>(
|
|
53
|
-
effect: EffectDescriptor<Effect, Props>,
|
|
54
|
-
props?: InferEffectProps<Props>
|
|
55
|
-
): EffectNode<Effect, Props> {
|
|
56
|
-
return this.fxManager.createShader(effect, props);
|
|
57
|
-
}
|
|
58
|
-
}
|
|
59
|
-
|
|
60
|
-
class CoreRenderer {
|
|
61
|
-
mode = 'core';
|
|
62
|
-
}
|
|
63
|
-
|
|
64
|
-
class WebGlCoreRenderer extends CoreRenderer {
|
|
65
|
-
override mode = 'webgl';
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
class CanvasCoreRenderer extends CoreRenderer {
|
|
69
|
-
override mode = 'canvas';
|
|
70
|
-
}
|
|
71
|
-
|
|
72
|
-
class CoreFxManager<RendererMap extends InstanceMap> {
|
|
73
|
-
fxCache: Map<string, RendererMap['effect']> = new Map();
|
|
74
|
-
|
|
75
|
-
resolveProps(defaultProps?: EffectProps, props?: EffectProps) {
|
|
76
|
-
if(defaultProps !== undefined) {
|
|
77
|
-
props = props ?? {}
|
|
78
|
-
const keys = Object.keys(defaultProps);
|
|
79
|
-
const l = keys.length;
|
|
80
|
-
for(let i = 0; i < l; i++) {
|
|
81
|
-
if(props[keys[i]] === undefined) {
|
|
82
|
-
props[keys[i]] = defaultProps[keys[i]].default || defaultProps[keys[i]]
|
|
83
|
-
}
|
|
84
|
-
}
|
|
85
|
-
}
|
|
86
|
-
}
|
|
87
|
-
|
|
88
|
-
createShader<Effect extends RendererMap['effect'], Props>(
|
|
89
|
-
effect: EffectDescriptor<Effect, Props>,
|
|
90
|
-
props?: InferEffectProps<Props>
|
|
91
|
-
): EffectNode<Effect, Props> {
|
|
92
|
-
|
|
93
|
-
// const f = JSON.stringify(effect);
|
|
94
|
-
// if (this.fxCache.has(f)) {
|
|
95
|
-
// console.log('already has this effect');
|
|
96
|
-
// } else {
|
|
97
|
-
// console.log('create new effect program');
|
|
98
|
-
// this.fxCache.set(f, effect);
|
|
99
|
-
// }
|
|
100
|
-
|
|
101
|
-
return new EffectNode<Effect, Props>(effect, WebGlCoreRenderer, props);
|
|
102
|
-
}
|
|
103
|
-
}
|
|
104
|
-
|
|
105
|
-
class EffectNode<Effect extends CoreEffect, Props extends EffectProps> {
|
|
106
|
-
#data: Record<string, any> | undefined = undefined;
|
|
107
|
-
constructor(
|
|
108
|
-
readonly type: Effect,
|
|
109
|
-
readonly program: new () => void,
|
|
110
|
-
props?: InferEffectProps<Props>
|
|
111
|
-
) {
|
|
112
|
-
this.#data = props;
|
|
113
|
-
}
|
|
114
|
-
}
|
|
115
|
-
|
|
116
|
-
const stage = new Stage<WebGlInstanceMap>({
|
|
117
|
-
renderEngine: CanvasCoreRenderer,
|
|
118
|
-
});
|
|
119
|
-
|
|
120
|
-
stage.createShader(
|
|
121
|
-
{
|
|
122
|
-
props: {
|
|
123
|
-
radius: 10,
|
|
124
|
-
},
|
|
125
|
-
fragment: '',
|
|
126
|
-
},
|
|
127
|
-
{
|
|
128
|
-
radius: 30,
|
|
129
|
-
}
|
|
130
|
-
);
|
|
131
|
-
|
|
132
|
-
stage.createShader({
|
|
133
|
-
props: {
|
|
134
|
-
radius: 10,
|
|
135
|
-
},
|
|
136
|
-
fragment: '',
|
|
137
|
-
});*/
|
|
138
|
-
//# sourceMappingURL=CoreStuff.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"CoreStuff.js","sourceRoot":"","sources":["../../../src/core/CoreStuff.ts"],"names":[],"mappings":";AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KAuIK"}
|