@babylonjs/core 8.32.2 → 8.33.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/Engines/abstractEngine.js +2 -2
- package/Engines/abstractEngine.js.map +1 -1
- package/FrameGraph/Node/Blocks/Layers/glowLayerBlock.js +1 -1
- package/FrameGraph/Node/Blocks/Layers/glowLayerBlock.js.map +1 -1
- package/FrameGraph/Node/Blocks/PostProcesses/taaPostProcessBlock.d.ts +55 -0
- package/FrameGraph/Node/Blocks/PostProcesses/taaPostProcessBlock.js +147 -0
- package/FrameGraph/Node/Blocks/PostProcesses/taaPostProcessBlock.js.map +1 -0
- package/FrameGraph/Node/Blocks/Rendering/geometryRendererBlock.js +1 -1
- package/FrameGraph/Node/Blocks/Rendering/geometryRendererBlock.js.map +1 -1
- package/FrameGraph/Node/Blocks/index.d.ts +1 -1
- package/FrameGraph/Node/Blocks/index.js +1 -1
- package/FrameGraph/Node/Blocks/index.js.map +1 -1
- package/FrameGraph/Tasks/PostProcesses/postProcessTask.js +1 -6
- package/FrameGraph/Tasks/PostProcesses/postProcessTask.js.map +1 -1
- package/FrameGraph/Tasks/PostProcesses/taaTask.d.ts +29 -0
- package/FrameGraph/Tasks/PostProcesses/taaTask.js +102 -0
- package/FrameGraph/Tasks/PostProcesses/taaTask.js.map +1 -0
- package/FrameGraph/frameGraphTextureManager.d.ts +9 -0
- package/FrameGraph/frameGraphTextureManager.js +15 -0
- package/FrameGraph/frameGraphTextureManager.js.map +1 -1
- package/FrameGraph/index.d.ts +1 -1
- package/FrameGraph/index.js +1 -1
- package/FrameGraph/index.js.map +1 -1
- package/Lights/Clustered/clusteredLightContainer.js +4 -3
- package/Lights/Clustered/clusteredLightContainer.js.map +1 -1
- package/Lights/pointLight.js +6 -4
- package/Lights/pointLight.js.map +1 -1
- package/Lights/rectAreaLight.js +6 -4
- package/Lights/rectAreaLight.js.map +1 -1
- package/Lights/spotLight.js +3 -2
- package/Lights/spotLight.js.map +1 -1
- package/Materials/Background/backgroundMaterial.js +1 -1
- package/Materials/Background/backgroundMaterial.js.map +1 -1
- package/Materials/GaussianSplatting/gaussianSplattingMaterial.d.ts +11 -0
- package/Materials/GaussianSplatting/gaussianSplattingMaterial.js +74 -27
- package/Materials/GaussianSplatting/gaussianSplattingMaterial.js.map +1 -1
- package/Materials/PBR/index.d.ts +1 -1
- package/Materials/PBR/index.js +1 -1
- package/Materials/PBR/index.js.map +1 -1
- package/Materials/PBR/{openPbrMaterial.d.ts → openpbrMaterial.d.ts} +77 -0
- package/Materials/PBR/{openPbrMaterial.js → openpbrMaterial.js} +129 -11
- package/Materials/PBR/openpbrMaterial.js.map +1 -0
- package/Materials/PBR/pbrBaseMaterial.js +1 -1
- package/Materials/PBR/pbrBaseMaterial.js.map +1 -1
- package/Materials/material.d.ts +7 -3
- package/Materials/material.js +11 -7
- package/Materials/material.js.map +1 -1
- package/Materials/standardMaterial.js +1 -1
- package/Materials/standardMaterial.js.map +1 -1
- package/Maths/math.vector.d.ts +1 -1
- package/Maths/math.vector.js +1 -1
- package/Maths/math.vector.js.map +1 -1
- package/Meshes/mesh.js +9 -0
- package/Meshes/mesh.js.map +1 -1
- package/Misc/brdfTextureTools.d.ts +12 -0
- package/Misc/brdfTextureTools.js +36 -6
- package/Misc/brdfTextureTools.js.map +1 -1
- package/Morph/morphTargetManager.d.ts +2 -0
- package/Morph/morphTargetManager.js +19 -1
- package/Morph/morphTargetManager.js.map +1 -1
- package/Particles/Node/nodeParticleSystemSet.d.ts +14 -6
- package/Particles/Node/nodeParticleSystemSet.js +37 -6
- package/Particles/Node/nodeParticleSystemSet.js.map +1 -1
- package/PostProcesses/RenderPipeline/Pipelines/taaMaterialManager.js +1 -1
- package/PostProcesses/RenderPipeline/Pipelines/taaMaterialManager.js.map +1 -1
- package/PostProcesses/RenderPipeline/Pipelines/taaRenderingPipeline.d.ts +0 -1
- package/PostProcesses/RenderPipeline/Pipelines/taaRenderingPipeline.js +4 -22
- package/PostProcesses/RenderPipeline/Pipelines/taaRenderingPipeline.js.map +1 -1
- package/PostProcesses/thinTAAPostProcess.d.ts +10 -5
- package/PostProcesses/thinTAAPostProcess.js +37 -7
- package/PostProcesses/thinTAAPostProcess.js.map +1 -1
- package/Rendering/IBLShadows/iblShadowsPluginMaterial.d.ts +1 -1
- package/Rendering/IBLShadows/iblShadowsPluginMaterial.js +1 -1
- package/Rendering/IBLShadows/iblShadowsPluginMaterial.js.map +1 -1
- package/Rendering/IBLShadows/iblShadowsRenderPipeline.js +1 -1
- package/Rendering/IBLShadows/iblShadowsRenderPipeline.js.map +1 -1
- package/Rendering/boundingBoxRenderer.js +6 -1
- package/Rendering/boundingBoxRenderer.js.map +1 -1
- package/Rendering/edgesRenderer.js +4 -0
- package/Rendering/edgesRenderer.js.map +1 -1
- package/Rendering/geometryBufferRenderer.js.map +1 -1
- package/Shaders/ShadersInclude/gaussianSplatting.js +10 -2
- package/Shaders/ShadersInclude/gaussianSplatting.js.map +1 -1
- package/Shaders/ShadersInclude/openpbrBaseLayerData.js +1 -1
- package/Shaders/ShadersInclude/openpbrBaseLayerData.js.map +1 -1
- package/Shaders/ShadersInclude/openpbrDirectLighting.js +10 -2
- package/Shaders/ShadersInclude/openpbrDirectLighting.js.map +1 -1
- package/Shaders/ShadersInclude/openpbrEnvironmentLighting.js +24 -2
- package/Shaders/ShadersInclude/openpbrEnvironmentLighting.js.map +1 -1
- package/Shaders/ShadersInclude/openpbrFragmentDeclaration.js +10 -1
- package/Shaders/ShadersInclude/openpbrFragmentDeclaration.js.map +1 -1
- package/Shaders/ShadersInclude/openpbrFragmentSamplersDeclaration.js +8 -2
- package/Shaders/ShadersInclude/openpbrFragmentSamplersDeclaration.js.map +1 -1
- package/Shaders/ShadersInclude/openpbrFuzzLayerData.d.ts +5 -0
- package/Shaders/ShadersInclude/openpbrFuzzLayerData.js +40 -0
- package/Shaders/ShadersInclude/openpbrFuzzLayerData.js.map +1 -0
- package/Shaders/ShadersInclude/openpbrGeometryInfo.js +2 -8
- package/Shaders/ShadersInclude/openpbrGeometryInfo.js.map +1 -1
- package/Shaders/ShadersInclude/openpbrNormalMapFragment.js +1 -1
- package/Shaders/ShadersInclude/openpbrNormalMapFragment.js.map +1 -1
- package/Shaders/ShadersInclude/openpbrNormalMapFragmentMainFunctions.js +1 -1
- package/Shaders/ShadersInclude/openpbrNormalMapFragmentMainFunctions.js.map +1 -1
- package/Shaders/ShadersInclude/openpbrNormalMapVertex.js +1 -1
- package/Shaders/ShadersInclude/openpbrNormalMapVertex.js.map +1 -1
- package/Shaders/ShadersInclude/openpbrNormalMapVertexDeclaration.js +1 -1
- package/Shaders/ShadersInclude/openpbrNormalMapVertexDeclaration.js.map +1 -1
- package/Shaders/ShadersInclude/openpbrUboDeclaration.js +1 -1
- package/Shaders/ShadersInclude/openpbrUboDeclaration.js.map +1 -1
- package/Shaders/ShadersInclude/openpbrVertexDeclaration.js +9 -0
- package/Shaders/ShadersInclude/openpbrVertexDeclaration.js.map +1 -1
- package/Shaders/ShadersInclude/pbrBRDFFunctions.js +3 -0
- package/Shaders/ShadersInclude/pbrBRDFFunctions.js.map +1 -1
- package/Shaders/ShadersInclude/pbrDirectLightingFunctions.js +9 -0
- package/Shaders/ShadersInclude/pbrDirectLightingFunctions.js.map +1 -1
- package/Shaders/gaussianSplattingDepth.fragment.d.ts +5 -0
- package/Shaders/gaussianSplattingDepth.fragment.js +11 -0
- package/Shaders/gaussianSplattingDepth.fragment.js.map +1 -0
- package/Shaders/gaussianSplattingDepth.vertex.d.ts +8 -0
- package/Shaders/gaussianSplattingDepth.vertex.js +17 -0
- package/Shaders/gaussianSplattingDepth.vertex.js.map +1 -0
- package/Shaders/openpbr.fragment.d.ts +1 -0
- package/Shaders/openpbr.fragment.js +8 -1
- package/Shaders/openpbr.fragment.js.map +1 -1
- package/Shaders/openpbr.vertex.js +6 -0
- package/Shaders/openpbr.vertex.js.map +1 -1
- package/ShadersWGSL/ShadersInclude/gaussianSplatting.js +7 -1
- package/ShadersWGSL/ShadersInclude/gaussianSplatting.js.map +1 -1
- package/ShadersWGSL/ShadersInclude/openpbrBaseLayerData.js +1 -1
- package/ShadersWGSL/ShadersInclude/openpbrBaseLayerData.js.map +1 -1
- package/ShadersWGSL/ShadersInclude/openpbrDirectLighting.js +10 -2
- package/ShadersWGSL/ShadersInclude/openpbrDirectLighting.js.map +1 -1
- package/ShadersWGSL/ShadersInclude/openpbrEnvironmentLighting.js +25 -2
- package/ShadersWGSL/ShadersInclude/openpbrEnvironmentLighting.js.map +1 -1
- package/ShadersWGSL/ShadersInclude/openpbrFragmentSamplersDeclaration.js +7 -1
- package/ShadersWGSL/ShadersInclude/openpbrFragmentSamplersDeclaration.js.map +1 -1
- package/ShadersWGSL/ShadersInclude/openpbrFuzzLayerData.d.ts +5 -0
- package/ShadersWGSL/ShadersInclude/openpbrFuzzLayerData.js +40 -0
- package/ShadersWGSL/ShadersInclude/openpbrFuzzLayerData.js.map +1 -0
- package/ShadersWGSL/ShadersInclude/openpbrGeometryInfo.js +2 -8
- package/ShadersWGSL/ShadersInclude/openpbrGeometryInfo.js.map +1 -1
- package/ShadersWGSL/ShadersInclude/openpbrNormalMapFragment.js +1 -1
- package/ShadersWGSL/ShadersInclude/openpbrNormalMapFragment.js.map +1 -1
- package/ShadersWGSL/ShadersInclude/openpbrNormalMapFragmentMainFunctions.js +1 -1
- package/ShadersWGSL/ShadersInclude/openpbrNormalMapFragmentMainFunctions.js.map +1 -1
- package/ShadersWGSL/ShadersInclude/openpbrNormalMapVertex.js +1 -1
- package/ShadersWGSL/ShadersInclude/openpbrNormalMapVertex.js.map +1 -1
- package/ShadersWGSL/ShadersInclude/openpbrNormalMapVertexDeclaration.js +1 -1
- package/ShadersWGSL/ShadersInclude/openpbrNormalMapVertexDeclaration.js.map +1 -1
- package/ShadersWGSL/ShadersInclude/openpbrUboDeclaration.js +1 -1
- package/ShadersWGSL/ShadersInclude/openpbrUboDeclaration.js.map +1 -1
- package/ShadersWGSL/ShadersInclude/pbrBRDFFunctions.js +3 -0
- package/ShadersWGSL/ShadersInclude/pbrBRDFFunctions.js.map +1 -1
- package/ShadersWGSL/ShadersInclude/pbrDirectLightingFunctions.js +9 -0
- package/ShadersWGSL/ShadersInclude/pbrDirectLightingFunctions.js.map +1 -1
- package/ShadersWGSL/gaussianSplattingDepth.fragment.d.ts +6 -0
- package/ShadersWGSL/gaussianSplattingDepth.fragment.js +17 -0
- package/ShadersWGSL/gaussianSplattingDepth.fragment.js.map +1 -0
- package/ShadersWGSL/gaussianSplattingDepth.vertex.d.ts +8 -0
- package/ShadersWGSL/gaussianSplattingDepth.vertex.js +19 -0
- package/ShadersWGSL/gaussianSplattingDepth.vertex.js.map +1 -0
- package/ShadersWGSL/openpbr.fragment.d.ts +1 -0
- package/ShadersWGSL/openpbr.fragment.js +8 -1
- package/ShadersWGSL/openpbr.fragment.js.map +1 -1
- package/ShadersWGSL/openpbr.vertex.js +6 -0
- package/ShadersWGSL/openpbr.vertex.js.map +1 -1
- package/package.json +1 -1
- package/scene.d.ts +4 -0
- package/scene.js +6 -5
- package/scene.js.map +1 -1
- package/FrameGraph/Node/Blocks/Rendering/taaObjectRendererBlock.d.ts +0 -48
- package/FrameGraph/Node/Blocks/Rendering/taaObjectRendererBlock.js +0 -119
- package/FrameGraph/Node/Blocks/Rendering/taaObjectRendererBlock.js.map +0 -1
- package/FrameGraph/Tasks/Rendering/taaObjectRendererTask.d.ts +0 -24
- package/FrameGraph/Tasks/Rendering/taaObjectRendererTask.js +0 -109
- package/FrameGraph/Tasks/Rendering/taaObjectRendererTask.js.map +0 -1
- package/Materials/PBR/openPbrMaterial.js.map +0 -1
|
@@ -6,6 +6,12 @@ import type { Scene } from "../scene.js";
|
|
|
6
6
|
* @returns the environment BRDF texture
|
|
7
7
|
*/
|
|
8
8
|
export declare const GetEnvironmentBRDFTexture: (scene: Scene) => BaseTexture;
|
|
9
|
+
/**
|
|
10
|
+
* Gets a default environment fuzz BRDF texture
|
|
11
|
+
* @param scene defines the hosting scene
|
|
12
|
+
* @returns the environment fuzz BRDF texture
|
|
13
|
+
*/
|
|
14
|
+
export declare const GetEnvironmentFuzzBRDFTexture: (scene: Scene) => BaseTexture;
|
|
9
15
|
/**
|
|
10
16
|
* Class used to host texture specific utilities
|
|
11
17
|
*/
|
|
@@ -16,4 +22,10 @@ export declare const BRDFTextureTools: {
|
|
|
16
22
|
* @returns the environment BRDF texture
|
|
17
23
|
*/
|
|
18
24
|
GetEnvironmentBRDFTexture: (scene: Scene) => BaseTexture;
|
|
25
|
+
/**
|
|
26
|
+
* Gets a default environment fuzz BRDF texture
|
|
27
|
+
* @param scene defines the hosting scene
|
|
28
|
+
* @returns the environment fuzz BRDF texture
|
|
29
|
+
*/
|
|
30
|
+
GetEnvironmentFuzzBRDFTexture: (scene: Scene) => BaseTexture;
|
|
19
31
|
};
|
package/Misc/brdfTextureTools.js
CHANGED
|
@@ -2,20 +2,27 @@ import { Texture } from "../Materials/Textures/texture.js";
|
|
|
2
2
|
import { RGBDTextureTools } from "./rgbdTextureTools.js";
|
|
3
3
|
// eslint-disable-next-line @typescript-eslint/naming-convention
|
|
4
4
|
const _environmentBRDFBase64Texture = "";
|
|
5
|
+
// Multiple-Scattering Sheen BRDF LUT from https://github.com/tizian/ltc-sheen
|
|
6
|
+
// eslint-disable-next-line @typescript-eslint/naming-convention
|
|
7
|
+
const _environmentFuzzBRDFBase64Texture = "";
|
|
5
8
|
let InstanceNumber = 0;
|
|
6
9
|
/**
|
|
7
|
-
*
|
|
10
|
+
* Internal function to load and setup BRDF textures
|
|
8
11
|
* @param scene defines the hosting scene
|
|
12
|
+
* @param textureData defines the base64 texture data
|
|
13
|
+
* @param textureProperty defines the scene property name to store the texture
|
|
14
|
+
* @param textureName defines the name for the texture
|
|
9
15
|
* @returns the environment BRDF texture
|
|
10
16
|
*/
|
|
11
|
-
|
|
12
|
-
|
|
17
|
+
// eslint-disable-next-line @typescript-eslint/naming-convention
|
|
18
|
+
const loadBRDFTexture = (scene, textureData, textureProperty, textureName) => {
|
|
19
|
+
if (!scene[textureProperty]) {
|
|
13
20
|
// Forces Delayed Texture Loading to prevent undefined error whilst setting RGBD values.
|
|
14
21
|
const useDelayedTextureLoading = scene.useDelayedTextureLoading;
|
|
15
22
|
scene.useDelayedTextureLoading = false;
|
|
16
23
|
const previousState = scene._blockEntityCollection;
|
|
17
24
|
scene._blockEntityCollection = false;
|
|
18
|
-
const texture = Texture.CreateFromBase64String(
|
|
25
|
+
const texture = Texture.CreateFromBase64String(textureData, textureName + InstanceNumber++, scene, true, false, Texture.BILINEAR_SAMPLINGMODE);
|
|
19
26
|
scene._blockEntityCollection = previousState;
|
|
20
27
|
// BRDF Texture should not be cached here due to pre processing and redundant scene caches.
|
|
21
28
|
const texturesCache = scene.getEngine().getLoadedTexturesCache();
|
|
@@ -26,7 +33,7 @@ export const GetEnvironmentBRDFTexture = (scene) => {
|
|
|
26
33
|
texture.isRGBD = true;
|
|
27
34
|
texture.wrapU = Texture.CLAMP_ADDRESSMODE;
|
|
28
35
|
texture.wrapV = Texture.CLAMP_ADDRESSMODE;
|
|
29
|
-
scene
|
|
36
|
+
scene[textureProperty] = texture;
|
|
30
37
|
scene.useDelayedTextureLoading = useDelayedTextureLoading;
|
|
31
38
|
RGBDTextureTools.ExpandRGBDTexture(texture);
|
|
32
39
|
const observer = scene.getEngine().onContextRestoredObservable.add(() => {
|
|
@@ -48,7 +55,23 @@ export const GetEnvironmentBRDFTexture = (scene) => {
|
|
|
48
55
|
scene.getEngine().onContextRestoredObservable.remove(observer);
|
|
49
56
|
});
|
|
50
57
|
}
|
|
51
|
-
return scene
|
|
58
|
+
return scene[textureProperty];
|
|
59
|
+
};
|
|
60
|
+
/**
|
|
61
|
+
* Gets a default environment BRDF for MS-BRDF Height Correlated BRDF
|
|
62
|
+
* @param scene defines the hosting scene
|
|
63
|
+
* @returns the environment BRDF texture
|
|
64
|
+
*/
|
|
65
|
+
export const GetEnvironmentBRDFTexture = (scene) => {
|
|
66
|
+
return loadBRDFTexture(scene, _environmentBRDFBase64Texture, "environmentBRDFTexture", "EnvironmentBRDFTexture");
|
|
67
|
+
};
|
|
68
|
+
/**
|
|
69
|
+
* Gets a default environment fuzz BRDF texture
|
|
70
|
+
* @param scene defines the hosting scene
|
|
71
|
+
* @returns the environment fuzz BRDF texture
|
|
72
|
+
*/
|
|
73
|
+
export const GetEnvironmentFuzzBRDFTexture = (scene) => {
|
|
74
|
+
return loadBRDFTexture(scene, _environmentFuzzBRDFBase64Texture, "environmentFuzzBRDFTexture", "EnvironmentFuzzBRDFTexture");
|
|
52
75
|
};
|
|
53
76
|
/**
|
|
54
77
|
* Class used to host texture specific utilities
|
|
@@ -61,5 +84,12 @@ export const BRDFTextureTools = {
|
|
|
61
84
|
*/
|
|
62
85
|
// eslint-disable-next-line @typescript-eslint/naming-convention
|
|
63
86
|
GetEnvironmentBRDFTexture,
|
|
87
|
+
/**
|
|
88
|
+
* Gets a default environment fuzz BRDF texture
|
|
89
|
+
* @param scene defines the hosting scene
|
|
90
|
+
* @returns the environment fuzz BRDF texture
|
|
91
|
+
*/
|
|
92
|
+
// eslint-disable-next-line @typescript-eslint/naming-convention
|
|
93
|
+
GetEnvironmentFuzzBRDFTexture,
|
|
64
94
|
};
|
|
65
95
|
//# sourceMappingURL=brdfTextureTools.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"brdfTextureTools.js","sourceRoot":"","sources":["../../../../dev/core/src/Misc/brdfTextureTools.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,EAAE,MAAM,+BAA+B,CAAC;AAExD,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AAEtD,gEAAgE;AAChE,MAAM,6BAA6B,GAC/B,wn9BAAwn9B,CAAC;AAE7n9B,IAAI,cAAc,GAAG,CAAC,CAAC;AAEvB;;;;GAIG;AACH,MAAM,CAAC,MAAM,yBAAyB,GAAG,CAAC,KAAY,EAAe,EAAE;IACnE,IAAI,CAAC,KAAK,CAAC,sBAAsB,EAAE,CAAC;QAChC,wFAAwF;QACxF,MAAM,wBAAwB,GAAG,KAAK,CAAC,wBAAwB,CAAC;QAChE,KAAK,CAAC,wBAAwB,GAAG,KAAK,CAAC;QAEvC,MAAM,aAAa,GAAG,KAAK,CAAC,sBAAsB,CAAC;QACnD,KAAK,CAAC,sBAAsB,GAAG,KAAK,CAAC;QACrC,MAAM,OAAO,GAAG,OAAO,CAAC,sBAAsB,CAC1C,6BAA6B,EAC7B,wBAAwB,GAAG,cAAc,EAAE,EAC3C,KAAK,EACL,IAAI,EACJ,KAAK,EACL,OAAO,CAAC,qBAAqB,CAChC,CAAC;QACF,KAAK,CAAC,sBAAsB,GAAG,aAAa,CAAC;QAC7C,2FAA2F;QAC3F,MAAM,aAAa,GAAG,KAAK,CAAC,SAAS,EAAE,CAAC,sBAAsB,EAAE,CAAC;QACjE,MAAM,KAAK,GAAG,aAAa,CAAC,OAAO,CAAC,OAAO,CAAC,kBAAkB,EAAG,CAAC,CAAC;QACnE,IAAI,KAAK,KAAK,CAAC,CAAC,EAAE,CAAC;YACf,aAAa,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;QACnC,CAAC;QAED,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC;QACtB,OAAO,CAAC,KAAK,GAAG,OAAO,CAAC,iBAAiB,CAAC;QAC1C,OAAO,CAAC,KAAK,GAAG,OAAO,CAAC,iBAAiB,CAAC;QAC1C,KAAK,CAAC,sBAAsB,GAAG,OAAO,CAAC;QAEvC,KAAK,CAAC,wBAAwB,GAAG,wBAAwB,CAAC;QAE1D,gBAAgB,CAAC,iBAAiB,CAAC,OAAO,CAAC,CAAC;QAE5C,MAAM,QAAQ,GAAG,KAAK,CAAC,SAAS,EAAE,CAAC,2BAA2B,CAAC,GAAG,CAAC,GAAG,EAAE;YACpE,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC;YACtB;;;;;eAKG;YACH,MAAM,EAAE,GAAG,KAAK,CAAC,wBAAwB,CAAC,GAAG,CAAC,GAAG,EAAE;gBAC/C,IAAI,OAAO,CAAC,OAAO,EAAE,EAAE,CAAC;oBACpB,KAAK,CAAC,wBAAwB,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;oBAC1C,gBAAgB,CAAC,iBAAiB,CAAC,OAAO,CAAC,CAAC;gBAChD,CAAC;YACL,CAAC,CAAC,CAAC;QACP,CAAC,CAAC,CAAC;QAEH,KAAK,CAAC,mBAAmB,CAAC,GAAG,CAAC,GAAG,EAAE;YAC/B,KAAK,CAAC,SAAS,EAAE,CAAC,2BAA2B,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;QACnE,CAAC,CAAC,CAAC;IACP,CAAC;IAED,OAAO,KAAK,CAAC,sBAAsB,CAAC;AACxC,CAAC,CAAC;AAEF;;GAEG;AACH,MAAM,CAAC,MAAM,gBAAgB,GAAG;IAC5B;;;;OAIG;IACH,gEAAgE;IAChE,yBAAyB;CAC5B,CAAC","sourcesContent":["import type { BaseTexture } from \"../Materials/Textures/baseTexture\";\r\nimport { Texture } from \"../Materials/Textures/texture\";\r\nimport type { Scene } from \"../scene\";\r\nimport { RGBDTextureTools } from \"./rgbdTextureTools\";\r\n\r\n// eslint-disable-next-line @typescript-eslint/naming-convention\r\nconst _environmentBRDFBase64Texture =\r\n \"\";\r\n\r\nlet InstanceNumber = 0;\r\n\r\n/**\r\n * Gets a default environment BRDF for MS-BRDF Height Correlated BRDF\r\n * @param scene defines the hosting scene\r\n * @returns the environment BRDF texture\r\n */\r\nexport const GetEnvironmentBRDFTexture = (scene: Scene): BaseTexture => {\r\n if (!scene.environmentBRDFTexture) {\r\n // Forces Delayed Texture Loading to prevent undefined error whilst setting RGBD values.\r\n const useDelayedTextureLoading = scene.useDelayedTextureLoading;\r\n scene.useDelayedTextureLoading = false;\r\n\r\n const previousState = scene._blockEntityCollection;\r\n scene._blockEntityCollection = false;\r\n const texture = Texture.CreateFromBase64String(\r\n _environmentBRDFBase64Texture,\r\n \"EnvironmentBRDFTexture\" + InstanceNumber++,\r\n scene,\r\n true,\r\n false,\r\n Texture.BILINEAR_SAMPLINGMODE\r\n );\r\n scene._blockEntityCollection = previousState;\r\n // BRDF Texture should not be cached here due to pre processing and redundant scene caches.\r\n const texturesCache = scene.getEngine().getLoadedTexturesCache();\r\n const index = texturesCache.indexOf(texture.getInternalTexture()!);\r\n if (index !== -1) {\r\n texturesCache.splice(index, 1);\r\n }\r\n\r\n texture.isRGBD = true;\r\n texture.wrapU = Texture.CLAMP_ADDRESSMODE;\r\n texture.wrapV = Texture.CLAMP_ADDRESSMODE;\r\n scene.environmentBRDFTexture = texture;\r\n\r\n scene.useDelayedTextureLoading = useDelayedTextureLoading;\r\n\r\n RGBDTextureTools.ExpandRGBDTexture(texture);\r\n\r\n const observer = scene.getEngine().onContextRestoredObservable.add(() => {\r\n texture.isRGBD = true;\r\n /**\r\n * Using scene.onBeforeRenderObservable instead of Tools.SetImmediate to check the texture's state of readiness allows us to check before any rendering occurs.\r\n * When a context restore occurs, it gives ExpandRGBDTexture the ability to reset the state to false, preventing the texture from being used in any rendering.\r\n * In WebGPU, not doing so would generate an error because ExpandRGBDTexture performs a _swapAndDie on the texture, which causes WebGPU caches to fail if the texture has already been used for rendering.\r\n * Only when ExpandRGBDTexture has finished its work, the texture is ready to be used again.\r\n */\r\n const oo = scene.onBeforeRenderObservable.add(() => {\r\n if (texture.isReady()) {\r\n scene.onBeforeRenderObservable.remove(oo);\r\n RGBDTextureTools.ExpandRGBDTexture(texture);\r\n }\r\n });\r\n });\r\n\r\n scene.onDisposeObservable.add(() => {\r\n scene.getEngine().onContextRestoredObservable.remove(observer);\r\n });\r\n }\r\n\r\n return scene.environmentBRDFTexture;\r\n};\r\n\r\n/**\r\n * Class used to host texture specific utilities\r\n */\r\nexport const BRDFTextureTools = {\r\n /**\r\n * Gets a default environment BRDF for MS-BRDF Height Correlated BRDF\r\n * @param scene defines the hosting scene\r\n * @returns the environment BRDF texture\r\n */\r\n // eslint-disable-next-line @typescript-eslint/naming-convention\r\n GetEnvironmentBRDFTexture,\r\n};\r\n"]}
|
|
1
|
+
{"version":3,"file":"brdfTextureTools.js","sourceRoot":"","sources":["../../../../dev/core/src/Misc/brdfTextureTools.ts"],"names":[],"mappings":"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","sourcesContent":["import type { BaseTexture } from \"../Materials/Textures/baseTexture\";\r\nimport { Texture } from \"../Materials/Textures/texture\";\r\nimport type { Scene } from \"../scene\";\r\nimport { RGBDTextureTools } from \"./rgbdTextureTools\";\r\n\r\n// eslint-disable-next-line @typescript-eslint/naming-convention\r\nconst _environmentBRDFBase64Texture =\r\n \"\";\r\n\r\n// Multiple-Scattering Sheen BRDF LUT from https://github.com/tizian/ltc-sheen\r\n// eslint-disable-next-line @typescript-eslint/naming-convention\r\nconst _environmentFuzzBRDFBase64Texture =\r\n \"\";\r\n\r\nlet InstanceNumber = 0;\r\n\r\n/**\r\n * Internal function to load and setup BRDF textures\r\n * @param scene defines the hosting scene\r\n * @param textureData defines the base64 texture data\r\n * @param textureProperty defines the scene property name to store the texture\r\n * @param textureName defines the name for the texture\r\n * @returns the environment BRDF texture\r\n */\r\n// eslint-disable-next-line @typescript-eslint/naming-convention\r\nconst loadBRDFTexture = (scene: Scene, textureData: string, textureProperty: string, textureName: string): BaseTexture => {\r\n if (!(scene as any)[textureProperty]) {\r\n // Forces Delayed Texture Loading to prevent undefined error whilst setting RGBD values.\r\n const useDelayedTextureLoading = scene.useDelayedTextureLoading;\r\n scene.useDelayedTextureLoading = false;\r\n\r\n const previousState = scene._blockEntityCollection;\r\n scene._blockEntityCollection = false;\r\n const texture = Texture.CreateFromBase64String(textureData, textureName + InstanceNumber++, scene, true, false, Texture.BILINEAR_SAMPLINGMODE);\r\n scene._blockEntityCollection = previousState;\r\n // BRDF Texture should not be cached here due to pre processing and redundant scene caches.\r\n const texturesCache = scene.getEngine().getLoadedTexturesCache();\r\n const index = texturesCache.indexOf(texture.getInternalTexture()!);\r\n if (index !== -1) {\r\n texturesCache.splice(index, 1);\r\n }\r\n\r\n texture.isRGBD = true;\r\n texture.wrapU = Texture.CLAMP_ADDRESSMODE;\r\n texture.wrapV = Texture.CLAMP_ADDRESSMODE;\r\n (scene as any)[textureProperty] = texture;\r\n\r\n scene.useDelayedTextureLoading = useDelayedTextureLoading;\r\n\r\n RGBDTextureTools.ExpandRGBDTexture(texture);\r\n\r\n const observer = scene.getEngine().onContextRestoredObservable.add(() => {\r\n texture.isRGBD = true;\r\n /**\r\n * Using scene.onBeforeRenderObservable instead of Tools.SetImmediate to check the texture's state of readiness allows us to check before any rendering occurs.\r\n * When a context restore occurs, it gives ExpandRGBDTexture the ability to reset the state to false, preventing the texture from being used in any rendering.\r\n * In WebGPU, not doing so would generate an error because ExpandRGBDTexture performs a _swapAndDie on the texture, which causes WebGPU caches to fail if the texture has already been used for rendering.\r\n * Only when ExpandRGBDTexture has finished its work, the texture is ready to be used again.\r\n */\r\n const oo = scene.onBeforeRenderObservable.add(() => {\r\n if (texture.isReady()) {\r\n scene.onBeforeRenderObservable.remove(oo);\r\n RGBDTextureTools.ExpandRGBDTexture(texture);\r\n }\r\n });\r\n });\r\n\r\n scene.onDisposeObservable.add(() => {\r\n scene.getEngine().onContextRestoredObservable.remove(observer);\r\n });\r\n }\r\n\r\n return (scene as any)[textureProperty];\r\n};\r\n\r\n/**\r\n * Gets a default environment BRDF for MS-BRDF Height Correlated BRDF\r\n * @param scene defines the hosting scene\r\n * @returns the environment BRDF texture\r\n */\r\nexport const GetEnvironmentBRDFTexture = (scene: Scene): BaseTexture => {\r\n return loadBRDFTexture(scene, _environmentBRDFBase64Texture, \"environmentBRDFTexture\", \"EnvironmentBRDFTexture\");\r\n};\r\n\r\n/**\r\n * Gets a default environment fuzz BRDF texture\r\n * @param scene defines the hosting scene\r\n * @returns the environment fuzz BRDF texture\r\n */\r\nexport const GetEnvironmentFuzzBRDFTexture = (scene: Scene): BaseTexture => {\r\n return loadBRDFTexture(scene, _environmentFuzzBRDFBase64Texture, \"environmentFuzzBRDFTexture\", \"EnvironmentFuzzBRDFTexture\");\r\n};\r\n\r\n/**\r\n * Class used to host texture specific utilities\r\n */\r\nexport const BRDFTextureTools = {\r\n /**\r\n * Gets a default environment BRDF for MS-BRDF Height Correlated BRDF\r\n * @param scene defines the hosting scene\r\n * @returns the environment BRDF texture\r\n */\r\n // eslint-disable-next-line @typescript-eslint/naming-convention\r\n GetEnvironmentBRDFTexture,\r\n\r\n /**\r\n * Gets a default environment fuzz BRDF texture\r\n * @param scene defines the hosting scene\r\n * @returns the environment fuzz BRDF texture\r\n */\r\n // eslint-disable-next-line @typescript-eslint/naming-convention\r\n GetEnvironmentFuzzBRDFTexture,\r\n};\r\n"]}
|
|
@@ -199,6 +199,8 @@ export declare class MorphTargetManager implements IDisposable {
|
|
|
199
199
|
* @returns the requested target
|
|
200
200
|
*/
|
|
201
201
|
getTargetByName(name: string): Nullable<MorphTarget>;
|
|
202
|
+
private _influencesAreDirty;
|
|
203
|
+
private _needUpdateInfluences;
|
|
202
204
|
/**
|
|
203
205
|
* Add a new target to this manager
|
|
204
206
|
* @param target defines the target to add
|
|
@@ -92,6 +92,8 @@ export class MorphTargetManager {
|
|
|
92
92
|
* Gets or sets an object used to store user defined information for the MorphTargetManager
|
|
93
93
|
*/
|
|
94
94
|
this.metadata = null;
|
|
95
|
+
this._influencesAreDirty = false;
|
|
96
|
+
this._needUpdateInfluences = false;
|
|
95
97
|
if (!scene) {
|
|
96
98
|
scene = EngineStore.LastCreatedScene;
|
|
97
99
|
}
|
|
@@ -221,12 +223,18 @@ export class MorphTargetManager {
|
|
|
221
223
|
* Gets the number of influencers (ie. the number of targets with influences > 0)
|
|
222
224
|
*/
|
|
223
225
|
get numInfluencers() {
|
|
226
|
+
if (this._influencesAreDirty) {
|
|
227
|
+
this._syncActiveTargets();
|
|
228
|
+
}
|
|
224
229
|
return this._activeTargets.length;
|
|
225
230
|
}
|
|
226
231
|
/**
|
|
227
232
|
* Gets the list of influences (one per target)
|
|
228
233
|
*/
|
|
229
234
|
get influences() {
|
|
235
|
+
if (this._influencesAreDirty) {
|
|
236
|
+
this._syncActiveTargets();
|
|
237
|
+
}
|
|
230
238
|
return this._influences;
|
|
231
239
|
}
|
|
232
240
|
/**
|
|
@@ -259,6 +267,9 @@ export class MorphTargetManager {
|
|
|
259
267
|
* @returns the requested target
|
|
260
268
|
*/
|
|
261
269
|
getActiveTarget(index) {
|
|
270
|
+
if (this._influencesAreDirty) {
|
|
271
|
+
this._syncActiveTargets();
|
|
272
|
+
}
|
|
262
273
|
return this._activeTargets.data[index];
|
|
263
274
|
}
|
|
264
275
|
/**
|
|
@@ -292,7 +303,8 @@ export class MorphTargetManager {
|
|
|
292
303
|
if (this.areUpdatesFrozen && needUpdate) {
|
|
293
304
|
this._forceUpdateWhenUnfrozen = true;
|
|
294
305
|
}
|
|
295
|
-
this.
|
|
306
|
+
this._influencesAreDirty = true;
|
|
307
|
+
this._needUpdateInfluences = this._needUpdateInfluences || needUpdate;
|
|
296
308
|
}));
|
|
297
309
|
this._targetDataLayoutChangedObservers.push(target._onDataLayoutChanged.add(() => {
|
|
298
310
|
this._mustSynchronize = true;
|
|
@@ -322,6 +334,9 @@ export class MorphTargetManager {
|
|
|
322
334
|
* @internal
|
|
323
335
|
*/
|
|
324
336
|
_bind(effect) {
|
|
337
|
+
if (this._influencesAreDirty) {
|
|
338
|
+
this._syncActiveTargets();
|
|
339
|
+
}
|
|
325
340
|
effect.setFloat3("morphTargetTextureInfo", this._textureVertexStride, this._textureWidth, this._textureHeight);
|
|
326
341
|
effect.setFloatArray("morphTargetTextureIndices", this._morphTargetTextureIndices);
|
|
327
342
|
effect.setTexture("morphTargets", this._targetStoreTexture);
|
|
@@ -367,6 +382,9 @@ export class MorphTargetManager {
|
|
|
367
382
|
if (this.areUpdatesFrozen) {
|
|
368
383
|
return;
|
|
369
384
|
}
|
|
385
|
+
needUpdate = needUpdate || this._needUpdateInfluences;
|
|
386
|
+
this._needUpdateInfluences = false;
|
|
387
|
+
this._influencesAreDirty = false;
|
|
370
388
|
const wasUsingTextureForTargets = !!this._targetStoreTexture;
|
|
371
389
|
const isUsingTextureForTargets = this.isUsingTextureForTargets;
|
|
372
390
|
if (this._mustSynchronize || wasUsingTextureForTargets !== isUsingTextureForTargets) {
|