@babylonjs/viewer 5.0.0-rc.3 → 5.0.1
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/configuration/configuration.d.ts +107 -107
- package/configuration/configuration.js +15 -15
- package/configuration/configuration.js.map +1 -1
- package/configuration/configurationCompatibility.d.ts +8 -8
- package/configuration/configurationCompatibility.js +65 -65
- package/configuration/configurationCompatibility.js.map +1 -1
- package/configuration/configurationContainer.d.ts +10 -10
- package/configuration/configurationContainer.js +9 -9
- package/configuration/configurationContainer.js.map +1 -1
- package/configuration/globals.d.ts +6 -6
- package/configuration/globals.js +17 -17
- package/configuration/globals.js.map +1 -1
- package/configuration/index.d.ts +2 -2
- package/configuration/index.js +3 -2
- package/configuration/index.js.map +1 -1
- package/configuration/interfaces/cameraConfiguration.d.ts +31 -31
- package/configuration/interfaces/cameraConfiguration.js +1 -1
- package/configuration/interfaces/cameraConfiguration.js.map +1 -1
- package/configuration/interfaces/colorGradingConfiguration.d.ts +81 -81
- package/configuration/interfaces/colorGradingConfiguration.js +1 -1
- package/configuration/interfaces/colorGradingConfiguration.js.map +1 -1
- package/configuration/interfaces/defaultRenderingPipelineConfiguration.d.ts +20 -20
- package/configuration/interfaces/defaultRenderingPipelineConfiguration.js +1 -1
- package/configuration/interfaces/defaultRenderingPipelineConfiguration.js.map +1 -1
- package/configuration/interfaces/environmentMapConfiguration.d.ts +22 -22
- package/configuration/interfaces/environmentMapConfiguration.js +1 -1
- package/configuration/interfaces/environmentMapConfiguration.js.map +1 -1
- package/configuration/interfaces/groundConfiguration.d.ts +24 -24
- package/configuration/interfaces/groundConfiguration.js +1 -1
- package/configuration/interfaces/groundConfiguration.js.map +1 -1
- package/configuration/interfaces/imageProcessingConfiguration.d.ts +43 -43
- package/configuration/interfaces/imageProcessingConfiguration.js +1 -1
- package/configuration/interfaces/imageProcessingConfiguration.js.map +1 -1
- package/configuration/interfaces/index.d.ts +15 -15
- package/configuration/interfaces/index.js +15 -15
- package/configuration/interfaces/index.js.map +1 -1
- package/configuration/interfaces/lightConfiguration.d.ts +60 -60
- package/configuration/interfaces/lightConfiguration.js +1 -1
- package/configuration/interfaces/lightConfiguration.js.map +1 -1
- package/configuration/interfaces/modelAnimationConfiguration.d.ts +26 -26
- package/configuration/interfaces/modelAnimationConfiguration.js +1 -1
- package/configuration/interfaces/modelAnimationConfiguration.js.map +1 -1
- package/configuration/interfaces/modelConfiguration.d.ts +65 -65
- package/configuration/interfaces/modelConfiguration.js +1 -1
- package/configuration/interfaces/modelConfiguration.js.map +1 -1
- package/configuration/interfaces/observersConfiguration.d.ts +5 -5
- package/configuration/interfaces/observersConfiguration.js +1 -1
- package/configuration/interfaces/observersConfiguration.js.map +1 -1
- package/configuration/interfaces/sceneConfiguration.d.ts +48 -48
- package/configuration/interfaces/sceneConfiguration.js +1 -1
- package/configuration/interfaces/sceneConfiguration.js.map +1 -1
- package/configuration/interfaces/sceneOptimizerConfiguration.d.ts +23 -23
- package/configuration/interfaces/sceneOptimizerConfiguration.js +1 -1
- package/configuration/interfaces/sceneOptimizerConfiguration.js.map +1 -1
- package/configuration/interfaces/skyboxConfiguration.d.ts +21 -21
- package/configuration/interfaces/skyboxConfiguration.js +1 -1
- package/configuration/interfaces/skyboxConfiguration.js.map +1 -1
- package/configuration/interfaces/templateConfiguration.d.ts +67 -67
- package/configuration/interfaces/templateConfiguration.js +1 -1
- package/configuration/interfaces/templateConfiguration.js.map +1 -1
- package/configuration/interfaces/vrConfiguration.d.ts +16 -16
- package/configuration/interfaces/vrConfiguration.js +1 -1
- package/configuration/interfaces/vrConfiguration.js.map +1 -1
- package/configuration/loader.d.ts +4 -4
- package/configuration/loader.js +16 -28
- package/configuration/loader.js.map +1 -1
- package/configuration/mappers.d.ts +42 -42
- package/configuration/mappers.js +190 -189
- package/configuration/mappers.js.map +1 -1
- package/configuration/renderOnlyLoader.d.ts +33 -33
- package/configuration/renderOnlyLoader.js +161 -158
- package/configuration/renderOnlyLoader.js.map +1 -1
- package/configuration/types/default.d.ts +6 -6
- package/configuration/types/default.js +120 -119
- package/configuration/types/default.js.map +1 -1
- package/configuration/types/environmentMap.d.ts +5 -5
- package/configuration/types/environmentMap.js +13 -13
- package/configuration/types/environmentMap.js.map +1 -1
- package/configuration/types/extended.d.ts +6 -6
- package/configuration/types/extended.js +316 -316
- package/configuration/types/extended.js.map +1 -1
- package/configuration/types/index.d.ts +13 -13
- package/configuration/types/index.js +49 -48
- package/configuration/types/index.js.map +1 -1
- package/configuration/types/minimal.d.ts +6 -6
- package/configuration/types/minimal.js +42 -42
- package/configuration/types/minimal.js.map +1 -1
- package/configuration/types/renderOnlyDefault.d.ts +30 -30
- package/configuration/types/renderOnlyDefault.js +30 -30
- package/configuration/types/renderOnlyDefault.js.map +1 -1
- package/configuration/types/shadowLight.d.ts +9 -9
- package/configuration/types/shadowLight.js +63 -63
- package/configuration/types/shadowLight.js.map +1 -1
- package/helper/index.d.ts +26 -26
- package/helper/index.js +62 -56
- package/helper/index.js.map +1 -1
- package/index.d.ts +30 -30
- package/index.js +45 -41
- package/index.js.map +1 -1
- package/initializer.d.ts +11 -11
- package/initializer.js +34 -33
- package/initializer.js.map +1 -1
- package/interfaces.d.ts +5 -5
- package/interfaces.js +1 -1
- package/interfaces.js.map +1 -1
- package/labs/environmentSerializer.d.ts +126 -126
- package/labs/environmentSerializer.js +190 -186
- package/labs/environmentSerializer.js.map +1 -1
- package/labs/texture.d.ts +183 -184
- package/labs/texture.js +300 -297
- package/labs/texture.js.map +1 -1
- package/labs/viewerLabs.d.ts +51 -51
- package/labs/viewerLabs.js +133 -131
- package/labs/viewerLabs.js.map +1 -1
- package/license.md +71 -0
- package/loader/modelLoader.d.ts +47 -44
- package/loader/modelLoader.js +189 -182
- package/loader/modelLoader.js.map +1 -1
- package/loader/plugins/applyMaterialConfig.d.ts +12 -12
- package/loader/plugins/applyMaterialConfig.js +15 -15
- package/loader/plugins/applyMaterialConfig.js.map +1 -1
- package/loader/plugins/extendedMaterialLoaderPlugin.d.ts +9 -9
- package/loader/plugins/extendedMaterialLoaderPlugin.js +15 -15
- package/loader/plugins/extendedMaterialLoaderPlugin.js.map +1 -1
- package/loader/plugins/index.d.ts +18 -17
- package/loader/plugins/index.js +42 -41
- package/loader/plugins/index.js.map +1 -1
- package/loader/plugins/loaderPlugin.d.ts +24 -24
- package/loader/plugins/loaderPlugin.js +1 -1
- package/loader/plugins/loaderPlugin.js.map +1 -1
- package/loader/plugins/msftLodLoaderPlugin.d.ts +12 -12
- package/loader/plugins/msftLodLoaderPlugin.js +20 -19
- package/loader/plugins/msftLodLoaderPlugin.js.map +1 -1
- package/loader/plugins/telemetryLoaderPlugin.d.ts +12 -12
- package/loader/plugins/telemetryLoaderPlugin.js +35 -35
- package/loader/plugins/telemetryLoaderPlugin.js.map +1 -1
- package/managers/observablesManager.d.ts +66 -66
- package/managers/observablesManager.js +34 -34
- package/managers/observablesManager.js.map +1 -1
- package/managers/sceneManager.d.ts +243 -245
- package/managers/sceneManager.js +1388 -1387
- package/managers/sceneManager.js.map +1 -1
- package/managers/telemetryManager.d.ts +57 -57
- package/managers/telemetryManager.js +113 -113
- package/managers/telemetryManager.js.map +1 -1
- package/model/modelAnimation.d.ts +215 -215
- package/model/modelAnimation.js +232 -232
- package/model/modelAnimation.js.map +1 -1
- package/model/viewerModel.d.ts +228 -236
- package/model/viewerModel.js +669 -664
- package/model/viewerModel.js.map +1 -1
- package/optimizer/custom/extended.d.ts +11 -13
- package/optimizer/custom/extended.js +98 -100
- package/optimizer/custom/extended.js.map +1 -1
- package/optimizer/custom/index.d.ts +8 -8
- package/optimizer/custom/index.js +24 -24
- package/optimizer/custom/index.js.map +1 -1
- package/package.json +41 -215
- package/readme.md +12 -8
- package/renderOnlyIndex.d.ts +11 -11
- package/renderOnlyIndex.js +17 -15
- package/renderOnlyIndex.js.map +1 -1
- package/templating/eventManager.d.ts +35 -35
- package/templating/eventManager.js +65 -63
- package/templating/eventManager.js.map +1 -1
- package/templating/plugins/hdButtonPlugin.d.ts +9 -9
- package/templating/plugins/hdButtonPlugin.js +21 -34
- package/templating/plugins/hdButtonPlugin.js.map +1 -1
- package/templating/plugins/printButton.d.ts +9 -10
- package/templating/plugins/printButton.js +40 -53
- package/templating/plugins/printButton.js.map +1 -1
- package/templating/templateManager.d.ts +190 -189
- package/templating/templateManager.js +553 -543
- package/templating/templateManager.js.map +1 -1
- package/templating/viewerTemplatePlugin.d.ts +21 -21
- package/templating/viewerTemplatePlugin.js +68 -68
- package/templating/viewerTemplatePlugin.js.map +1 -1
- package/viewer/defaultViewer.d.ts +122 -116
- package/viewer/defaultViewer.js +665 -670
- package/viewer/defaultViewer.js.map +1 -1
- package/viewer/renderOnlyViewer.d.ts +8 -8
- package/viewer/renderOnlyViewer.js +43 -50
- package/viewer/renderOnlyViewer.js.map +1 -1
- package/viewer/viewer.d.ts +254 -253
- package/viewer/viewer.js +777 -763
- package/viewer/viewer.js.map +1 -1
- package/viewer/viewerManager.d.ts +55 -55
- package/viewer/viewerManager.js +87 -86
- package/viewer/viewerManager.js.map +1 -1
- package/viewer/viewerWithTemplate.d.ts +9 -9
- package/viewer/viewerWithTemplate.js +19 -32
- package/viewer/viewerWithTemplate.js.map +1 -1
|
@@ -1,126 +1,126 @@
|
|
|
1
|
-
import { Vector3 } from
|
|
2
|
-
import { TextureCube } from
|
|
3
|
-
/**
|
|
4
|
-
* Spherical polynomial coefficients (counter part to spherical harmonic coefficients used in shader irradiance calculation)
|
|
5
|
-
* @ignoreChildren
|
|
6
|
-
*/
|
|
7
|
-
export interface SphericalPolynomalCoefficients {
|
|
8
|
-
x: Vector3;
|
|
9
|
-
y: Vector3;
|
|
10
|
-
z: Vector3;
|
|
11
|
-
xx: Vector3;
|
|
12
|
-
yy: Vector3;
|
|
13
|
-
zz: Vector3;
|
|
14
|
-
yz: Vector3;
|
|
15
|
-
zx: Vector3;
|
|
16
|
-
xy: Vector3;
|
|
17
|
-
}
|
|
18
|
-
/**
|
|
19
|
-
* Wraps data and maps required for environments with physically based rendering
|
|
20
|
-
*/
|
|
21
|
-
export interface PBREnvironment {
|
|
22
|
-
/**
|
|
23
|
-
* Spherical Polynomial Coefficients representing an irradiance map
|
|
24
|
-
*/
|
|
25
|
-
irradiancePolynomialCoefficients: SphericalPolynomalCoefficients;
|
|
26
|
-
/**
|
|
27
|
-
* Specular cubemap
|
|
28
|
-
*/
|
|
29
|
-
specularTexture?: TextureCube;
|
|
30
|
-
/**
|
|
31
|
-
* A scale factor applied to RGB values after reading from environment maps
|
|
32
|
-
*/
|
|
33
|
-
textureIntensityScale: number;
|
|
34
|
-
}
|
|
35
|
-
/**
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
export declare type MapType =
|
|
39
|
-
/**
|
|
40
|
-
* Image type used for environment map
|
|
41
|
-
*/
|
|
42
|
-
export declare type ImageType =
|
|
43
|
-
/**
|
|
44
|
-
* A generic field in JSON that report's its type
|
|
45
|
-
*/
|
|
46
|
-
export interface TypedObject<T> {
|
|
47
|
-
type: T;
|
|
48
|
-
}
|
|
49
|
-
/**
|
|
50
|
-
* Describes a range of bytes starting at byte pos (inclusive) and finishing at byte pos + length - 1
|
|
51
|
-
*/
|
|
52
|
-
export interface ByteRange {
|
|
53
|
-
pos: number;
|
|
54
|
-
length: number;
|
|
55
|
-
}
|
|
56
|
-
/**
|
|
57
|
-
* Complete Spectre Environment JSON Descriptor
|
|
58
|
-
*/
|
|
59
|
-
export interface EnvJsonDescriptor {
|
|
60
|
-
radiance: TypedObject<MapType>;
|
|
61
|
-
irradiance: TypedObject<MapType>;
|
|
62
|
-
specular: TypedObject<MapType>;
|
|
63
|
-
}
|
|
64
|
-
/**
|
|
65
|
-
* Spherical harmonic coefficients to provide an irradiance map
|
|
66
|
-
*/
|
|
67
|
-
export interface IrradianceSHCoefficients9 extends TypedObject<MapType> {
|
|
68
|
-
l00: Array<number>;
|
|
69
|
-
l1_1: Array<number>;
|
|
70
|
-
l10: Array<number>;
|
|
71
|
-
l11: Array<number>;
|
|
72
|
-
l2_2: Array<number>;
|
|
73
|
-
l2_1: Array<number>;
|
|
74
|
-
l20: Array<number>;
|
|
75
|
-
l21: Array<number>;
|
|
76
|
-
l22: Array<number>;
|
|
77
|
-
}
|
|
78
|
-
/**
|
|
79
|
-
* A generic set of images, where the image content is specified by byte ranges in the mipmaps field
|
|
80
|
-
*/
|
|
81
|
-
export interface ImageSet<T> extends TypedObject<MapType> {
|
|
82
|
-
imageType: ImageType;
|
|
83
|
-
width: number;
|
|
84
|
-
height: number;
|
|
85
|
-
mipmaps: Array<T>;
|
|
86
|
-
multiplier: number;
|
|
87
|
-
}
|
|
88
|
-
/**
|
|
89
|
-
* A set of cubemap faces
|
|
90
|
-
*/
|
|
91
|
-
export declare type CubemapFaces = ImageSet<Array<ByteRange>>;
|
|
92
|
-
/**
|
|
93
|
-
* A single image containing an atlas of equirectangular-projection maps across all mip levels
|
|
94
|
-
*/
|
|
95
|
-
export declare type EquirectangularMipmapAtlas = ImageSet<ByteRange>;
|
|
96
|
-
/**
|
|
97
|
-
* A static class proving methods to aid parsing Spectre environment files
|
|
98
|
-
*/
|
|
99
|
-
export declare class EnvironmentDeserializer {
|
|
100
|
-
/**
|
|
101
|
-
* Parses an arraybuffer into a new PBREnvironment object
|
|
102
|
-
* @param arrayBuffer The arraybuffer of the Spectre environment file
|
|
103
|
-
* @return a PBREnvironment object
|
|
104
|
-
*/
|
|
105
|
-
static Parse(arrayBuffer: ArrayBuffer): PBREnvironment;
|
|
106
|
-
/**
|
|
107
|
-
* Convert from irradiance to outgoing radiance for Lambertian BDRF, suitable for efficient shader evaluation.
|
|
108
|
-
* L = (1/pi) * E * rho
|
|
109
|
-
*
|
|
110
|
-
* This is done by an additional scale by 1/pi, so is a fairly trivial operation but important conceptually.
|
|
111
|
-
* @param harmonics Spherical harmonic coefficients (9)
|
|
112
|
-
*/
|
|
113
|
-
private static _ConvertSHIrradianceToLambertianRadiance;
|
|
114
|
-
/**
|
|
115
|
-
* Convert spherical harmonics to spherical polynomial coefficients
|
|
116
|
-
* @param harmonics Spherical harmonic coefficients (9)
|
|
117
|
-
* @param outPolynomialCoefficents Polynomial coefficients (9) object to store result
|
|
118
|
-
*/
|
|
119
|
-
private static _ConvertSHToSP;
|
|
120
|
-
/**
|
|
121
|
-
* Multiplies harmonic coefficients in place
|
|
122
|
-
* @param harmonics Spherical harmonic coefficients (9)
|
|
123
|
-
* @param scaleFactor Value to multiply by
|
|
124
|
-
*/
|
|
125
|
-
private static _ScaleSH;
|
|
126
|
-
}
|
|
1
|
+
import { Vector3 } from "@babylonjs/core/Maths/math.js";
|
|
2
|
+
import { TextureCube } from "./texture";
|
|
3
|
+
/**
|
|
4
|
+
* Spherical polynomial coefficients (counter part to spherical harmonic coefficients used in shader irradiance calculation)
|
|
5
|
+
* @ignoreChildren
|
|
6
|
+
*/
|
|
7
|
+
export interface SphericalPolynomalCoefficients {
|
|
8
|
+
x: Vector3;
|
|
9
|
+
y: Vector3;
|
|
10
|
+
z: Vector3;
|
|
11
|
+
xx: Vector3;
|
|
12
|
+
yy: Vector3;
|
|
13
|
+
zz: Vector3;
|
|
14
|
+
yz: Vector3;
|
|
15
|
+
zx: Vector3;
|
|
16
|
+
xy: Vector3;
|
|
17
|
+
}
|
|
18
|
+
/**
|
|
19
|
+
* Wraps data and maps required for environments with physically based rendering
|
|
20
|
+
*/
|
|
21
|
+
export interface PBREnvironment {
|
|
22
|
+
/**
|
|
23
|
+
* Spherical Polynomial Coefficients representing an irradiance map
|
|
24
|
+
*/
|
|
25
|
+
irradiancePolynomialCoefficients: SphericalPolynomalCoefficients;
|
|
26
|
+
/**
|
|
27
|
+
* Specular cubemap
|
|
28
|
+
*/
|
|
29
|
+
specularTexture?: TextureCube;
|
|
30
|
+
/**
|
|
31
|
+
* A scale factor applied to RGB values after reading from environment maps
|
|
32
|
+
*/
|
|
33
|
+
textureIntensityScale: number;
|
|
34
|
+
}
|
|
35
|
+
/**
|
|
36
|
+
* Environment map representations: layouts, projections and approximations
|
|
37
|
+
*/
|
|
38
|
+
export declare type MapType = "irradiance_sh_coefficients_9" | "cubemap_faces";
|
|
39
|
+
/**
|
|
40
|
+
* Image type used for environment map
|
|
41
|
+
*/
|
|
42
|
+
export declare type ImageType = "png";
|
|
43
|
+
/**
|
|
44
|
+
* A generic field in JSON that report's its type
|
|
45
|
+
*/
|
|
46
|
+
export interface TypedObject<T> {
|
|
47
|
+
type: T;
|
|
48
|
+
}
|
|
49
|
+
/**
|
|
50
|
+
* Describes a range of bytes starting at byte pos (inclusive) and finishing at byte pos + length - 1
|
|
51
|
+
*/
|
|
52
|
+
export interface ByteRange {
|
|
53
|
+
pos: number;
|
|
54
|
+
length: number;
|
|
55
|
+
}
|
|
56
|
+
/**
|
|
57
|
+
* Complete Spectre Environment JSON Descriptor
|
|
58
|
+
*/
|
|
59
|
+
export interface EnvJsonDescriptor {
|
|
60
|
+
radiance: TypedObject<MapType>;
|
|
61
|
+
irradiance: TypedObject<MapType>;
|
|
62
|
+
specular: TypedObject<MapType>;
|
|
63
|
+
}
|
|
64
|
+
/**
|
|
65
|
+
* Spherical harmonic coefficients to provide an irradiance map
|
|
66
|
+
*/
|
|
67
|
+
export interface IrradianceSHCoefficients9 extends TypedObject<MapType> {
|
|
68
|
+
l00: Array<number>;
|
|
69
|
+
l1_1: Array<number>;
|
|
70
|
+
l10: Array<number>;
|
|
71
|
+
l11: Array<number>;
|
|
72
|
+
l2_2: Array<number>;
|
|
73
|
+
l2_1: Array<number>;
|
|
74
|
+
l20: Array<number>;
|
|
75
|
+
l21: Array<number>;
|
|
76
|
+
l22: Array<number>;
|
|
77
|
+
}
|
|
78
|
+
/**
|
|
79
|
+
* A generic set of images, where the image content is specified by byte ranges in the mipmaps field
|
|
80
|
+
*/
|
|
81
|
+
export interface ImageSet<T> extends TypedObject<MapType> {
|
|
82
|
+
imageType: ImageType;
|
|
83
|
+
width: number;
|
|
84
|
+
height: number;
|
|
85
|
+
mipmaps: Array<T>;
|
|
86
|
+
multiplier: number;
|
|
87
|
+
}
|
|
88
|
+
/**
|
|
89
|
+
* A set of cubemap faces
|
|
90
|
+
*/
|
|
91
|
+
export declare type CubemapFaces = ImageSet<Array<ByteRange>>;
|
|
92
|
+
/**
|
|
93
|
+
* A single image containing an atlas of equirectangular-projection maps across all mip levels
|
|
94
|
+
*/
|
|
95
|
+
export declare type EquirectangularMipmapAtlas = ImageSet<ByteRange>;
|
|
96
|
+
/**
|
|
97
|
+
* A static class proving methods to aid parsing Spectre environment files
|
|
98
|
+
*/
|
|
99
|
+
export declare class EnvironmentDeserializer {
|
|
100
|
+
/**
|
|
101
|
+
* Parses an arraybuffer into a new PBREnvironment object
|
|
102
|
+
* @param arrayBuffer The arraybuffer of the Spectre environment file
|
|
103
|
+
* @return a PBREnvironment object
|
|
104
|
+
*/
|
|
105
|
+
static Parse(arrayBuffer: ArrayBuffer): PBREnvironment;
|
|
106
|
+
/**
|
|
107
|
+
* Convert from irradiance to outgoing radiance for Lambertian BDRF, suitable for efficient shader evaluation.
|
|
108
|
+
* L = (1/pi) * E * rho
|
|
109
|
+
*
|
|
110
|
+
* This is done by an additional scale by 1/pi, so is a fairly trivial operation but important conceptually.
|
|
111
|
+
* @param harmonics Spherical harmonic coefficients (9)
|
|
112
|
+
*/
|
|
113
|
+
private static _ConvertSHIrradianceToLambertianRadiance;
|
|
114
|
+
/**
|
|
115
|
+
* Convert spherical harmonics to spherical polynomial coefficients
|
|
116
|
+
* @param harmonics Spherical harmonic coefficients (9)
|
|
117
|
+
* @param outPolynomialCoefficents Polynomial coefficients (9) object to store result
|
|
118
|
+
*/
|
|
119
|
+
private static _ConvertSHToSP;
|
|
120
|
+
/**
|
|
121
|
+
* Multiplies harmonic coefficients in place
|
|
122
|
+
* @param harmonics Spherical harmonic coefficients (9)
|
|
123
|
+
* @param scaleFactor Value to multiply by
|
|
124
|
+
*/
|
|
125
|
+
private static _ScaleSH;
|
|
126
|
+
}
|
|
@@ -1,187 +1,191 @@
|
|
|
1
|
-
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
*
|
|
13
|
-
* @
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
var
|
|
35
|
-
var
|
|
36
|
-
var
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
pos
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
var
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
var
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
var
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
image
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
*
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
outPolynomialCoefficents.
|
|
125
|
-
outPolynomialCoefficents.y
|
|
126
|
-
outPolynomialCoefficents.z
|
|
127
|
-
outPolynomialCoefficents.
|
|
128
|
-
outPolynomialCoefficents.
|
|
129
|
-
|
|
130
|
-
outPolynomialCoefficents.
|
|
131
|
-
outPolynomialCoefficents.
|
|
132
|
-
outPolynomialCoefficents.
|
|
133
|
-
|
|
134
|
-
outPolynomialCoefficents.
|
|
135
|
-
outPolynomialCoefficents.
|
|
136
|
-
outPolynomialCoefficents.
|
|
137
|
-
outPolynomialCoefficents.
|
|
138
|
-
outPolynomialCoefficents.
|
|
139
|
-
|
|
140
|
-
outPolynomialCoefficents.
|
|
141
|
-
outPolynomialCoefficents.
|
|
142
|
-
outPolynomialCoefficents.
|
|
143
|
-
|
|
144
|
-
outPolynomialCoefficents.
|
|
145
|
-
outPolynomialCoefficents.
|
|
146
|
-
outPolynomialCoefficents.
|
|
147
|
-
outPolynomialCoefficents.
|
|
148
|
-
outPolynomialCoefficents.
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
harmonics.
|
|
161
|
-
harmonics.
|
|
162
|
-
harmonics.
|
|
163
|
-
harmonics.
|
|
164
|
-
harmonics.
|
|
165
|
-
harmonics.
|
|
166
|
-
harmonics.
|
|
167
|
-
harmonics.
|
|
168
|
-
harmonics.
|
|
169
|
-
harmonics.
|
|
170
|
-
harmonics.
|
|
171
|
-
harmonics.
|
|
172
|
-
harmonics.
|
|
173
|
-
harmonics.
|
|
174
|
-
harmonics.
|
|
175
|
-
harmonics.
|
|
176
|
-
harmonics.
|
|
177
|
-
harmonics.
|
|
178
|
-
harmonics.
|
|
179
|
-
harmonics.
|
|
180
|
-
harmonics.
|
|
181
|
-
harmonics.
|
|
182
|
-
harmonics.
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
1
|
+
/* eslint-disable @typescript-eslint/naming-convention */
|
|
2
|
+
import { Vector3 } from "@babylonjs/core/Maths/math.js";
|
|
3
|
+
import { Tools } from "@babylonjs/core/Misc/tools.js";
|
|
4
|
+
import { TextureCube } from "./texture.js";
|
|
5
|
+
/**
|
|
6
|
+
* A static class proving methods to aid parsing Spectre environment files
|
|
7
|
+
*/
|
|
8
|
+
var EnvironmentDeserializer = /** @class */ (function () {
|
|
9
|
+
function EnvironmentDeserializer() {
|
|
10
|
+
}
|
|
11
|
+
/**
|
|
12
|
+
* Parses an arraybuffer into a new PBREnvironment object
|
|
13
|
+
* @param arrayBuffer The arraybuffer of the Spectre environment file
|
|
14
|
+
* @return a PBREnvironment object
|
|
15
|
+
*/
|
|
16
|
+
EnvironmentDeserializer.Parse = function (arrayBuffer) {
|
|
17
|
+
var environment = {
|
|
18
|
+
//irradiance
|
|
19
|
+
irradiancePolynomialCoefficients: {
|
|
20
|
+
x: new Vector3(0, 0, 0),
|
|
21
|
+
y: new Vector3(0, 0, 0),
|
|
22
|
+
z: new Vector3(0, 0, 0),
|
|
23
|
+
xx: new Vector3(0, 0, 0),
|
|
24
|
+
yy: new Vector3(0, 0, 0),
|
|
25
|
+
zz: new Vector3(0, 0, 0),
|
|
26
|
+
yz: new Vector3(0, 0, 0),
|
|
27
|
+
zx: new Vector3(0, 0, 0),
|
|
28
|
+
xy: new Vector3(0, 0, 0),
|
|
29
|
+
},
|
|
30
|
+
//specular
|
|
31
|
+
textureIntensityScale: 1.0,
|
|
32
|
+
};
|
|
33
|
+
//read .env
|
|
34
|
+
var littleEndian = false;
|
|
35
|
+
var magicBytes = [0x86, 0x16, 0x87, 0x96, 0xf6, 0xd6, 0x96, 0x36];
|
|
36
|
+
var dataView = new DataView(arrayBuffer);
|
|
37
|
+
var pos = 0;
|
|
38
|
+
for (var i = 0; i < magicBytes.length; i++) {
|
|
39
|
+
if (dataView.getUint8(pos++) !== magicBytes[i]) {
|
|
40
|
+
Tools.Error("Not a Spectre environment map");
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
var version = dataView.getUint16(pos, littleEndian);
|
|
44
|
+
pos += 2;
|
|
45
|
+
if (version !== 1) {
|
|
46
|
+
Tools.Warn('Unsupported Spectre environment map version "' + version + '"');
|
|
47
|
+
}
|
|
48
|
+
//read json descriptor - collect characters up to null terminator
|
|
49
|
+
var descriptorString = "";
|
|
50
|
+
var charCode = 0x00;
|
|
51
|
+
while ((charCode = dataView.getUint8(pos++))) {
|
|
52
|
+
descriptorString += String.fromCharCode(charCode);
|
|
53
|
+
}
|
|
54
|
+
var descriptor = JSON.parse(descriptorString);
|
|
55
|
+
var payloadPos = pos;
|
|
56
|
+
//irradiance
|
|
57
|
+
switch (descriptor.irradiance.type) {
|
|
58
|
+
case "irradiance_sh_coefficients_9": {
|
|
59
|
+
//irradiance
|
|
60
|
+
var harmonics = descriptor.irradiance;
|
|
61
|
+
EnvironmentDeserializer._ConvertSHIrradianceToLambertianRadiance(harmonics);
|
|
62
|
+
//harmonics now represent radiance
|
|
63
|
+
EnvironmentDeserializer._ConvertSHToSP(harmonics, environment.irradiancePolynomialCoefficients);
|
|
64
|
+
break;
|
|
65
|
+
}
|
|
66
|
+
default:
|
|
67
|
+
Tools.Error("Unhandled MapType descriptor.irradiance.type (" + descriptor.irradiance.type + ")");
|
|
68
|
+
}
|
|
69
|
+
//specular
|
|
70
|
+
switch (descriptor.specular.type) {
|
|
71
|
+
case "cubemap_faces": {
|
|
72
|
+
var specularDescriptor = descriptor.specular;
|
|
73
|
+
var specularTexture = (environment.specularTexture = new TextureCube(6408 /* RGBA */, 5121 /* UNSIGNED_BYTE */));
|
|
74
|
+
environment.textureIntensityScale = specularDescriptor.multiplier != null ? specularDescriptor.multiplier : 1.0;
|
|
75
|
+
var mipmaps = specularDescriptor.mipmaps;
|
|
76
|
+
var imageType = specularDescriptor.imageType;
|
|
77
|
+
for (var l = 0; l < mipmaps.length; l++) {
|
|
78
|
+
var faceRanges = mipmaps[l];
|
|
79
|
+
specularTexture.source[l] = [];
|
|
80
|
+
for (var i = 0; i < 6; i++) {
|
|
81
|
+
var range = faceRanges[i];
|
|
82
|
+
var bytes = new Uint8Array(arrayBuffer, payloadPos + range.pos, range.length);
|
|
83
|
+
switch (imageType) {
|
|
84
|
+
case "png": {
|
|
85
|
+
//construct image element from bytes
|
|
86
|
+
var image = new Image();
|
|
87
|
+
var src = URL.createObjectURL(new Blob([bytes], { type: "image/png" }));
|
|
88
|
+
image.src = src;
|
|
89
|
+
specularTexture.source[l][i] = image;
|
|
90
|
+
break;
|
|
91
|
+
}
|
|
92
|
+
default:
|
|
93
|
+
Tools.Error("Unhandled ImageType descriptor.specular.imageType (" + imageType + ")");
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
break;
|
|
98
|
+
}
|
|
99
|
+
default:
|
|
100
|
+
Tools.Error("Unhandled MapType descriptor.specular.type (" + descriptor.specular.type + ")");
|
|
101
|
+
}
|
|
102
|
+
return environment;
|
|
103
|
+
};
|
|
104
|
+
/**
|
|
105
|
+
* Convert from irradiance to outgoing radiance for Lambertian BDRF, suitable for efficient shader evaluation.
|
|
106
|
+
* L = (1/pi) * E * rho
|
|
107
|
+
*
|
|
108
|
+
* This is done by an additional scale by 1/pi, so is a fairly trivial operation but important conceptually.
|
|
109
|
+
* @param harmonics Spherical harmonic coefficients (9)
|
|
110
|
+
*/
|
|
111
|
+
EnvironmentDeserializer._ConvertSHIrradianceToLambertianRadiance = function (harmonics) {
|
|
112
|
+
EnvironmentDeserializer._ScaleSH(harmonics, 1 / Math.PI);
|
|
113
|
+
// The resultant SH now represents outgoing radiance, so includes the Lambert 1/pi normalisation factor but without albedo (rho) applied
|
|
114
|
+
// (The pixel shader must apply albedo after texture fetches, etc).
|
|
115
|
+
};
|
|
116
|
+
/**
|
|
117
|
+
* Convert spherical harmonics to spherical polynomial coefficients
|
|
118
|
+
* @param harmonics Spherical harmonic coefficients (9)
|
|
119
|
+
* @param outPolynomialCoefficents Polynomial coefficients (9) object to store result
|
|
120
|
+
*/
|
|
121
|
+
EnvironmentDeserializer._ConvertSHToSP = function (harmonics, outPolynomialCoefficents) {
|
|
122
|
+
var rPi = 1 / Math.PI;
|
|
123
|
+
//x
|
|
124
|
+
outPolynomialCoefficents.x.x = 1.02333 * harmonics.l11[0] * rPi;
|
|
125
|
+
outPolynomialCoefficents.x.y = 1.02333 * harmonics.l11[1] * rPi;
|
|
126
|
+
outPolynomialCoefficents.x.z = 1.02333 * harmonics.l11[2] * rPi;
|
|
127
|
+
outPolynomialCoefficents.y.x = 1.02333 * harmonics.l1_1[0] * rPi;
|
|
128
|
+
outPolynomialCoefficents.y.y = 1.02333 * harmonics.l1_1[1] * rPi;
|
|
129
|
+
outPolynomialCoefficents.y.z = 1.02333 * harmonics.l1_1[2] * rPi;
|
|
130
|
+
outPolynomialCoefficents.z.x = 1.02333 * harmonics.l10[0] * rPi;
|
|
131
|
+
outPolynomialCoefficents.z.y = 1.02333 * harmonics.l10[1] * rPi;
|
|
132
|
+
outPolynomialCoefficents.z.z = 1.02333 * harmonics.l10[2] * rPi;
|
|
133
|
+
//xx
|
|
134
|
+
outPolynomialCoefficents.xx.x = (0.886277 * harmonics.l00[0] - 0.247708 * harmonics.l20[0] + 0.429043 * harmonics.l22[0]) * rPi;
|
|
135
|
+
outPolynomialCoefficents.xx.y = (0.886277 * harmonics.l00[1] - 0.247708 * harmonics.l20[1] + 0.429043 * harmonics.l22[1]) * rPi;
|
|
136
|
+
outPolynomialCoefficents.xx.z = (0.886277 * harmonics.l00[2] - 0.247708 * harmonics.l20[2] + 0.429043 * harmonics.l22[2]) * rPi;
|
|
137
|
+
outPolynomialCoefficents.yy.x = (0.886277 * harmonics.l00[0] - 0.247708 * harmonics.l20[0] - 0.429043 * harmonics.l22[0]) * rPi;
|
|
138
|
+
outPolynomialCoefficents.yy.y = (0.886277 * harmonics.l00[1] - 0.247708 * harmonics.l20[1] - 0.429043 * harmonics.l22[1]) * rPi;
|
|
139
|
+
outPolynomialCoefficents.yy.z = (0.886277 * harmonics.l00[2] - 0.247708 * harmonics.l20[2] - 0.429043 * harmonics.l22[2]) * rPi;
|
|
140
|
+
outPolynomialCoefficents.zz.x = (0.886277 * harmonics.l00[0] + 0.495417 * harmonics.l20[0]) * rPi;
|
|
141
|
+
outPolynomialCoefficents.zz.y = (0.886277 * harmonics.l00[1] + 0.495417 * harmonics.l20[1]) * rPi;
|
|
142
|
+
outPolynomialCoefficents.zz.z = (0.886277 * harmonics.l00[2] + 0.495417 * harmonics.l20[2]) * rPi;
|
|
143
|
+
//yz
|
|
144
|
+
outPolynomialCoefficents.yz.x = 0.858086 * harmonics.l2_1[0] * rPi;
|
|
145
|
+
outPolynomialCoefficents.yz.y = 0.858086 * harmonics.l2_1[1] * rPi;
|
|
146
|
+
outPolynomialCoefficents.yz.z = 0.858086 * harmonics.l2_1[2] * rPi;
|
|
147
|
+
outPolynomialCoefficents.zx.x = 0.858086 * harmonics.l21[0] * rPi;
|
|
148
|
+
outPolynomialCoefficents.zx.y = 0.858086 * harmonics.l21[1] * rPi;
|
|
149
|
+
outPolynomialCoefficents.zx.z = 0.858086 * harmonics.l21[2] * rPi;
|
|
150
|
+
outPolynomialCoefficents.xy.x = 0.858086 * harmonics.l2_2[0] * rPi;
|
|
151
|
+
outPolynomialCoefficents.xy.y = 0.858086 * harmonics.l2_2[1] * rPi;
|
|
152
|
+
outPolynomialCoefficents.xy.z = 0.858086 * harmonics.l2_2[2] * rPi;
|
|
153
|
+
};
|
|
154
|
+
/**
|
|
155
|
+
* Multiplies harmonic coefficients in place
|
|
156
|
+
* @param harmonics Spherical harmonic coefficients (9)
|
|
157
|
+
* @param scaleFactor Value to multiply by
|
|
158
|
+
*/
|
|
159
|
+
EnvironmentDeserializer._ScaleSH = function (harmonics, scaleFactor) {
|
|
160
|
+
harmonics.l00[0] *= scaleFactor;
|
|
161
|
+
harmonics.l00[1] *= scaleFactor;
|
|
162
|
+
harmonics.l00[2] *= scaleFactor;
|
|
163
|
+
harmonics.l1_1[0] *= scaleFactor;
|
|
164
|
+
harmonics.l1_1[1] *= scaleFactor;
|
|
165
|
+
harmonics.l1_1[2] *= scaleFactor;
|
|
166
|
+
harmonics.l10[0] *= scaleFactor;
|
|
167
|
+
harmonics.l10[1] *= scaleFactor;
|
|
168
|
+
harmonics.l10[2] *= scaleFactor;
|
|
169
|
+
harmonics.l11[0] *= scaleFactor;
|
|
170
|
+
harmonics.l11[1] *= scaleFactor;
|
|
171
|
+
harmonics.l11[2] *= scaleFactor;
|
|
172
|
+
harmonics.l2_2[0] *= scaleFactor;
|
|
173
|
+
harmonics.l2_2[1] *= scaleFactor;
|
|
174
|
+
harmonics.l2_2[2] *= scaleFactor;
|
|
175
|
+
harmonics.l2_1[0] *= scaleFactor;
|
|
176
|
+
harmonics.l2_1[1] *= scaleFactor;
|
|
177
|
+
harmonics.l2_1[2] *= scaleFactor;
|
|
178
|
+
harmonics.l20[0] *= scaleFactor;
|
|
179
|
+
harmonics.l20[1] *= scaleFactor;
|
|
180
|
+
harmonics.l20[2] *= scaleFactor;
|
|
181
|
+
harmonics.l21[0] *= scaleFactor;
|
|
182
|
+
harmonics.l21[1] *= scaleFactor;
|
|
183
|
+
harmonics.l21[2] *= scaleFactor;
|
|
184
|
+
harmonics.l22[0] *= scaleFactor;
|
|
185
|
+
harmonics.l22[1] *= scaleFactor;
|
|
186
|
+
harmonics.l22[2] *= scaleFactor;
|
|
187
|
+
};
|
|
188
|
+
return EnvironmentDeserializer;
|
|
189
|
+
}());
|
|
190
|
+
export { EnvironmentDeserializer };
|
|
187
191
|
//# sourceMappingURL=environmentSerializer.js.map
|